added prescaler for 16 bit pwm in LPC1347 target

Fork of mbed-dev by mbed official

targets/cmsis/TARGET_ARM_SSG/TARGET_BEETLE/fcache_api.c

Committer:
<>
Date:
2016-09-02
Revision:
144:ef7eb2e8f9f7

File content as of revision 144:ef7eb2e8f9f7:

/* mbed Microcontroller Library
 * Copyright (c) 2015 ARM Limited
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include "fcache_api.h"

static unsigned int enabled;
static unsigned int fcache_mode;
/* Functions */

/*
 * FCache_DriverInitialize: flash cache driver initialize funtion
 */
void FCache_DriverInitialize()
{
    unsigned int irqstat;

    /* Clear interrupt status register */
    irqstat = FCache_Readl(SYS_FCACHE_IRQSTAT) & (FCACHE_POW_ERR | FCACHE_MAN_INV_ERR);
    FCache_Writel(SYS_FCACHE_IRQSTAT, irqstat);

    /* Cache Disabled: Set enabled to 0 */
    enabled = 0;
}

/*
 * FCache_Enable: Enables the flash cache mode
 * mode: supported modes:
 * 0 - auto-power auto-invalidate
 * 1 - manual-power, manual-invalidate
 */
void FCache_Enable(int mode)
{
    /* Save Enable Mode */
    fcache_mode = mode;

    /* Enable the FCache */
    switch (fcache_mode) {
        case 0:
            /* Statistic counters enabled, Cache enable,
             * auto-inval, auto-power control
             */
            FCache_Writel(SYS_FCACHE_CCR, (FCACHE_EN | FCACHE_STATISTIC_EN));
            /* Wait until the cache is enabled */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_CS) != FCACHE_CS_ENABLED);
            /* Cache Enabled: Set enabled to 1 */
            enabled = 1;
            break;
        case 1:
            /*
             * Statistic counters enabled, Cache disabled,
             * Manual power request (Setting: Power CTRL:
             * Manual, Invalidate: Manual)
             */
            FCache_Writel(SYS_FCACHE_CCR, (FCACHE_POW_REQ
                        | FCACHE_SET_MAN_POW
                        | FCACHE_SET_MAN_INV
                        | FCACHE_STATISTIC_EN));
            /* Wait until the cache rams are powered */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_POW_STAT) != FCACHE_POW_STAT);
            /* Statistic counters enabled, Cache enabled
             * Manual invalidate request (Setting: Power CTRL:
             * Manual, Invalidate: Manual)
             */
            FCache_Writel(SYS_FCACHE_CCR, (FCACHE_INV_REQ
                        | FCACHE_POW_REQ
                        | FCACHE_SET_MAN_POW
                        | FCACHE_SET_MAN_INV
                        | FCACHE_STATISTIC_EN));
            /* Wait until the cache is invalidated */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_INV_STAT) == FCACHE_INV_STAT);
            /* Statistic counters enabled, Cache enable,
             * manual-inval, manual-power control
             */
            FCache_Writel(SYS_FCACHE_CCR, (FCACHE_EN
                        | FCACHE_POW_REQ
                        | FCACHE_SET_MAN_POW
                        | FCACHE_SET_MAN_INV
                        | FCACHE_STATISTIC_EN));
            /* Wait until the cache is enabled */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_CS) != FCACHE_CS_ENABLED);
            /* Cache Enabled: Set enabled to 1 */
            enabled = 1;
            break;
        default:
            break;
    }
}

/*
 * FCache_Disable: Disables the flash cache mode previously enabled
 */
void FCache_Disable()
{
    /* Disable the FCache */
    switch (fcache_mode) {
        case 0:
            /* Statistic counters enabled, Cache disable,
             * auto-inval, auto-power control
             */
            FCache_Writel(SYS_FCACHE_CCR, FCACHE_STATISTIC_EN);
            /* Wait until the cache is disabled */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_CS) != FCACHE_CS_DISABLED);
            /* Cache Enabled: Set enabled to 0 */
            enabled = 0;
            break;
        case 1:
            /* Statistic counters enabled, Cache disable,
             * manual-inval, manual-power control
             */
            FCache_Writel(SYS_FCACHE_CCR, (FCACHE_POW_REQ
                        | FCACHE_SET_MAN_POW
                        | FCACHE_SET_MAN_INV
                        | FCACHE_STATISTIC_EN));
            /* Wait until the cache is disabled */
            while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_CS) != FCACHE_CS_DISABLED);
            /* Cache Enabled: Set enabled to 0 */
            enabled = 0;
            break;
        default:
            break;
    }
}

/*
 * FCache_Invalidate: to be invalidated the cache needs to be disabled.
 * return -1: flash cannot be disabled
 *        -2: flash cannot be enabled
 */
int FCache_Invalidate()
{
    /* Manual cache invalidate */
    if (fcache_mode == 1)
    {
        /* Disable Flash Cache */
        if (enabled == 1)
            FCache_Disable();
        else
            goto error;

        /* Trigger INV_REQ */
        FCache_Writel(SYS_FCACHE_CCR, (FCACHE_INV_REQ
                    | FCACHE_POW_REQ
                    | FCACHE_SET_MAN_POW
                    | FCACHE_SET_MAN_INV
                    | FCACHE_STATISTIC_EN));

        /* Wait until INV_REQ is finished */
        while ((FCache_Readl(SYS_FCACHE_SR) & FCACHE_CS) != FCACHE_CS_DISABLED);

        /* Clear Stats */
        FCache_Writel(SYS_FCACHE_CSHR, 0);
        FCache_Writel(SYS_FCACHE_CSMR, 0);

        /* Enable Flash Cache */
        if (enabled == 0)
            FCache_Enable(1);

error:
        if (enabled == 0)
            return -1;
        else
            return -2;
    }

    return 0;
}

unsigned int * FCache_GetStats()
{
    static unsigned int stats[2];

    /* Cache Statistics HIT Register */
    stats[0] = FCache_Readl(SYS_FCACHE_CSHR);
    /* Cache Statistics MISS Register */
    stats[1] = FCache_Readl(SYS_FCACHE_CSMR);

    return stats;
}

/*
 * FCache_isEnabled: returns 1 if FCache is enabled
 */
unsigned int FCache_isEnabled()
{
    return enabled;
}