mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 03:32:49 +01:00
7db791476e
Signed-off-by: Jean Pierre Dudey <me@jeandudey.tech>
1637 lines
68 KiB
C
1637 lines
68 KiB
C
/******************************************************************************
|
|
* Filename: hw_prcm_h
|
|
* Revised: 2017-09-14 10:33:07 +0200 (Thu, 14 Sep 2017)
|
|
* Revision: 49733
|
|
*
|
|
* Copyright (c) 2015 - 2017, Texas Instruments Incorporated
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions are met:
|
|
*
|
|
* 1) Redistributions of source code must retain the above copyright notice,
|
|
* this list of conditions and the following disclaimer.
|
|
*
|
|
* 2) Redistributions in binary form must reproduce the above copyright notice,
|
|
* this list of conditions and the following disclaimer in the documentation
|
|
* and/or other materials provided with the distribution.
|
|
*
|
|
* 3) Neither the name of the ORGANIZATION nor the names of its contributors may
|
|
* be used to endorse or promote products derived from this software without
|
|
* specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
******************************************************************************/
|
|
|
|
#ifndef __HW_PRCM_H__
|
|
#define __HW_PRCM_H__
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// This section defines the register offsets of
|
|
// PRCM component
|
|
//
|
|
//*****************************************************************************
|
|
// Infrastructure Clock Division Factor For Run Mode
|
|
#define PRCM_O_INFRCLKDIVR 0x00000000
|
|
|
|
// Infrastructure Clock Division Factor For Sleep Mode
|
|
#define PRCM_O_INFRCLKDIVS 0x00000004
|
|
|
|
// Infrastructure Clock Division Factor For DeepSleep Mode
|
|
#define PRCM_O_INFRCLKDIVDS 0x00000008
|
|
|
|
// MCU Voltage Domain Control
|
|
#define PRCM_O_VDCTL 0x0000000C
|
|
|
|
// Load PRCM Settings To CLKCTRL Power Domain
|
|
#define PRCM_O_CLKLOADCTL 0x00000028
|
|
|
|
// RFC Clock Gate
|
|
#define PRCM_O_RFCCLKG 0x0000002C
|
|
|
|
// VIMS Clock Gate
|
|
#define PRCM_O_VIMSCLKG 0x00000030
|
|
|
|
// TRNG, CRYPTO And UDMA Clock Gate For Run Mode
|
|
#define PRCM_O_SECDMACLKGR 0x0000003C
|
|
|
|
// TRNG, CRYPTO And UDMA Clock Gate For Sleep Mode
|
|
#define PRCM_O_SECDMACLKGS 0x00000040
|
|
|
|
// TRNG, CRYPTO And UDMA Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_SECDMACLKGDS 0x00000044
|
|
|
|
// GPIO Clock Gate For Run Mode
|
|
#define PRCM_O_GPIOCLKGR 0x00000048
|
|
|
|
// GPIO Clock Gate For Sleep Mode
|
|
#define PRCM_O_GPIOCLKGS 0x0000004C
|
|
|
|
// GPIO Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_GPIOCLKGDS 0x00000050
|
|
|
|
// GPT Clock Gate For Run Mode
|
|
#define PRCM_O_GPTCLKGR 0x00000054
|
|
|
|
// GPT Clock Gate For Sleep Mode
|
|
#define PRCM_O_GPTCLKGS 0x00000058
|
|
|
|
// GPT Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_GPTCLKGDS 0x0000005C
|
|
|
|
// I2C Clock Gate For Run Mode
|
|
#define PRCM_O_I2CCLKGR 0x00000060
|
|
|
|
// I2C Clock Gate For Sleep Mode
|
|
#define PRCM_O_I2CCLKGS 0x00000064
|
|
|
|
// I2C Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_I2CCLKGDS 0x00000068
|
|
|
|
// UART Clock Gate For Run Mode
|
|
#define PRCM_O_UARTCLKGR 0x0000006C
|
|
|
|
// UART Clock Gate For Sleep Mode
|
|
#define PRCM_O_UARTCLKGS 0x00000070
|
|
|
|
// UART Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_UARTCLKGDS 0x00000074
|
|
|
|
// SSI Clock Gate For Run Mode
|
|
#define PRCM_O_SSICLKGR 0x00000078
|
|
|
|
// SSI Clock Gate For Sleep Mode
|
|
#define PRCM_O_SSICLKGS 0x0000007C
|
|
|
|
// SSI Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_SSICLKGDS 0x00000080
|
|
|
|
// I2S Clock Gate For Run Mode
|
|
#define PRCM_O_I2SCLKGR 0x00000084
|
|
|
|
// I2S Clock Gate For Sleep Mode
|
|
#define PRCM_O_I2SCLKGS 0x00000088
|
|
|
|
// I2S Clock Gate For Deep Sleep Mode
|
|
#define PRCM_O_I2SCLKGDS 0x0000008C
|
|
|
|
// Internal
|
|
#define PRCM_O_CPUCLKDIV 0x000000B8
|
|
|
|
// I2S Clock Control
|
|
#define PRCM_O_I2SBCLKSEL 0x000000C8
|
|
|
|
// GPT Scalar
|
|
#define PRCM_O_GPTCLKDIV 0x000000CC
|
|
|
|
// I2S Clock Control
|
|
#define PRCM_O_I2SCLKCTL 0x000000D0
|
|
|
|
// MCLK Division Ratio
|
|
#define PRCM_O_I2SMCLKDIV 0x000000D4
|
|
|
|
// BCLK Division Ratio
|
|
#define PRCM_O_I2SBCLKDIV 0x000000D8
|
|
|
|
// WCLK Division Ratio
|
|
#define PRCM_O_I2SWCLKDIV 0x000000DC
|
|
|
|
// SW Initiated Resets
|
|
#define PRCM_O_SWRESET 0x0000010C
|
|
|
|
// WARM Reset Control And Status
|
|
#define PRCM_O_WARMRESET 0x00000110
|
|
|
|
// Power Domain Control
|
|
#define PRCM_O_PDCTL0 0x0000012C
|
|
|
|
// RFC Power Domain Control
|
|
#define PRCM_O_PDCTL0RFC 0x00000130
|
|
|
|
// SERIAL Power Domain Control
|
|
#define PRCM_O_PDCTL0SERIAL 0x00000134
|
|
|
|
// PERIPH Power Domain Control
|
|
#define PRCM_O_PDCTL0PERIPH 0x00000138
|
|
|
|
// Power Domain Status
|
|
#define PRCM_O_PDSTAT0 0x00000140
|
|
|
|
// RFC Power Domain Status
|
|
#define PRCM_O_PDSTAT0RFC 0x00000144
|
|
|
|
// SERIAL Power Domain Status
|
|
#define PRCM_O_PDSTAT0SERIAL 0x00000148
|
|
|
|
// PERIPH Power Domain Status
|
|
#define PRCM_O_PDSTAT0PERIPH 0x0000014C
|
|
|
|
// Power Domain Control
|
|
#define PRCM_O_PDCTL1 0x0000017C
|
|
|
|
// CPU Power Domain Direct Control
|
|
#define PRCM_O_PDCTL1CPU 0x00000184
|
|
|
|
// RFC Power Domain Direct Control
|
|
#define PRCM_O_PDCTL1RFC 0x00000188
|
|
|
|
// VIMS Mode Direct Control
|
|
#define PRCM_O_PDCTL1VIMS 0x0000018C
|
|
|
|
// Power Manager Status
|
|
#define PRCM_O_PDSTAT1 0x00000194
|
|
|
|
// BUS Power Domain Direct Read Status
|
|
#define PRCM_O_PDSTAT1BUS 0x00000198
|
|
|
|
// RFC Power Domain Direct Read Status
|
|
#define PRCM_O_PDSTAT1RFC 0x0000019C
|
|
|
|
// CPU Power Domain Direct Read Status
|
|
#define PRCM_O_PDSTAT1CPU 0x000001A0
|
|
|
|
// VIMS Mode Direct Read Status
|
|
#define PRCM_O_PDSTAT1VIMS 0x000001A4
|
|
|
|
// Control To RFC
|
|
#define PRCM_O_RFCBITS 0x000001CC
|
|
|
|
// Selected RFC Mode
|
|
#define PRCM_O_RFCMODESEL 0x000001D0
|
|
|
|
// Allowed RFC Modes
|
|
#define PRCM_O_RFCMODEHWOPT 0x000001D4
|
|
|
|
// Power Profiler Register
|
|
#define PRCM_O_PWRPROFSTAT 0x000001E0
|
|
|
|
// Memory Retention Control
|
|
#define PRCM_O_RAMRETEN 0x00000224
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_INFRCLKDIVR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] RATIO
|
|
//
|
|
// Division rate for clocks driving modules in the MCU_AON domain when system
|
|
// CPU is in run mode. Division ratio affects both infrastructure clock and
|
|
// perbusull clock.
|
|
// ENUMs:
|
|
// DIV32 Divide by 32
|
|
// DIV8 Divide by 8
|
|
// DIV2 Divide by 2
|
|
// DIV1 Divide by 1
|
|
#define PRCM_INFRCLKDIVR_RATIO_W 2
|
|
#define PRCM_INFRCLKDIVR_RATIO_M 0x00000003
|
|
#define PRCM_INFRCLKDIVR_RATIO_S 0
|
|
#define PRCM_INFRCLKDIVR_RATIO_DIV32 0x00000003
|
|
#define PRCM_INFRCLKDIVR_RATIO_DIV8 0x00000002
|
|
#define PRCM_INFRCLKDIVR_RATIO_DIV2 0x00000001
|
|
#define PRCM_INFRCLKDIVR_RATIO_DIV1 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_INFRCLKDIVS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] RATIO
|
|
//
|
|
// Division rate for clocks driving modules in the MCU_AON domain when system
|
|
// CPU is in sleep mode. Division ratio affects both infrastructure clock and
|
|
// perbusull clock.
|
|
// ENUMs:
|
|
// DIV32 Divide by 32
|
|
// DIV8 Divide by 8
|
|
// DIV2 Divide by 2
|
|
// DIV1 Divide by 1
|
|
#define PRCM_INFRCLKDIVS_RATIO_W 2
|
|
#define PRCM_INFRCLKDIVS_RATIO_M 0x00000003
|
|
#define PRCM_INFRCLKDIVS_RATIO_S 0
|
|
#define PRCM_INFRCLKDIVS_RATIO_DIV32 0x00000003
|
|
#define PRCM_INFRCLKDIVS_RATIO_DIV8 0x00000002
|
|
#define PRCM_INFRCLKDIVS_RATIO_DIV2 0x00000001
|
|
#define PRCM_INFRCLKDIVS_RATIO_DIV1 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_INFRCLKDIVDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] RATIO
|
|
//
|
|
// Division rate for clocks driving modules in the MCU_AON domain when system
|
|
// CPU is in seepsleep mode. Division ratio affects both infrastructure clock
|
|
// and perbusull clock.
|
|
// ENUMs:
|
|
// DIV32 Divide by 32
|
|
// DIV8 Divide by 8
|
|
// DIV2 Divide by 2
|
|
// DIV1 Divide by 1
|
|
#define PRCM_INFRCLKDIVDS_RATIO_W 2
|
|
#define PRCM_INFRCLKDIVDS_RATIO_M 0x00000003
|
|
#define PRCM_INFRCLKDIVDS_RATIO_S 0
|
|
#define PRCM_INFRCLKDIVDS_RATIO_DIV32 0x00000003
|
|
#define PRCM_INFRCLKDIVDS_RATIO_DIV8 0x00000002
|
|
#define PRCM_INFRCLKDIVDS_RATIO_DIV2 0x00000001
|
|
#define PRCM_INFRCLKDIVDS_RATIO_DIV1 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_VDCTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] MCU_VD
|
|
//
|
|
// Request WUC to power down the MCU voltage domain
|
|
//
|
|
// 0: No request
|
|
// 1: Assert request when possible. An asserted power down request will result
|
|
// in a boot of the MCU system when powered up again.
|
|
//
|
|
// The bit will have no effect before the following requirements are met:
|
|
// 1. PDCTL1.CPU_ON = 0
|
|
// 2. PDCTL1.VIMS_MODE = 0
|
|
// 3. SECDMACLKGDS.DMA_CLK_EN = 0 (Note: Setting must be loaded with
|
|
// CLKLOADCTL.LOAD)
|
|
// 4. SECDMACLKGDS.CRYPTO_CLK_EN = 0 (Note: Setting must be loaded with
|
|
// CLKLOADCTL.LOAD)
|
|
// 5. RFC do no request access to BUS
|
|
// 6. System CPU in deepsleep
|
|
#define PRCM_VDCTL_MCU_VD 0x00000004
|
|
#define PRCM_VDCTL_MCU_VD_BITN 2
|
|
#define PRCM_VDCTL_MCU_VD_M 0x00000004
|
|
#define PRCM_VDCTL_MCU_VD_S 2
|
|
|
|
// Field: [0] ULDO
|
|
//
|
|
// Request WUC to switch to uLDO.
|
|
//
|
|
// 0: No request
|
|
// 1: Assert request when possible
|
|
//
|
|
// The bit will have no effect before the following requirements are met:
|
|
// 1. PDCTL1.CPU_ON = 0
|
|
// 2. PDCTL1.VIMS_MODE = 0
|
|
// 3. SECDMACLKGDS.DMA_CLK_EN = 0 (Note: Setting must be loaded with
|
|
// CLKLOADCTL.LOAD)
|
|
// 4. SECDMACLKGDS.CRYPTO_CLK_EN = 0 (Note: Setting must be loaded with
|
|
// CLKLOADCTL.LOAD)
|
|
// 5. RFC do no request access to BUS
|
|
// 6. System CPU in deepsleep
|
|
#define PRCM_VDCTL_ULDO 0x00000001
|
|
#define PRCM_VDCTL_ULDO_BITN 0
|
|
#define PRCM_VDCTL_ULDO_M 0x00000001
|
|
#define PRCM_VDCTL_ULDO_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_CLKLOADCTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1] LOAD_DONE
|
|
//
|
|
// Status of LOAD.
|
|
// Will be cleared to 0 when any of the registers requiring a LOAD is written
|
|
// to, and be set to 1 when a LOAD is done.
|
|
// Note that writing no change to a register will result in the LOAD_DONE being
|
|
// cleared.
|
|
//
|
|
// 0 : One or more registers have been write accessed after last LOAD
|
|
// 1 : No registers are write accessed after last LOAD
|
|
#define PRCM_CLKLOADCTL_LOAD_DONE 0x00000002
|
|
#define PRCM_CLKLOADCTL_LOAD_DONE_BITN 1
|
|
#define PRCM_CLKLOADCTL_LOAD_DONE_M 0x00000002
|
|
#define PRCM_CLKLOADCTL_LOAD_DONE_S 1
|
|
|
|
// Field: [0] LOAD
|
|
//
|
|
// 0: No action
|
|
// 1: Load settings to CLKCTRL. Bit is HW cleared.
|
|
//
|
|
// Multiple changes to settings may be done before LOAD is written once so all
|
|
// changes takes place at the same time. LOAD can also be done after single
|
|
// setting updates.
|
|
//
|
|
// Registers that needs to be followed by LOAD before settings being applied
|
|
// are:
|
|
// - RFCCLKG
|
|
// - VIMSCLKG
|
|
// - SECDMACLKGR
|
|
// - SECDMACLKGS
|
|
// - SECDMACLKGDS
|
|
// - GPIOCLKGR
|
|
// - GPIOCLKGS
|
|
// - GPIOCLKGDS
|
|
// - GPTCLKGR
|
|
// - GPTCLKGS
|
|
// - GPTCLKGDS
|
|
// - GPTCLKDIV
|
|
// - I2CCLKGR
|
|
// - I2CCLKGS
|
|
// - I2CCLKGDS
|
|
// - SSICLKGR
|
|
// - SSICLKGS
|
|
// - SSICLKGDS
|
|
// - UARTCLKGR
|
|
// - UARTCLKGS
|
|
// - UARTCLKGDS
|
|
// - I2SCLKGR
|
|
// - I2SCLKGS
|
|
// - I2SCLKGDS
|
|
// - I2SBCLKSEL
|
|
// - I2SCLKCTL
|
|
// - I2SMCLKDIV
|
|
// - I2SBCLKDIV
|
|
// - I2SWCLKDIV
|
|
#define PRCM_CLKLOADCTL_LOAD 0x00000001
|
|
#define PRCM_CLKLOADCTL_LOAD_BITN 0
|
|
#define PRCM_CLKLOADCTL_LOAD_M 0x00000001
|
|
#define PRCM_CLKLOADCTL_LOAD_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_RFCCLKG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock if RFC power domain is on
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_RFCCLKG_CLK_EN 0x00000001
|
|
#define PRCM_RFCCLKG_CLK_EN_BITN 0
|
|
#define PRCM_RFCCLKG_CLK_EN_M 0x00000001
|
|
#define PRCM_RFCCLKG_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_VIMSCLKG
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] CLK_EN
|
|
//
|
|
//
|
|
// 00: Disable clock
|
|
// 01: Disable clock when system CPU is in DeepSleep
|
|
// 11: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_VIMSCLKG_CLK_EN_W 2
|
|
#define PRCM_VIMSCLKG_CLK_EN_M 0x00000003
|
|
#define PRCM_VIMSCLKG_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SECDMACLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [8] DMA_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGR_DMA_CLK_EN 0x00000100
|
|
#define PRCM_SECDMACLKGR_DMA_CLK_EN_BITN 8
|
|
#define PRCM_SECDMACLKGR_DMA_CLK_EN_M 0x00000100
|
|
#define PRCM_SECDMACLKGR_DMA_CLK_EN_S 8
|
|
|
|
// Field: [1] TRNG_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGR_TRNG_CLK_EN 0x00000002
|
|
#define PRCM_SECDMACLKGR_TRNG_CLK_EN_BITN 1
|
|
#define PRCM_SECDMACLKGR_TRNG_CLK_EN_M 0x00000002
|
|
#define PRCM_SECDMACLKGR_TRNG_CLK_EN_S 1
|
|
|
|
// Field: [0] CRYPTO_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGR_CRYPTO_CLK_EN 0x00000001
|
|
#define PRCM_SECDMACLKGR_CRYPTO_CLK_EN_BITN 0
|
|
#define PRCM_SECDMACLKGR_CRYPTO_CLK_EN_M 0x00000001
|
|
#define PRCM_SECDMACLKGR_CRYPTO_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SECDMACLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [8] DMA_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGS_DMA_CLK_EN 0x00000100
|
|
#define PRCM_SECDMACLKGS_DMA_CLK_EN_BITN 8
|
|
#define PRCM_SECDMACLKGS_DMA_CLK_EN_M 0x00000100
|
|
#define PRCM_SECDMACLKGS_DMA_CLK_EN_S 8
|
|
|
|
// Field: [1] TRNG_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGS_TRNG_CLK_EN 0x00000002
|
|
#define PRCM_SECDMACLKGS_TRNG_CLK_EN_BITN 1
|
|
#define PRCM_SECDMACLKGS_TRNG_CLK_EN_M 0x00000002
|
|
#define PRCM_SECDMACLKGS_TRNG_CLK_EN_S 1
|
|
|
|
// Field: [0] CRYPTO_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGS_CRYPTO_CLK_EN 0x00000001
|
|
#define PRCM_SECDMACLKGS_CRYPTO_CLK_EN_BITN 0
|
|
#define PRCM_SECDMACLKGS_CRYPTO_CLK_EN_M 0x00000001
|
|
#define PRCM_SECDMACLKGS_CRYPTO_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SECDMACLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [8] DMA_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGDS_DMA_CLK_EN 0x00000100
|
|
#define PRCM_SECDMACLKGDS_DMA_CLK_EN_BITN 8
|
|
#define PRCM_SECDMACLKGDS_DMA_CLK_EN_M 0x00000100
|
|
#define PRCM_SECDMACLKGDS_DMA_CLK_EN_S 8
|
|
|
|
// Field: [1] TRNG_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGDS_TRNG_CLK_EN 0x00000002
|
|
#define PRCM_SECDMACLKGDS_TRNG_CLK_EN_BITN 1
|
|
#define PRCM_SECDMACLKGDS_TRNG_CLK_EN_M 0x00000002
|
|
#define PRCM_SECDMACLKGDS_TRNG_CLK_EN_S 1
|
|
|
|
// Field: [0] CRYPTO_CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_SECDMACLKGDS_CRYPTO_CLK_EN 0x00000001
|
|
#define PRCM_SECDMACLKGDS_CRYPTO_CLK_EN_BITN 0
|
|
#define PRCM_SECDMACLKGDS_CRYPTO_CLK_EN_M 0x00000001
|
|
#define PRCM_SECDMACLKGDS_CRYPTO_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPIOCLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_GPIOCLKGR_CLK_EN 0x00000001
|
|
#define PRCM_GPIOCLKGR_CLK_EN_BITN 0
|
|
#define PRCM_GPIOCLKGR_CLK_EN_M 0x00000001
|
|
#define PRCM_GPIOCLKGR_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPIOCLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_GPIOCLKGS_CLK_EN 0x00000001
|
|
#define PRCM_GPIOCLKGS_CLK_EN_BITN 0
|
|
#define PRCM_GPIOCLKGS_CLK_EN_M 0x00000001
|
|
#define PRCM_GPIOCLKGS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPIOCLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_GPIOCLKGDS_CLK_EN 0x00000001
|
|
#define PRCM_GPIOCLKGDS_CLK_EN_BITN 0
|
|
#define PRCM_GPIOCLKGDS_CLK_EN_M 0x00000001
|
|
#define PRCM_GPIOCLKGDS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPTCLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3:0] CLK_EN
|
|
//
|
|
// Each bit below has the following meaning:
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// ENUMs can be combined
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// GPT3 Enable clock for GPT3
|
|
// GPT2 Enable clock for GPT2
|
|
// GPT1 Enable clock for GPT1
|
|
// GPT0 Enable clock for GPT0
|
|
#define PRCM_GPTCLKGR_CLK_EN_W 4
|
|
#define PRCM_GPTCLKGR_CLK_EN_M 0x0000000F
|
|
#define PRCM_GPTCLKGR_CLK_EN_S 0
|
|
#define PRCM_GPTCLKGR_CLK_EN_GPT3 0x00000008
|
|
#define PRCM_GPTCLKGR_CLK_EN_GPT2 0x00000004
|
|
#define PRCM_GPTCLKGR_CLK_EN_GPT1 0x00000002
|
|
#define PRCM_GPTCLKGR_CLK_EN_GPT0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPTCLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3:0] CLK_EN
|
|
//
|
|
// Each bit below has the following meaning:
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// ENUMs can be combined
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// GPT3 Enable clock for GPT3
|
|
// GPT2 Enable clock for GPT2
|
|
// GPT1 Enable clock for GPT1
|
|
// GPT0 Enable clock for GPT0
|
|
#define PRCM_GPTCLKGS_CLK_EN_W 4
|
|
#define PRCM_GPTCLKGS_CLK_EN_M 0x0000000F
|
|
#define PRCM_GPTCLKGS_CLK_EN_S 0
|
|
#define PRCM_GPTCLKGS_CLK_EN_GPT3 0x00000008
|
|
#define PRCM_GPTCLKGS_CLK_EN_GPT2 0x00000004
|
|
#define PRCM_GPTCLKGS_CLK_EN_GPT1 0x00000002
|
|
#define PRCM_GPTCLKGS_CLK_EN_GPT0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPTCLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3:0] CLK_EN
|
|
//
|
|
// Each bit below has the following meaning:
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// ENUMs can be combined
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// GPT3 Enable clock for GPT3
|
|
// GPT2 Enable clock for GPT2
|
|
// GPT1 Enable clock for GPT1
|
|
// GPT0 Enable clock for GPT0
|
|
#define PRCM_GPTCLKGDS_CLK_EN_W 4
|
|
#define PRCM_GPTCLKGDS_CLK_EN_M 0x0000000F
|
|
#define PRCM_GPTCLKGDS_CLK_EN_S 0
|
|
#define PRCM_GPTCLKGDS_CLK_EN_GPT3 0x00000008
|
|
#define PRCM_GPTCLKGDS_CLK_EN_GPT2 0x00000004
|
|
#define PRCM_GPTCLKGDS_CLK_EN_GPT1 0x00000002
|
|
#define PRCM_GPTCLKGDS_CLK_EN_GPT0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2CCLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2CCLKGR_CLK_EN 0x00000001
|
|
#define PRCM_I2CCLKGR_CLK_EN_BITN 0
|
|
#define PRCM_I2CCLKGR_CLK_EN_M 0x00000001
|
|
#define PRCM_I2CCLKGR_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2CCLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2CCLKGS_CLK_EN 0x00000001
|
|
#define PRCM_I2CCLKGS_CLK_EN_BITN 0
|
|
#define PRCM_I2CCLKGS_CLK_EN_M 0x00000001
|
|
#define PRCM_I2CCLKGS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2CCLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2CCLKGDS_CLK_EN 0x00000001
|
|
#define PRCM_I2CCLKGDS_CLK_EN_BITN 0
|
|
#define PRCM_I2CCLKGDS_CLK_EN_M 0x00000001
|
|
#define PRCM_I2CCLKGDS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_UARTCLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_UARTCLKGR_CLK_EN 0x00000001
|
|
#define PRCM_UARTCLKGR_CLK_EN_BITN 0
|
|
#define PRCM_UARTCLKGR_CLK_EN_M 0x00000001
|
|
#define PRCM_UARTCLKGR_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_UARTCLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_UARTCLKGS_CLK_EN 0x00000001
|
|
#define PRCM_UARTCLKGS_CLK_EN_BITN 0
|
|
#define PRCM_UARTCLKGS_CLK_EN_M 0x00000001
|
|
#define PRCM_UARTCLKGS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_UARTCLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_UARTCLKGDS_CLK_EN 0x00000001
|
|
#define PRCM_UARTCLKGDS_CLK_EN_BITN 0
|
|
#define PRCM_UARTCLKGDS_CLK_EN_M 0x00000001
|
|
#define PRCM_UARTCLKGDS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SSICLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// SSI1 Enable clock for SSI1
|
|
// SSI0 Enable clock for SSI0
|
|
#define PRCM_SSICLKGR_CLK_EN_W 2
|
|
#define PRCM_SSICLKGR_CLK_EN_M 0x00000003
|
|
#define PRCM_SSICLKGR_CLK_EN_S 0
|
|
#define PRCM_SSICLKGR_CLK_EN_SSI1 0x00000002
|
|
#define PRCM_SSICLKGR_CLK_EN_SSI0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SSICLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// SSI1 Enable clock for SSI1
|
|
// SSI0 Enable clock for SSI0
|
|
#define PRCM_SSICLKGS_CLK_EN_W 2
|
|
#define PRCM_SSICLKGS_CLK_EN_M 0x00000003
|
|
#define PRCM_SSICLKGS_CLK_EN_S 0
|
|
#define PRCM_SSICLKGS_CLK_EN_SSI1 0x00000002
|
|
#define PRCM_SSICLKGS_CLK_EN_SSI0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SSICLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [1:0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// ENUMs:
|
|
// SSI1 Enable clock for SSI1
|
|
// SSI0 Enable clock for SSI0
|
|
#define PRCM_SSICLKGDS_CLK_EN_W 2
|
|
#define PRCM_SSICLKGDS_CLK_EN_M 0x00000003
|
|
#define PRCM_SSICLKGDS_CLK_EN_S 0
|
|
#define PRCM_SSICLKGDS_CLK_EN_SSI1 0x00000002
|
|
#define PRCM_SSICLKGDS_CLK_EN_SSI0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SCLKGR
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKGR_CLK_EN 0x00000001
|
|
#define PRCM_I2SCLKGR_CLK_EN_BITN 0
|
|
#define PRCM_I2SCLKGR_CLK_EN_M 0x00000001
|
|
#define PRCM_I2SCLKGR_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SCLKGS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKGS_CLK_EN 0x00000001
|
|
#define PRCM_I2SCLKGS_CLK_EN_BITN 0
|
|
#define PRCM_I2SCLKGS_CLK_EN_M 0x00000001
|
|
#define PRCM_I2SCLKGS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SCLKGDS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] CLK_EN
|
|
//
|
|
//
|
|
// 0: Disable clock
|
|
// 1: Enable clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKGDS_CLK_EN 0x00000001
|
|
#define PRCM_I2SCLKGDS_CLK_EN_BITN 0
|
|
#define PRCM_I2SCLKGDS_CLK_EN_M 0x00000001
|
|
#define PRCM_I2SCLKGDS_CLK_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_CPUCLKDIV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] RATIO
|
|
//
|
|
// Internal. Only to be used through TI provided API.
|
|
// ENUMs:
|
|
// DIV2 Internal. Only to be used through TI provided API.
|
|
// DIV1 Internal. Only to be used through TI provided API.
|
|
#define PRCM_CPUCLKDIV_RATIO 0x00000001
|
|
#define PRCM_CPUCLKDIV_RATIO_BITN 0
|
|
#define PRCM_CPUCLKDIV_RATIO_M 0x00000001
|
|
#define PRCM_CPUCLKDIV_RATIO_S 0
|
|
#define PRCM_CPUCLKDIV_RATIO_DIV2 0x00000001
|
|
#define PRCM_CPUCLKDIV_RATIO_DIV1 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SBCLKSEL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] SRC
|
|
//
|
|
// BCLK source selector
|
|
//
|
|
// 0: Use external BCLK
|
|
// 1: Use internally generated clock
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SBCLKSEL_SRC 0x00000001
|
|
#define PRCM_I2SBCLKSEL_SRC_BITN 0
|
|
#define PRCM_I2SBCLKSEL_SRC_M 0x00000001
|
|
#define PRCM_I2SBCLKSEL_SRC_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_GPTCLKDIV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3:0] RATIO
|
|
//
|
|
// Scalar used for GPTs. The division rate will be constant and ungated for Run
|
|
// / Sleep / DeepSleep mode.
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
// Other values are not supported.
|
|
// ENUMs:
|
|
// DIV256 Divide by 256
|
|
// DIV128 Divide by 128
|
|
// DIV64 Divide by 64
|
|
// DIV32 Divide by 32
|
|
// DIV16 Divide by 16
|
|
// DIV8 Divide by 8
|
|
// DIV4 Divide by 4
|
|
// DIV2 Divide by 2
|
|
// DIV1 Divide by 1
|
|
#define PRCM_GPTCLKDIV_RATIO_W 4
|
|
#define PRCM_GPTCLKDIV_RATIO_M 0x0000000F
|
|
#define PRCM_GPTCLKDIV_RATIO_S 0
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV256 0x00000008
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV128 0x00000007
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV64 0x00000006
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV32 0x00000005
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV16 0x00000004
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV8 0x00000003
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV4 0x00000002
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV2 0x00000001
|
|
#define PRCM_GPTCLKDIV_RATIO_DIV1 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SCLKCTL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3] SMPL_ON_POSEDGE
|
|
//
|
|
// On the I2S serial interface, data and WCLK is sampled and clocked out on
|
|
// opposite edges of BCLK.
|
|
//
|
|
// 0 - data and WCLK are sampled on the negative edge and clocked out on the
|
|
// positive edge.
|
|
// 1 - data and WCLK are sampled on the positive edge and clocked out on the
|
|
// negative edge.
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKCTL_SMPL_ON_POSEDGE 0x00000008
|
|
#define PRCM_I2SCLKCTL_SMPL_ON_POSEDGE_BITN 3
|
|
#define PRCM_I2SCLKCTL_SMPL_ON_POSEDGE_M 0x00000008
|
|
#define PRCM_I2SCLKCTL_SMPL_ON_POSEDGE_S 3
|
|
|
|
// Field: [2:1] WCLK_PHASE
|
|
//
|
|
// Decides how the WCLK division ratio is calculated and used to generate
|
|
// different duty cycles (See I2SWCLKDIV.WDIV).
|
|
//
|
|
// 0: Single phase
|
|
// 1: Dual phase
|
|
// 2: User Defined
|
|
// 3: Reserved/Undefined
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKCTL_WCLK_PHASE_W 2
|
|
#define PRCM_I2SCLKCTL_WCLK_PHASE_M 0x00000006
|
|
#define PRCM_I2SCLKCTL_WCLK_PHASE_S 1
|
|
|
|
// Field: [0] EN
|
|
//
|
|
//
|
|
// 0: MCLK, BCLK and WCLK will be static low
|
|
// 1: Enables the generation of MCLK, BCLK and WCLK
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SCLKCTL_EN 0x00000001
|
|
#define PRCM_I2SCLKCTL_EN_BITN 0
|
|
#define PRCM_I2SCLKCTL_EN_M 0x00000001
|
|
#define PRCM_I2SCLKCTL_EN_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SMCLKDIV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [9:0] MDIV
|
|
//
|
|
// An unsigned factor of the division ratio used to generate MCLK [2-1024]:
|
|
//
|
|
// MCLK = MCUCLK/MDIV[Hz]
|
|
// MCUCLK is 48MHz in normal mode. For powerdown mode the frequency is defined
|
|
// by AON_WUC:MCUCLK.PWR_DWN_SRC
|
|
//
|
|
// A value of 0 is interpreted as 1024.
|
|
// A value of 1 is invalid.
|
|
// If MDIV is odd the low phase of the clock is one MCUCLK period longer than
|
|
// the high phase.
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SMCLKDIV_MDIV_W 10
|
|
#define PRCM_I2SMCLKDIV_MDIV_M 0x000003FF
|
|
#define PRCM_I2SMCLKDIV_MDIV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SBCLKDIV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [9:0] BDIV
|
|
//
|
|
// An unsigned factor of the division ratio used to generate I2S BCLK [2-1024]:
|
|
//
|
|
// BCLK = MCUCLK/BDIV[Hz]
|
|
// MCUCLK is 48MHz in normal mode. For powerdown mode the frequency is defined
|
|
// by AON_WUC:MCUCLK.PWR_DWN_SRC
|
|
//
|
|
// A value of 0 is interpreted as 1024.
|
|
// A value of 1 is invalid.
|
|
// If BDIV is odd and I2SCLKCTL.SMPL_ON_POSEDGE = 0, the low phase of the clock
|
|
// is one MCUCLK period longer than the high phase.
|
|
// If BDIV is odd and I2SCLKCTL.SMPL_ON_POSEDGE = 1 , the high phase of the
|
|
// clock is one MCUCLK period longer than the low phase.
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SBCLKDIV_BDIV_W 10
|
|
#define PRCM_I2SBCLKDIV_BDIV_M 0x000003FF
|
|
#define PRCM_I2SBCLKDIV_BDIV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_I2SWCLKDIV
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [15:0] WDIV
|
|
//
|
|
// If I2SCLKCTL.WCLK_PHASE = 0, Single phase.
|
|
// WCLK is high one BCLK period and low WDIV[9:0] (unsigned, [1-1023]) BCLK
|
|
// periods.
|
|
//
|
|
// WCLK = MCUCLK / BDIV*(WDIV[9:0] + 1) [Hz]
|
|
// MCUCLK is 48MHz in normal mode. For powerdown mode the frequency is defined
|
|
// by AON_WUC:MCUCLK.PWR_DWN_SRC
|
|
//
|
|
// If I2SCLKCTL.WCLK_PHASE = 1, Dual phase.
|
|
// Each phase on WCLK (50% duty cycle) is WDIV[9:0] (unsigned, [1-1023]) BCLK
|
|
// periods.
|
|
//
|
|
// WCLK = MCUCLK / BDIV*(2*WDIV[9:0]) [Hz]
|
|
//
|
|
// If I2SCLKCTL.WCLK_PHASE = 2, User defined.
|
|
// WCLK is high WDIV[7:0] (unsigned, [1-255]) BCLK periods and low WDIV[15:8]
|
|
// (unsigned, [1-255]) BCLK periods.
|
|
//
|
|
// WCLK = MCUCLK / (BDIV*(WDIV[7:0] + WDIV[15:8]) [Hz]
|
|
//
|
|
// For changes to take effect, CLKLOADCTL.LOAD needs to be written
|
|
#define PRCM_I2SWCLKDIV_WDIV_W 16
|
|
#define PRCM_I2SWCLKDIV_WDIV_M 0x0000FFFF
|
|
#define PRCM_I2SWCLKDIV_WDIV_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_SWRESET
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] MCU
|
|
//
|
|
// Internal. Only to be used through TI provided API.
|
|
#define PRCM_SWRESET_MCU 0x00000004
|
|
#define PRCM_SWRESET_MCU_BITN 2
|
|
#define PRCM_SWRESET_MCU_M 0x00000004
|
|
#define PRCM_SWRESET_MCU_S 2
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_WARMRESET
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] WR_TO_PINRESET
|
|
//
|
|
// 0: No action
|
|
// 1: A warm system reset event triggered by the below listed sources will
|
|
// result in an emulated pin reset.
|
|
//
|
|
// Warm reset sources included:
|
|
// ICEPick sysreset
|
|
// System CPU reset request, CPU_SCS:AIRCR.SYSRESETREQ
|
|
// System CPU Lockup
|
|
// WDT timeout
|
|
//
|
|
// An active ICEPick block system reset will gate all sources except ICEPick
|
|
// sysreset
|
|
//
|
|
// SW can read AON_SYSCTL:RESETCTL.RESET_SRC to find the source of the last
|
|
// reset resulting in a full power up sequence. WARMRESET in this register is
|
|
// set in the scenario that WR_TO_PINRESET=1 and one of the above listed
|
|
// sources is triggered.
|
|
#define PRCM_WARMRESET_WR_TO_PINRESET 0x00000004
|
|
#define PRCM_WARMRESET_WR_TO_PINRESET_BITN 2
|
|
#define PRCM_WARMRESET_WR_TO_PINRESET_M 0x00000004
|
|
#define PRCM_WARMRESET_WR_TO_PINRESET_S 2
|
|
|
|
// Field: [1] LOCKUP_STAT
|
|
//
|
|
//
|
|
// 0: No registred event
|
|
// 1: A system CPU LOCKUP event has occured since last SW clear of the
|
|
// register.
|
|
//
|
|
// A read of this register clears both WDT_STAT and LOCKUP_STAT.
|
|
#define PRCM_WARMRESET_LOCKUP_STAT 0x00000002
|
|
#define PRCM_WARMRESET_LOCKUP_STAT_BITN 1
|
|
#define PRCM_WARMRESET_LOCKUP_STAT_M 0x00000002
|
|
#define PRCM_WARMRESET_LOCKUP_STAT_S 1
|
|
|
|
// Field: [0] WDT_STAT
|
|
//
|
|
//
|
|
// 0: No registered event
|
|
// 1: A WDT event has occured since last SW clear of the register.
|
|
//
|
|
// A read of this register clears both WDT_STAT and LOCKUP_STAT.
|
|
#define PRCM_WARMRESET_WDT_STAT 0x00000001
|
|
#define PRCM_WARMRESET_WDT_STAT_BITN 0
|
|
#define PRCM_WARMRESET_WDT_STAT_M 0x00000001
|
|
#define PRCM_WARMRESET_WDT_STAT_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL0
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] PERIPH_ON
|
|
//
|
|
// PERIPH Power domain.
|
|
//
|
|
// 0: PERIPH power domain is powered down
|
|
// 1: PERIPH power domain is powered up
|
|
#define PRCM_PDCTL0_PERIPH_ON 0x00000004
|
|
#define PRCM_PDCTL0_PERIPH_ON_BITN 2
|
|
#define PRCM_PDCTL0_PERIPH_ON_M 0x00000004
|
|
#define PRCM_PDCTL0_PERIPH_ON_S 2
|
|
|
|
// Field: [1] SERIAL_ON
|
|
//
|
|
// SERIAL Power domain.
|
|
//
|
|
// 0: SERIAL power domain is powered down
|
|
// 1: SERIAL power domain is powered up
|
|
#define PRCM_PDCTL0_SERIAL_ON 0x00000002
|
|
#define PRCM_PDCTL0_SERIAL_ON_BITN 1
|
|
#define PRCM_PDCTL0_SERIAL_ON_M 0x00000002
|
|
#define PRCM_PDCTL0_SERIAL_ON_S 1
|
|
|
|
// Field: [0] RFC_ON
|
|
//
|
|
//
|
|
// 0: RFC power domain powered off if also PDCTL1.RFC_ON = 0
|
|
// 1: RFC power domain powered on
|
|
#define PRCM_PDCTL0_RFC_ON 0x00000001
|
|
#define PRCM_PDCTL0_RFC_ON_BITN 0
|
|
#define PRCM_PDCTL0_RFC_ON_M 0x00000001
|
|
#define PRCM_PDCTL0_RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL0RFC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDCTL0.RFC_ON
|
|
#define PRCM_PDCTL0RFC_ON 0x00000001
|
|
#define PRCM_PDCTL0RFC_ON_BITN 0
|
|
#define PRCM_PDCTL0RFC_ON_M 0x00000001
|
|
#define PRCM_PDCTL0RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL0SERIAL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDCTL0.SERIAL_ON
|
|
#define PRCM_PDCTL0SERIAL_ON 0x00000001
|
|
#define PRCM_PDCTL0SERIAL_ON_BITN 0
|
|
#define PRCM_PDCTL0SERIAL_ON_M 0x00000001
|
|
#define PRCM_PDCTL0SERIAL_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL0PERIPH
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDCTL0.PERIPH_ON
|
|
#define PRCM_PDCTL0PERIPH_ON 0x00000001
|
|
#define PRCM_PDCTL0PERIPH_ON_BITN 0
|
|
#define PRCM_PDCTL0PERIPH_ON_M 0x00000001
|
|
#define PRCM_PDCTL0PERIPH_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT0
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] PERIPH_ON
|
|
//
|
|
// PERIPH Power domain.
|
|
//
|
|
// 0: Domain may be powered down
|
|
// 1: Domain powered up (guaranteed)
|
|
#define PRCM_PDSTAT0_PERIPH_ON 0x00000004
|
|
#define PRCM_PDSTAT0_PERIPH_ON_BITN 2
|
|
#define PRCM_PDSTAT0_PERIPH_ON_M 0x00000004
|
|
#define PRCM_PDSTAT0_PERIPH_ON_S 2
|
|
|
|
// Field: [1] SERIAL_ON
|
|
//
|
|
// SERIAL Power domain.
|
|
//
|
|
// 0: Domain may be powered down
|
|
// 1: Domain powered up (guaranteed)
|
|
#define PRCM_PDSTAT0_SERIAL_ON 0x00000002
|
|
#define PRCM_PDSTAT0_SERIAL_ON_BITN 1
|
|
#define PRCM_PDSTAT0_SERIAL_ON_M 0x00000002
|
|
#define PRCM_PDSTAT0_SERIAL_ON_S 1
|
|
|
|
// Field: [0] RFC_ON
|
|
//
|
|
// RFC Power domain
|
|
//
|
|
// 0: Domain may be powered down
|
|
// 1: Domain powered up (guaranteed)
|
|
#define PRCM_PDSTAT0_RFC_ON 0x00000001
|
|
#define PRCM_PDSTAT0_RFC_ON_BITN 0
|
|
#define PRCM_PDSTAT0_RFC_ON_M 0x00000001
|
|
#define PRCM_PDSTAT0_RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT0RFC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDSTAT0.RFC_ON
|
|
#define PRCM_PDSTAT0RFC_ON 0x00000001
|
|
#define PRCM_PDSTAT0RFC_ON_BITN 0
|
|
#define PRCM_PDSTAT0RFC_ON_M 0x00000001
|
|
#define PRCM_PDSTAT0RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT0SERIAL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDSTAT0.SERIAL_ON
|
|
#define PRCM_PDSTAT0SERIAL_ON 0x00000001
|
|
#define PRCM_PDSTAT0SERIAL_ON_BITN 0
|
|
#define PRCM_PDSTAT0SERIAL_ON_M 0x00000001
|
|
#define PRCM_PDSTAT0SERIAL_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT0PERIPH
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// Alias for PDSTAT0.PERIPH_ON
|
|
#define PRCM_PDSTAT0PERIPH_ON 0x00000001
|
|
#define PRCM_PDSTAT0PERIPH_ON_BITN 0
|
|
#define PRCM_PDSTAT0PERIPH_ON_M 0x00000001
|
|
#define PRCM_PDSTAT0PERIPH_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL1
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [3] VIMS_MODE
|
|
//
|
|
//
|
|
// 0: VIMS power domain is only powered when CPU power domain is powered.
|
|
// 1: VIMS power domain is powered whenever the BUS power domain is powered.
|
|
#define PRCM_PDCTL1_VIMS_MODE 0x00000008
|
|
#define PRCM_PDCTL1_VIMS_MODE_BITN 3
|
|
#define PRCM_PDCTL1_VIMS_MODE_M 0x00000008
|
|
#define PRCM_PDCTL1_VIMS_MODE_S 3
|
|
|
|
// Field: [2] RFC_ON
|
|
//
|
|
//
|
|
// 0: RFC power domain powered off if also PDCTL0.RFC_ON = 0
|
|
// 1: RFC power domain powered on
|
|
//
|
|
// Bit shall be used by RFC in autonomus mode but there is no HW restrictions
|
|
// fom system CPU to access the bit.
|
|
#define PRCM_PDCTL1_RFC_ON 0x00000004
|
|
#define PRCM_PDCTL1_RFC_ON_BITN 2
|
|
#define PRCM_PDCTL1_RFC_ON_M 0x00000004
|
|
#define PRCM_PDCTL1_RFC_ON_S 2
|
|
|
|
// Field: [1] CPU_ON
|
|
//
|
|
//
|
|
// 0: Causes a power down of the CPU power domain when system CPU indicates it
|
|
// is idle.
|
|
// 1: Initiates power-on of the CPU power domain.
|
|
//
|
|
// This bit is automatically set by a WIC power-on event.
|
|
#define PRCM_PDCTL1_CPU_ON 0x00000002
|
|
#define PRCM_PDCTL1_CPU_ON_BITN 1
|
|
#define PRCM_PDCTL1_CPU_ON_M 0x00000002
|
|
#define PRCM_PDCTL1_CPU_ON_S 1
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL1CPU
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDCTL1.CPU_ON
|
|
#define PRCM_PDCTL1CPU_ON 0x00000001
|
|
#define PRCM_PDCTL1CPU_ON_BITN 0
|
|
#define PRCM_PDCTL1CPU_ON_M 0x00000001
|
|
#define PRCM_PDCTL1CPU_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL1RFC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDCTL1.RFC_ON
|
|
#define PRCM_PDCTL1RFC_ON 0x00000001
|
|
#define PRCM_PDCTL1RFC_ON_BITN 0
|
|
#define PRCM_PDCTL1RFC_ON_M 0x00000001
|
|
#define PRCM_PDCTL1RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDCTL1VIMS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDCTL1.VIMS_MODE
|
|
#define PRCM_PDCTL1VIMS_ON 0x00000001
|
|
#define PRCM_PDCTL1VIMS_ON_BITN 0
|
|
#define PRCM_PDCTL1VIMS_ON_M 0x00000001
|
|
#define PRCM_PDCTL1VIMS_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT1
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [4] BUS_ON
|
|
//
|
|
//
|
|
// 0: BUS domain not accessible
|
|
// 1: BUS domain is currently accessible
|
|
#define PRCM_PDSTAT1_BUS_ON 0x00000010
|
|
#define PRCM_PDSTAT1_BUS_ON_BITN 4
|
|
#define PRCM_PDSTAT1_BUS_ON_M 0x00000010
|
|
#define PRCM_PDSTAT1_BUS_ON_S 4
|
|
|
|
// Field: [3] VIMS_MODE
|
|
//
|
|
//
|
|
// 0: VIMS domain not accessible
|
|
// 1: VIMS domain is currently accessible
|
|
#define PRCM_PDSTAT1_VIMS_MODE 0x00000008
|
|
#define PRCM_PDSTAT1_VIMS_MODE_BITN 3
|
|
#define PRCM_PDSTAT1_VIMS_MODE_M 0x00000008
|
|
#define PRCM_PDSTAT1_VIMS_MODE_S 3
|
|
|
|
// Field: [2] RFC_ON
|
|
//
|
|
//
|
|
// 0: RFC domain not accessible
|
|
// 1: RFC domain is currently accessible
|
|
#define PRCM_PDSTAT1_RFC_ON 0x00000004
|
|
#define PRCM_PDSTAT1_RFC_ON_BITN 2
|
|
#define PRCM_PDSTAT1_RFC_ON_M 0x00000004
|
|
#define PRCM_PDSTAT1_RFC_ON_S 2
|
|
|
|
// Field: [1] CPU_ON
|
|
//
|
|
//
|
|
// 0: CPU and BUS domain not accessible
|
|
// 1: CPU and BUS domains are both currently accessible
|
|
#define PRCM_PDSTAT1_CPU_ON 0x00000002
|
|
#define PRCM_PDSTAT1_CPU_ON_BITN 1
|
|
#define PRCM_PDSTAT1_CPU_ON_M 0x00000002
|
|
#define PRCM_PDSTAT1_CPU_ON_S 1
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT1BUS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDSTAT1.BUS_ON
|
|
#define PRCM_PDSTAT1BUS_ON 0x00000001
|
|
#define PRCM_PDSTAT1BUS_ON_BITN 0
|
|
#define PRCM_PDSTAT1BUS_ON_M 0x00000001
|
|
#define PRCM_PDSTAT1BUS_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT1RFC
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDSTAT1.RFC_ON
|
|
#define PRCM_PDSTAT1RFC_ON 0x00000001
|
|
#define PRCM_PDSTAT1RFC_ON_BITN 0
|
|
#define PRCM_PDSTAT1RFC_ON_M 0x00000001
|
|
#define PRCM_PDSTAT1RFC_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT1CPU
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDSTAT1.CPU_ON
|
|
#define PRCM_PDSTAT1CPU_ON 0x00000001
|
|
#define PRCM_PDSTAT1CPU_ON_BITN 0
|
|
#define PRCM_PDSTAT1CPU_ON_M 0x00000001
|
|
#define PRCM_PDSTAT1CPU_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PDSTAT1VIMS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [0] ON
|
|
//
|
|
// This is an alias for PDSTAT1.VIMS_MODE
|
|
#define PRCM_PDSTAT1VIMS_ON 0x00000001
|
|
#define PRCM_PDSTAT1VIMS_ON_BITN 0
|
|
#define PRCM_PDSTAT1VIMS_ON_M 0x00000001
|
|
#define PRCM_PDSTAT1VIMS_ON_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_RFCBITS
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [31:0] READ
|
|
//
|
|
// Control bits for RFC. The RF core CPE processor will automatically check
|
|
// this register when it boots, and it can be used to immediately instruct CPE
|
|
// to perform some tasks at its start-up. The supported functionality is
|
|
// ROM-defined and may vary. See the technical reference manual for more
|
|
// details.
|
|
#define PRCM_RFCBITS_READ_W 32
|
|
#define PRCM_RFCBITS_READ_M 0xFFFFFFFF
|
|
#define PRCM_RFCBITS_READ_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_RFCMODESEL
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2:0] CURR
|
|
//
|
|
// Selects the set of commands that the RFC will accept. Only modes permitted
|
|
// by RFCMODEHWOPT.AVAIL are writeable. See the technical reference manual for
|
|
// details.
|
|
// ENUMs:
|
|
// MODE7 Select Mode 7
|
|
// MODE6 Select Mode 6
|
|
// MODE5 Select Mode 5
|
|
// MODE4 Select Mode 4
|
|
// MODE3 Select Mode 3
|
|
// MODE2 Select Mode 2
|
|
// MODE1 Select Mode 1
|
|
// MODE0 Select Mode 0
|
|
#define PRCM_RFCMODESEL_CURR_W 3
|
|
#define PRCM_RFCMODESEL_CURR_M 0x00000007
|
|
#define PRCM_RFCMODESEL_CURR_S 0
|
|
#define PRCM_RFCMODESEL_CURR_MODE7 0x00000007
|
|
#define PRCM_RFCMODESEL_CURR_MODE6 0x00000006
|
|
#define PRCM_RFCMODESEL_CURR_MODE5 0x00000005
|
|
#define PRCM_RFCMODESEL_CURR_MODE4 0x00000004
|
|
#define PRCM_RFCMODESEL_CURR_MODE3 0x00000003
|
|
#define PRCM_RFCMODESEL_CURR_MODE2 0x00000002
|
|
#define PRCM_RFCMODESEL_CURR_MODE1 0x00000001
|
|
#define PRCM_RFCMODESEL_CURR_MODE0 0x00000000
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_RFCMODEHWOPT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] AVAIL
|
|
//
|
|
// Permitted RFC modes. More than one mode can be permitted.
|
|
// ENUMs:
|
|
// MODE7 Mode 7 permitted
|
|
// MODE6 Mode 6 permitted
|
|
// MODE5 Mode 5 permitted
|
|
// MODE4 Mode 4 permitted
|
|
// MODE3 Mode 3 permitted
|
|
// MODE2 Mode 2 permitted
|
|
// MODE1 Mode 1 permitted
|
|
// MODE0 Mode 0 permitted
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_W 8
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_M 0x000000FF
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_S 0
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE7 0x00000080
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE6 0x00000040
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE5 0x00000020
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE4 0x00000010
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE3 0x00000008
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE2 0x00000004
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE1 0x00000002
|
|
#define PRCM_RFCMODEHWOPT_AVAIL_MODE0 0x00000001
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_PWRPROFSTAT
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [7:0] VALUE
|
|
//
|
|
// SW can use these bits to timestamp the application. These bits are also
|
|
// available through the testtap and can thus be used by the emulator to
|
|
// profile in real time.
|
|
#define PRCM_PWRPROFSTAT_VALUE_W 8
|
|
#define PRCM_PWRPROFSTAT_VALUE_M 0x000000FF
|
|
#define PRCM_PWRPROFSTAT_VALUE_S 0
|
|
|
|
//*****************************************************************************
|
|
//
|
|
// Register: PRCM_O_RAMRETEN
|
|
//
|
|
//*****************************************************************************
|
|
// Field: [2] RFC
|
|
//
|
|
//
|
|
// 0: Retention for RFC SRAM disabled
|
|
// 1: Retention for RFC SRAM enabled
|
|
//
|
|
// Memories controlled: CPERAM MCERAM RFERAM
|
|
#define PRCM_RAMRETEN_RFC 0x00000004
|
|
#define PRCM_RAMRETEN_RFC_BITN 2
|
|
#define PRCM_RAMRETEN_RFC_M 0x00000004
|
|
#define PRCM_RAMRETEN_RFC_S 2
|
|
|
|
// Field: [1:0] VIMS
|
|
//
|
|
//
|
|
// 0: Memory retention disabled
|
|
// 1: Memory retention enabled
|
|
//
|
|
// Bit 0: VIMS_TRAM
|
|
// Bit 1: VIMS_CRAM
|
|
//
|
|
// Legal modes depend on settings in VIMS:CTL.MODE
|
|
//
|
|
// 00: VIMS:CTL.MODE must be OFF before DEEPSLEEP is asserted - must be set to
|
|
// CACHE or SPLIT mode after waking up again
|
|
// 01: VIMS:CTL.MODE must be GPRAM before DEEPSLEEP is asserted. Must remain in
|
|
// GPRAM mode after wake up, alternatively select OFF mode first and then CACHE
|
|
// or SPILT mode.
|
|
// 10: Illegal mode
|
|
// 11: No restrictions
|
|
#define PRCM_RAMRETEN_VIMS_W 2
|
|
#define PRCM_RAMRETEN_VIMS_M 0x00000003
|
|
#define PRCM_RAMRETEN_VIMS_S 0
|
|
|
|
|
|
#endif // __PRCM__
|