ext: hal: nxp: mcux: add device files for RT1020
Add mcux 2.5.0 soc drivers and header files for mimxrt1021. Origins: NXP MCUxpresso SDK 2.5.0 URL: mcuxpresso.nxp.com Maintained-by: External Signed-off-by: Ryan QIAN <jianghao.qian@nxp.com>
This commit is contained in:
parent
e66e6b054c
commit
7cd79d8207
10 changed files with 211744 additions and 0 deletions
|
@ -20,6 +20,7 @@ Status:
|
||||||
MIMXRT1052 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
MIMXRT1052 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
||||||
MIMXRT1061 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
MIMXRT1061 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
||||||
MIMXRT1062 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
MIMXRT1062 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
||||||
|
MIMXRT1021 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
||||||
MK64F12 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
MK64F12 SDK 2.5.0 (2018-12-17) REL_2.5.0_REL9_RFP_RC3_7_1
|
||||||
MKL25Z4 KSDK 2.2.0 (2017-06-29) REL6.GA.RC4.6_ISSDK1.6GAFIX.GEN
|
MKL25Z4 KSDK 2.2.0 (2017-06-29) REL6.GA.RC4.6_ISSDK1.6GAFIX.GEN
|
||||||
MKW21Z4 KSDK 2.2.0 (2018-01-19) release_conn_ksdk_2.2_kw41z_1.0.4_stage_final
|
MKW21Z4 KSDK 2.2.0 (2018-01-19) release_conn_ksdk_2.2_kw41z_1.0.4_stage_final
|
||||||
|
|
37290
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021.h
Normal file
37290
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021.h
Normal file
File diff suppressed because it is too large
Load diff
170220
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021.xml
Normal file
170220
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021.xml
Normal file
File diff suppressed because it is too large
Load diff
588
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021_features.h
Normal file
588
ext/hal/nxp/mcux/devices/MIMXRT1021/MIMXRT1021_features.h
Normal file
|
@ -0,0 +1,588 @@
|
||||||
|
/*
|
||||||
|
** ###################################################################
|
||||||
|
** Version: rev. 1.0, 2018-11-16
|
||||||
|
** Build: b181120
|
||||||
|
**
|
||||||
|
** Abstract:
|
||||||
|
** Chip specific module features.
|
||||||
|
**
|
||||||
|
** Copyright 2016 Freescale Semiconductor, Inc.
|
||||||
|
** Copyright 2016-2018 NXP
|
||||||
|
** All rights reserved.
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
**
|
||||||
|
** http: www.nxp.com
|
||||||
|
** mail: support@nxp.com
|
||||||
|
**
|
||||||
|
** Revisions:
|
||||||
|
** - rev. 0.1 (2017-06-06)
|
||||||
|
** Initial version.
|
||||||
|
** - rev. 1.0 (2018-11-16)
|
||||||
|
** Update feature files to align with IMXRT1020RM Rev.1.
|
||||||
|
**
|
||||||
|
** ###################################################################
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _MIMXRT1021_FEATURES_H_
|
||||||
|
#define _MIMXRT1021_FEATURES_H_
|
||||||
|
|
||||||
|
/* SOC module features */
|
||||||
|
|
||||||
|
/* @brief ADC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_ADC_COUNT (2)
|
||||||
|
/* @brief AIPSTZ availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_AIPSTZ_COUNT (4)
|
||||||
|
/* @brief AOI availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_AOI_COUNT (1)
|
||||||
|
/* @brief CCM availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_CCM_COUNT (1)
|
||||||
|
/* @brief CCM_ANALOG availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_CCM_ANALOG_COUNT (1)
|
||||||
|
/* @brief CMP availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_CMP_COUNT (4)
|
||||||
|
/* @brief DCDC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_DCDC_COUNT (1)
|
||||||
|
/* @brief DCP availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_DCP_COUNT (1)
|
||||||
|
/* @brief DMAMUX availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_DMAMUX_COUNT (1)
|
||||||
|
/* @brief EDMA availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_EDMA_COUNT (1)
|
||||||
|
/* @brief ENC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_ENC_COUNT (2)
|
||||||
|
/* @brief ENET availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_ENET_COUNT (1)
|
||||||
|
/* @brief EWM availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_EWM_COUNT (1)
|
||||||
|
/* @brief FLEXCAN availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_FLEXCAN_COUNT (2)
|
||||||
|
/* @brief FLEXIO availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_FLEXIO_COUNT (1)
|
||||||
|
/* @brief FLEXRAM availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_FLEXRAM_COUNT (1)
|
||||||
|
/* @brief FLEXSPI availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_FLEXSPI_COUNT (1)
|
||||||
|
/* @brief GPC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_GPC_COUNT (1)
|
||||||
|
/* @brief GPT availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_GPT_COUNT (2)
|
||||||
|
/* @brief I2S availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_I2S_COUNT (3)
|
||||||
|
/* @brief IGPIO availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_IGPIO_COUNT (4)
|
||||||
|
/* @brief IOMUXC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_IOMUXC_COUNT (1)
|
||||||
|
/* @brief IOMUXC_GPR availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_IOMUXC_GPR_COUNT (1)
|
||||||
|
/* @brief IOMUXC_SNVS availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_IOMUXC_SNVS_COUNT (1)
|
||||||
|
/* @brief KPP availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_KPP_COUNT (1)
|
||||||
|
/* @brief LPI2C availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_LPI2C_COUNT (4)
|
||||||
|
/* @brief LPSPI availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_LPSPI_COUNT (4)
|
||||||
|
/* @brief LPUART availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_LPUART_COUNT (8)
|
||||||
|
/* @brief OCOTP availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_OCOTP_COUNT (1)
|
||||||
|
/* @brief PIT availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_PIT_COUNT (1)
|
||||||
|
/* @brief PMU availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_PMU_COUNT (1)
|
||||||
|
/* @brief PWM availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_PWM_COUNT (2)
|
||||||
|
/* @brief ROMC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_ROMC_COUNT (1)
|
||||||
|
/* @brief SEMC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_SEMC_COUNT (1)
|
||||||
|
/* @brief SNVS availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_SNVS_COUNT (1)
|
||||||
|
/* @brief SPDIF availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_SPDIF_COUNT (1)
|
||||||
|
/* @brief SRC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_SRC_COUNT (1)
|
||||||
|
/* @brief TEMPMON availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_TEMPMON_COUNT (1)
|
||||||
|
/* @brief TMR availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_TMR_COUNT (2)
|
||||||
|
/* @brief TRNG availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_TRNG_COUNT (1)
|
||||||
|
/* @brief USBHS availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_USBHS_COUNT (1)
|
||||||
|
/* @brief USBNC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_USBNC_COUNT (1)
|
||||||
|
/* @brief USBPHY availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_USBPHY_COUNT (1)
|
||||||
|
/* @brief USDHC availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_USDHC_COUNT (2)
|
||||||
|
/* @brief WDOG availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_WDOG_COUNT (2)
|
||||||
|
/* @brief XBARA availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_XBARA_COUNT (1)
|
||||||
|
/* @brief XBARB availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_XBARB_COUNT (1)
|
||||||
|
/* @brief XTALOSC24M availability on the SoC. */
|
||||||
|
#define FSL_FEATURE_SOC_XTALOSC24M_COUNT (1)
|
||||||
|
|
||||||
|
/* ADC module features */
|
||||||
|
|
||||||
|
/* @brief Remove Hardware Trigger feature. */
|
||||||
|
#define FSL_FEATURE_ADC_SUPPORT_HARDWARE_TRIGGER_REMOVE (0)
|
||||||
|
/* @brief Remove ALT Clock selection feature. */
|
||||||
|
#define FSL_FEATURE_ADC_SUPPORT_ALTCLK_REMOVE (1)
|
||||||
|
|
||||||
|
/* ADC_ETC module features */
|
||||||
|
|
||||||
|
/* @brief Has DMA model control(bit field CTRL[DMA_MODE_SEL]). */
|
||||||
|
#define FSL_FEATURE_ADC_ETC_HAS_CTRL_DMA_MODE_SEL (0)
|
||||||
|
|
||||||
|
/* AOI module features */
|
||||||
|
|
||||||
|
/* @brief Maximum value of input mux. */
|
||||||
|
#define FSL_FEATURE_AOI_MODULE_INPUTS (4)
|
||||||
|
/* @brief Number of events related to number of registers AOIx_BFCRT01n/AOIx_BFCRT23n. */
|
||||||
|
#define FSL_FEATURE_AOI_EVENT_COUNT (4)
|
||||||
|
|
||||||
|
/* FLEXCAN module features */
|
||||||
|
|
||||||
|
/* @brief Message buffer size */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_MESSAGE_BUFFER_MAX_NUMBERn(x) (64)
|
||||||
|
/* @brief Has doze mode support (register bit field MCR[DOZE]). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_DOZE_MODE_SUPPORT (0)
|
||||||
|
/* @brief Insatnce has doze mode support (register bit field MCR[DOZE]). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_INSTANCE_HAS_DOZE_MODE_SUPPORTn(x) (0)
|
||||||
|
/* @brief Has a glitch filter on the receive pin (register bit field MCR[WAKSRC]). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_GLITCH_FILTER (1)
|
||||||
|
/* @brief Has extended interrupt mask and flag register (register IMASK2, IFLAG2). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_EXTENDED_FLAG_REGISTER (1)
|
||||||
|
/* @brief Instance has extended bit timing register (register CBT). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_INSTANCE_HAS_EXTENDED_TIMING_REGISTERn(x) (0)
|
||||||
|
/* @brief Has a receive FIFO DMA feature (register bit field MCR[DMA]). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_RX_FIFO_DMA (0)
|
||||||
|
/* @brief Instance has a receive FIFO DMA feature (register bit field MCR[DMA]). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_INSTANCE_HAS_RX_FIFO_DMAn(x) (0)
|
||||||
|
/* @brief Remove CAN Engine Clock Source Selection from unsupported part. */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_SUPPORT_ENGINE_CLK_SEL_REMOVE (1)
|
||||||
|
/* @brief Instance remove CAN Engine Clock Source Selection from unsupported part. */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_INSTANCE_SUPPORT_ENGINE_CLK_SEL_REMOVEn(x) (1)
|
||||||
|
/* @brief Is affected by errata with ID 5641 (Module does not transmit a message that is enabled to be transmitted at a specific moment during the arbitration process). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_ERRATA_5641 (0)
|
||||||
|
/* @brief Is affected by errata with ID 5829 (FlexCAN: FlexCAN does not transmit a message that is enabled to be transmitted in a specific moment during the arbitration process). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_ERRATA_5829 (1)
|
||||||
|
/* @brief Is affected by errata with ID 6032 (FlexCAN: A frame with wrong ID or payload is transmitted into the CAN bus when the Message Buffer under transmission is either aborted or deactivated while the CAN bus is in the Bus Idle state). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_ERRATA_6032 (1)
|
||||||
|
/* @brief Is affected by errata with ID 9595 (FlexCAN: Corrupt frame possible if the Freeze Mode or the Low-Power Mode are entered during a Bus-Off state). */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_ERRATA_9595 (1)
|
||||||
|
/* @brief Has CAN with Flexible Data rate (CAN FD) protocol. */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_FLEXIBLE_DATA_RATE (0)
|
||||||
|
/* @brief CAN instance support Flexible Data rate (CAN FD) protocol. */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_INSTANCE_HAS_FLEXIBLE_DATA_RATEn(x) (0)
|
||||||
|
/* @brief Has extra MB interrupt or common one. */
|
||||||
|
#define FSL_FEATURE_FLEXCAN_HAS_EXTRA_MB_INT (1)
|
||||||
|
|
||||||
|
/* CMP module features */
|
||||||
|
|
||||||
|
/* @brief Has Trigger mode in CMP (register bit field CR1[TRIGM]). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_TRIGGER_MODE (0)
|
||||||
|
/* @brief Has Window mode in CMP (register bit field CR1[WE]). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_WINDOW_MODE (1)
|
||||||
|
/* @brief Has External sample supported in CMP (register bit field CR1[SE]). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_EXTERNAL_SAMPLE_SUPPORT (1)
|
||||||
|
/* @brief Has DMA support in CMP (register bit field SCR[DMAEN]). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_DMA (1)
|
||||||
|
/* @brief Has Pass Through mode in CMP (register bit field MUXCR[PSTM]). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_PASS_THROUGH_MODE (0)
|
||||||
|
/* @brief Has DAC Test function in CMP (register DACTEST). */
|
||||||
|
#define FSL_FEATURE_CMP_HAS_DAC_TEST (0)
|
||||||
|
|
||||||
|
/* EDMA module features */
|
||||||
|
|
||||||
|
/* @brief Number of DMA channels (related to number of registers TCD, DCHPRI, bit fields ERQ[ERQn], EEI[EEIn], INT[INTn], ERR[ERRn], HRS[HRSn] and bit field widths ES[ERRCHN], CEEI[CEEI], SEEI[SEEI], CERQ[CERQ], SERQ[SERQ], CDNE[CDNE], SSRT[SSRT], CERR[CERR], CINT[CINT], TCDn_CITER_ELINKYES[LINKCH], TCDn_CSR[MAJORLINKCH], TCDn_BITER_ELINKYES[LINKCH]). (Valid only for eDMA modules.) */
|
||||||
|
#define FSL_FEATURE_EDMA_MODULE_CHANNEL (32)
|
||||||
|
/* @brief Total number of DMA channels on all modules. */
|
||||||
|
#define FSL_FEATURE_EDMA_DMAMUX_CHANNELS (32)
|
||||||
|
/* @brief Number of DMA channel groups (register bit fields CR[ERGA], CR[GRPnPRI], ES[GPE], DCHPRIn[GRPPRI]). (Valid only for eDMA modules.) */
|
||||||
|
#define FSL_FEATURE_EDMA_CHANNEL_GROUP_COUNT (1)
|
||||||
|
/* @brief Has DMA_Error interrupt vector. */
|
||||||
|
#define FSL_FEATURE_EDMA_HAS_ERROR_IRQ (1)
|
||||||
|
/* @brief Number of DMA channels with asynchronous request capability (register EARS). (Valid only for eDMA modules.) */
|
||||||
|
#define FSL_FEATURE_EDMA_ASYNCHRO_REQUEST_CHANNEL_COUNT (32)
|
||||||
|
|
||||||
|
/* DMAMUX module features */
|
||||||
|
|
||||||
|
/* @brief Number of DMA channels (related to number of register CHCFGn). */
|
||||||
|
#define FSL_FEATURE_DMAMUX_MODULE_CHANNEL (32)
|
||||||
|
/* @brief Total number of DMA channels on all modules. */
|
||||||
|
#define FSL_FEATURE_DMAMUX_DMAMUX_CHANNELS (FSL_FEATURE_SOC_DMAMUX_COUNT * 32)
|
||||||
|
/* @brief Has the periodic trigger capability for the triggered DMA channel (register bit CHCFG0[TRIG]). */
|
||||||
|
#define FSL_FEATURE_DMAMUX_HAS_TRIG (1)
|
||||||
|
/* @brief Has DMA Channel Always ON function (register bit CHCFG0[A_ON]). */
|
||||||
|
#define FSL_FEATURE_DMAMUX_HAS_A_ON (1)
|
||||||
|
|
||||||
|
/* ENET module features */
|
||||||
|
|
||||||
|
/* @brief Support Interrupt Coalesce */
|
||||||
|
#define FSL_FEATURE_ENET_HAS_INTERRUPT_COALESCE (1)
|
||||||
|
/* @brief Queue Size. */
|
||||||
|
#define FSL_FEATURE_ENET_QUEUE (1)
|
||||||
|
/* @brief Has AVB Support. */
|
||||||
|
#define FSL_FEATURE_ENET_HAS_AVB (0)
|
||||||
|
/* @brief Has Timer Pulse Width control. */
|
||||||
|
#define FSL_FEATURE_ENET_HAS_TIMER_PWCONTROL (1)
|
||||||
|
/* @brief Has Extend MDIO Support. */
|
||||||
|
#define FSL_FEATURE_ENET_HAS_EXTEND_MDIO (1)
|
||||||
|
/* @brief Has Additional 1588 Timer Channel Interrupt. */
|
||||||
|
#define FSL_FEATURE_ENET_HAS_ADD_1588_TIMER_CHN_INT (0)
|
||||||
|
|
||||||
|
/* EWM module features */
|
||||||
|
|
||||||
|
/* @brief Has clock select (register CLKCTRL). */
|
||||||
|
#define FSL_FEATURE_EWM_HAS_CLOCK_SELECT (1)
|
||||||
|
/* @brief Has clock prescaler (register CLKPRESCALER). */
|
||||||
|
#define FSL_FEATURE_EWM_HAS_PRESCALER (1)
|
||||||
|
|
||||||
|
/* FLEXIO module features */
|
||||||
|
|
||||||
|
/* @brief Has Shifter Status Register (FLEXIO_SHIFTSTAT) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_SHIFTER_STATUS (1)
|
||||||
|
/* @brief Has Pin Data Input Register (FLEXIO_PIN) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_PIN_STATUS (1)
|
||||||
|
/* @brief Has Shifter Buffer N Nibble Byte Swapped Register (FLEXIO_SHIFTBUFNBSn) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_NIBBLE_BYTE_SWAP (1)
|
||||||
|
/* @brief Has Shifter Buffer N Half Word Swapped Register (FLEXIO_SHIFTBUFHWSn) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_HALF_WORD_SWAP (1)
|
||||||
|
/* @brief Has Shifter Buffer N Nibble Swapped Register (FLEXIO_SHIFTBUFNISn) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_SHFT_BUFFER_NIBBLE_SWAP (1)
|
||||||
|
/* @brief Supports Shifter State Mode (FLEXIO_SHIFTCTLn[SMOD]) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_STATE_MODE (1)
|
||||||
|
/* @brief Supports Shifter Logic Mode (FLEXIO_SHIFTCTLn[SMOD]) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_LOGIC_MODE (1)
|
||||||
|
/* @brief Supports paralle width (FLEXIO_SHIFTCFGn[PWIDTH]) */
|
||||||
|
#define FSL_FEATURE_FLEXIO_HAS_PARALLEL_WIDTH (1)
|
||||||
|
/* @brief Reset value of the FLEXIO_VERID register */
|
||||||
|
#define FSL_FEATURE_FLEXIO_VERID_RESET_VALUE (0x1010001)
|
||||||
|
/* @brief Reset value of the FLEXIO_PARAM register */
|
||||||
|
#define FSL_FEATURE_FLEXIO_PARAM_RESET_VALUE (0x2200808)
|
||||||
|
|
||||||
|
/* FLEXRAM module features */
|
||||||
|
|
||||||
|
/* @brief Bank size */
|
||||||
|
#define FSL_FEATURE_FLEXRAM_INTERNAL_RAM_BANK_SIZE (32768)
|
||||||
|
/* @brief Total Bank numbers */
|
||||||
|
#define FSL_FEATURE_FLEXRAM_INTERNAL_RAM_TOTAL_BANK_NUMBERS (8)
|
||||||
|
|
||||||
|
/* FLEXSPI module features */
|
||||||
|
|
||||||
|
/* @brief FlexSPI AHB buffer count */
|
||||||
|
#define FSL_FEATURE_FLEXSPI_AHB_BUFFER_COUNTn(x) (4)
|
||||||
|
/* @brief FlexSPI has no data learn. */
|
||||||
|
#define FSL_FEATURE_FLEXSPI_HAS_NO_DATA_LEARN (1)
|
||||||
|
|
||||||
|
/* GPC module features */
|
||||||
|
|
||||||
|
/* @brief Has DVFS0 Change Request. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_DVFS0CR (0)
|
||||||
|
/* @brief Has GPC interrupt/event masking. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_GPCIRQM (0)
|
||||||
|
/* @brief Has L2 cache power control. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_L2PGE (0)
|
||||||
|
/* @brief Has FLEXRAM PDRAM0(bank1-7) power control. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_PDRAM0PGE (1)
|
||||||
|
/* @brief Has VADC power control. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_VADC (0)
|
||||||
|
/* @brief Has Display power control. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_CNTR_DISPLAY (0)
|
||||||
|
/* @brief Supports IRQ 0-31. */
|
||||||
|
#define FSL_FEATURE_GPC_HAS_IRQ_0_31 (1)
|
||||||
|
|
||||||
|
/* IGPIO module features */
|
||||||
|
|
||||||
|
/* @brief Has data register set DR_SET. */
|
||||||
|
#define FSL_FEATURE_IGPIO_HAS_DR_SET (1)
|
||||||
|
/* @brief Has data register clear DR_CLEAR. */
|
||||||
|
#define FSL_FEATURE_IGPIO_HAS_DR_CLEAR (1)
|
||||||
|
/* @brief Has data register toggle DR_TOGGLE. */
|
||||||
|
#define FSL_FEATURE_IGPIO_HAS_DR_TOGGLE (1)
|
||||||
|
|
||||||
|
/* LPI2C module features */
|
||||||
|
|
||||||
|
/* @brief Has separate DMA RX and TX requests. */
|
||||||
|
#define FSL_FEATURE_LPI2C_HAS_SEPARATE_DMA_RX_TX_REQn(x) (0)
|
||||||
|
/* @brief Capacity (number of entries) of the transmit/receive FIFO (or zero if no FIFO is available). */
|
||||||
|
#define FSL_FEATURE_LPI2C_FIFO_SIZEn(x) (4)
|
||||||
|
|
||||||
|
/* LPSPI module features */
|
||||||
|
|
||||||
|
/* @brief Capacity (number of entries) of the transmit/receive FIFO (or zero if no FIFO is available). */
|
||||||
|
#define FSL_FEATURE_LPSPI_FIFO_SIZEn(x) (16)
|
||||||
|
/* @brief Has separate DMA RX and TX requests. */
|
||||||
|
#define FSL_FEATURE_LPSPI_HAS_SEPARATE_DMA_RX_TX_REQn(x) (1)
|
||||||
|
|
||||||
|
/* LPUART module features */
|
||||||
|
|
||||||
|
/* @brief Has receive FIFO overflow detection (bit field CFIFO[RXOFE]). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_IRQ_EXTENDED_FUNCTIONS (0)
|
||||||
|
/* @brief Has low power features (can be enabled in wait mode via register bit C1[DOZEEN] or CTRL[DOZEEN] if the registers are 32-bit wide). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_LOW_POWER_UART_SUPPORT (1)
|
||||||
|
/* @brief Has extended data register ED (or extra flags in the DATA register if the registers are 32-bit wide). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_EXTENDED_DATA_REGISTER_FLAGS (1)
|
||||||
|
/* @brief Capacity (number of entries) of the transmit/receive FIFO (or zero if no FIFO is available). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_FIFO (1)
|
||||||
|
/* @brief Has 32-bit register MODIR */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_MODIR (1)
|
||||||
|
/* @brief Hardware flow control (RTS, CTS) is supported. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_MODEM_SUPPORT (1)
|
||||||
|
/* @brief Infrared (modulation) is supported. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_IR_SUPPORT (1)
|
||||||
|
/* @brief 2 bits long stop bit is available. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_STOP_BIT_CONFIG_SUPPORT (1)
|
||||||
|
/* @brief If 10-bit mode is supported. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_10BIT_DATA_SUPPORT (1)
|
||||||
|
/* @brief If 7-bit mode is supported. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_7BIT_DATA_SUPPORT (1)
|
||||||
|
/* @brief Baud rate fine adjustment is available. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_BAUD_RATE_FINE_ADJUST_SUPPORT (0)
|
||||||
|
/* @brief Baud rate oversampling is available (has bit fields C4[OSR], C5[BOTHEDGE], C5[RESYNCDIS] or BAUD[OSR], BAUD[BOTHEDGE], BAUD[RESYNCDIS] if the registers are 32-bit wide). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_BAUD_RATE_OVER_SAMPLING_SUPPORT (1)
|
||||||
|
/* @brief Baud rate oversampling is available. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_RX_RESYNC_SUPPORT (1)
|
||||||
|
/* @brief Baud rate oversampling is available. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_BOTH_EDGE_SAMPLING_SUPPORT (1)
|
||||||
|
/* @brief Peripheral type. */
|
||||||
|
#define FSL_FEATURE_LPUART_IS_SCI (1)
|
||||||
|
/* @brief Capacity (number of entries) of the transmit/receive FIFO (or zero if no FIFO is available). */
|
||||||
|
#define FSL_FEATURE_LPUART_FIFO_SIZEn(x) (4)
|
||||||
|
/* @brief Maximal data width without parity bit. */
|
||||||
|
#define FSL_FEATURE_LPUART_MAX_DATA_WIDTH_WITH_NO_PARITY (10)
|
||||||
|
/* @brief Maximal data width with parity bit. */
|
||||||
|
#define FSL_FEATURE_LPUART_MAX_DATA_WIDTH_WITH_PARITY (9)
|
||||||
|
/* @brief Supports two match addresses to filter incoming frames. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_ADDRESS_MATCHING (1)
|
||||||
|
/* @brief Has transmitter/receiver DMA enable bits C5[TDMAE]/C5[RDMAE] (or BAUD[TDMAE]/BAUD[RDMAE] if the registers are 32-bit wide). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_DMA_ENABLE (1)
|
||||||
|
/* @brief Has transmitter/receiver DMA select bits C4[TDMAS]/C4[RDMAS], resp. C5[TDMAS]/C5[RDMAS] if IS_SCI = 0. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_DMA_SELECT (0)
|
||||||
|
/* @brief Data character bit order selection is supported (bit field S2[MSBF] or STAT[MSBF] if the registers are 32-bit wide). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_BIT_ORDER_SELECT (1)
|
||||||
|
/* @brief Has smart card (ISO7816 protocol) support and no improved smart card support. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_SMART_CARD_SUPPORT (0)
|
||||||
|
/* @brief Has improved smart card (ISO7816 protocol) support. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_IMPROVED_SMART_CARD_SUPPORT (0)
|
||||||
|
/* @brief Has local operation network (CEA709.1-B protocol) support. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_LOCAL_OPERATION_NETWORK_SUPPORT (0)
|
||||||
|
/* @brief Has 32-bit registers (BAUD, STAT, CTRL, DATA, MATCH, MODIR) instead of 8-bit (BDH, BDL, C1, S1, D, etc.). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_32BIT_REGISTERS (1)
|
||||||
|
/* @brief Lin break detect available (has bit BAUD[LBKDIE]). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_LIN_BREAK_DETECT (1)
|
||||||
|
/* @brief UART stops in Wait mode available (has bit C1[UARTSWAI]). */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_WAIT_MODE_OPERATION (0)
|
||||||
|
/* @brief Has separate DMA RX and TX requests. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_SEPARATE_DMA_RX_TX_REQn(x) (1)
|
||||||
|
/* @brief Has separate RX and TX interrupts. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_SEPARATE_RX_TX_IRQ (0)
|
||||||
|
/* @brief Has LPAURT_PARAM. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_PARAM (1)
|
||||||
|
/* @brief Has LPUART_VERID. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_VERID (1)
|
||||||
|
/* @brief Has LPUART_GLOBAL. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_GLOBAL (1)
|
||||||
|
/* @brief Has LPUART_PINCFG. */
|
||||||
|
#define FSL_FEATURE_LPUART_HAS_PINCFG (1)
|
||||||
|
|
||||||
|
/* interrupt module features */
|
||||||
|
|
||||||
|
/* @brief Lowest interrupt request number. */
|
||||||
|
#define FSL_FEATURE_INTERRUPT_IRQ_MIN (-14)
|
||||||
|
/* @brief Highest interrupt request number. */
|
||||||
|
#define FSL_FEATURE_INTERRUPT_IRQ_MAX (141)
|
||||||
|
|
||||||
|
/* OCOTP module features */
|
||||||
|
|
||||||
|
/* No feature definitions */
|
||||||
|
|
||||||
|
/* PIT module features */
|
||||||
|
|
||||||
|
/* @brief Number of channels (related to number of registers LDVALn, CVALn, TCTRLn, TFLGn). */
|
||||||
|
#define FSL_FEATURE_PIT_TIMER_COUNT (4)
|
||||||
|
/* @brief Has lifetime timer (related to existence of registers LTMR64L and LTMR64H). */
|
||||||
|
#define FSL_FEATURE_PIT_HAS_LIFETIME_TIMER (1)
|
||||||
|
/* @brief Has chain mode (related to existence of register bit field TCTRLn[CHN]). */
|
||||||
|
#define FSL_FEATURE_PIT_HAS_CHAIN_MODE (1)
|
||||||
|
/* @brief Has shared interrupt handler (has not individual interrupt handler for each channel). */
|
||||||
|
#define FSL_FEATURE_PIT_HAS_SHARED_IRQ_HANDLER (1)
|
||||||
|
/* @brief Has timer enable control. */
|
||||||
|
#define FSL_FEATURE_PIT_HAS_MDIS (1)
|
||||||
|
|
||||||
|
/* PWM module features */
|
||||||
|
|
||||||
|
/* @brief Number of each EflexPWM module channels (outputs). */
|
||||||
|
#define FSL_FEATURE_PWM_CHANNEL_COUNT (12U)
|
||||||
|
/* @brief Number of EflexPWM module A channels (outputs). */
|
||||||
|
#define FSL_FEATURE_PWM_CHANNELA_COUNT (4U)
|
||||||
|
/* @brief Number of EflexPWM module B channels (outputs). */
|
||||||
|
#define FSL_FEATURE_PWM_CHANNELB_COUNT (4U)
|
||||||
|
/* @brief Number of EflexPWM module X channels (outputs). */
|
||||||
|
#define FSL_FEATURE_PWM_CHANNELX_COUNT (4U)
|
||||||
|
/* @brief Number of each EflexPWM module compare channels interrupts. */
|
||||||
|
#define FSL_FEATURE_PWM_CMP_INT_HANDLER_COUNT (4U)
|
||||||
|
/* @brief Number of each EflexPWM module reload channels interrupts. */
|
||||||
|
#define FSL_FEATURE_PWM_RELOAD_INT_HANDLER_COUNT (4U)
|
||||||
|
/* @brief Number of each EflexPWM module capture channels interrupts. */
|
||||||
|
#define FSL_FEATURE_PWM_CAP_INT_HANDLER_COUNT (1U)
|
||||||
|
/* @brief Number of each EflexPWM module reload error channels interrupts. */
|
||||||
|
#define FSL_FEATURE_PWM_RERR_INT_HANDLER_COUNT (1U)
|
||||||
|
/* @brief Number of each EflexPWM module fault channels interrupts. */
|
||||||
|
#define FSL_FEATURE_PWM_FAULT_INT_HANDLER_COUNT (1U)
|
||||||
|
/* @brief Number of submodules in each EflexPWM module. */
|
||||||
|
#define FSL_FEATURE_PWM_SUBMODULE_COUNT (4U)
|
||||||
|
|
||||||
|
/* RTWDOG module features */
|
||||||
|
|
||||||
|
/* @brief Watchdog is available. */
|
||||||
|
#define FSL_FEATURE_RTWDOG_HAS_WATCHDOG (1)
|
||||||
|
/* @brief RTWDOG_CNT can be 32-bit written. */
|
||||||
|
#define FSL_FEATURE_RTWDOG_HAS_32BIT_ACCESS (1)
|
||||||
|
|
||||||
|
/* SAI module features */
|
||||||
|
|
||||||
|
/* @brief Receive/transmit FIFO size in item count (register bit fields TCSR[FRDE], TCSR[FRIE], TCSR[FRF], TCR1[TFW], RCSR[FRDE], RCSR[FRIE], RCSR[FRF], RCR1[RFW], registers TFRn, RFRn). */
|
||||||
|
#define FSL_FEATURE_SAI_FIFO_COUNT (32)
|
||||||
|
/* @brief Receive/transmit channel number (register bit fields TCR3[TCE], RCR3[RCE], registers TDRn and RDRn). */
|
||||||
|
#define FSL_FEATURE_SAI_CHANNEL_COUNT (4)
|
||||||
|
/* @brief Maximum words per frame (register bit fields TCR3[WDFL], TCR4[FRSZ], TMR[TWM], RCR3[WDFL], RCR4[FRSZ], RMR[RWM]). */
|
||||||
|
#define FSL_FEATURE_SAI_MAX_WORDS_PER_FRAME (32)
|
||||||
|
/* @brief Has support of combining multiple data channel FIFOs into single channel FIFO (register bit fields TCR3[CFR], TCR4[FCOMB], TFR0[WCP], TFR1[WCP], RCR3[CFR], RCR4[FCOMB], RFR0[RCP], RFR1[RCP]). */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_FIFO_COMBINE_MODE (1)
|
||||||
|
/* @brief Has packing of 8-bit and 16-bit data into each 32-bit FIFO word (register bit fields TCR4[FPACK], RCR4[FPACK]). */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_FIFO_PACKING (1)
|
||||||
|
/* @brief Configures when the SAI will continue transmitting after a FIFO error has been detected (register bit fields TCR4[FCONT], RCR4[FCONT]). */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_FIFO_FUNCTION_AFTER_ERROR (1)
|
||||||
|
/* @brief Configures if the frame sync is generated internally, a frame sync is only generated when the FIFO warning flag is clear or continuously (register bit fields TCR4[ONDEM], RCR4[ONDEM]). */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_ON_DEMAND_MODE (1)
|
||||||
|
/* @brief Simplified bit clock source and asynchronous/synchronous mode selection (register bit fields TCR2[CLKMODE], RCR2[CLKMODE]), in comparison with the exclusively implemented TCR2[SYNC,BCS,BCI,MSEL], RCR2[SYNC,BCS,BCI,MSEL]. */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_CLOCKING_MODE (0)
|
||||||
|
/* @brief Has register for configuration of the MCLK divide ratio (register bit fields MDR[FRACT], MDR[DIVIDE]). */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_MCLKDIV_REGISTER (0)
|
||||||
|
/* @brief Interrupt source number */
|
||||||
|
#define FSL_FEATURE_SAI_INT_SOURCE_NUM (2)
|
||||||
|
/* @brief Has register of MCR. */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_MCR (0)
|
||||||
|
/* @brief Has bit field MICS of the MCR register. */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_NO_MCR_MICS (1)
|
||||||
|
/* @brief Has register of MDR */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_MDR (0)
|
||||||
|
/* @brief Has support the BCLK bypass mode when BCLK = MCLK. */
|
||||||
|
#define FSL_FEATURE_SAI_HAS_BCLK_BYPASS (0)
|
||||||
|
|
||||||
|
/* SEMC module features */
|
||||||
|
|
||||||
|
/* @brief Has WDH time in NOR controller (register bit field NORCR2[WDH]). */
|
||||||
|
#define FSL_FEATURE_SEMC_HAS_NOR_WDH_TIME (1)
|
||||||
|
/* @brief Has WDS time in NOR controller (register bit field NORCR2[WDS]).) */
|
||||||
|
#define FSL_FEATURE_SEMC_HAS_NOR_WDS_TIME (1)
|
||||||
|
|
||||||
|
/* SNVS module features */
|
||||||
|
|
||||||
|
/* @brief Has Secure Real Time Counter Enabled and Valid (bit field LPCR[SRTC_ENV]). */
|
||||||
|
#define FSL_FEATURE_SNVS_HAS_SRTC (1)
|
||||||
|
|
||||||
|
/* SRC module features */
|
||||||
|
|
||||||
|
/* @brief There is MASK_WDOG3_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_MASK_WDOG3_RST (1)
|
||||||
|
/* @brief There is MIX_RST_STRCH bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_MIX_RST_STRCH (0)
|
||||||
|
/* @brief There is DBG_RST_MSK_PG bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_DBG_RST_MSK_PG (1)
|
||||||
|
/* @brief There is WDOG3_RST_OPTN bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_WDOG3_RST_OPTN (0)
|
||||||
|
/* @brief There is CORES_DBG_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_CORES_DBG_RST (0)
|
||||||
|
/* @brief There is MTSR bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_MTSR (0)
|
||||||
|
/* @brief There is CORE0_DBG_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_CORE0_DBG_RST (1)
|
||||||
|
/* @brief There is CORE0_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_CORE0_RST (1)
|
||||||
|
/* @brief There is LOCKUP_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_LOCKUP_RST (1)
|
||||||
|
/* @brief There is SWRC bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_SWRC (0)
|
||||||
|
/* @brief There is EIM_RST bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_EIM_RST (0)
|
||||||
|
/* @brief There is LUEN bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SCR_LUEN (0)
|
||||||
|
/* @brief There is no WRBC bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_NO_SCR_WRBC (1)
|
||||||
|
/* @brief There is no WRE bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_NO_SCR_WRE (1)
|
||||||
|
/* @brief There is SISR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SISR (0)
|
||||||
|
/* @brief There is RESET_OUT bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_RESET_OUT (0)
|
||||||
|
/* @brief There is WDOG3_RST_B bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_WDOG3_RST_B (1)
|
||||||
|
/* @brief There is SW bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_SW (0)
|
||||||
|
/* @brief There is IPP_USER_RESET_B bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_IPP_USER_RESET_B (1)
|
||||||
|
/* @brief There is SNVS bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_SNVS (0)
|
||||||
|
/* @brief There is CSU_RESET_B bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_CSU_RESET_B (1)
|
||||||
|
/* @brief There is LOCKUP bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_LOCKUP (0)
|
||||||
|
/* @brief There is LOCKUP_SYSRESETREQ bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_LOCKUP_SYSRESETREQ (1)
|
||||||
|
/* @brief There is POR bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_POR (0)
|
||||||
|
/* @brief There is IPP_RESET_B bit in SRSR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_SRSR_IPP_RESET_B (1)
|
||||||
|
/* @brief There is no WBI bit in SCR register. */
|
||||||
|
#define FSL_FEATURE_SRC_HAS_NO_SRSR_WBI (1)
|
||||||
|
|
||||||
|
/* SCB module features */
|
||||||
|
|
||||||
|
/* @brief L1 ICACHE line size in byte. */
|
||||||
|
#define FSL_FEATURE_L1ICACHE_LINESIZE_BYTE (32)
|
||||||
|
/* @brief L1 DCACHE line size in byte. */
|
||||||
|
#define FSL_FEATURE_L1DCACHE_LINESIZE_BYTE (32)
|
||||||
|
|
||||||
|
/* TRNG module features */
|
||||||
|
|
||||||
|
/* @brief TRNG has no TRNG_ACC bitfield. */
|
||||||
|
#define FSL_FEATURE_TRNG_HAS_NO_TRNG_ACC (0)
|
||||||
|
|
||||||
|
/* USBHS module features */
|
||||||
|
|
||||||
|
/* @brief EHCI module instance count */
|
||||||
|
#define FSL_FEATURE_USBHS_EHCI_COUNT (1)
|
||||||
|
/* @brief Number of endpoints supported */
|
||||||
|
#define FSL_FEATURE_USBHS_ENDPT_COUNT (8)
|
||||||
|
|
||||||
|
/* USDHC module features */
|
||||||
|
|
||||||
|
/* @brief Has external DMA support (VEND_SPEC[EXT_DMA_EN]) */
|
||||||
|
#define FSL_FEATURE_USDHC_HAS_EXT_DMA (0)
|
||||||
|
/* @brief Has HS400 mode (MIX_CTRL[HS400_MODE]) */
|
||||||
|
#define FSL_FEATURE_USDHC_HAS_HS400_MODE (0)
|
||||||
|
/* @brief Has SDR50 support (HOST_CTRL_CAP[SDR50_SUPPORT]) */
|
||||||
|
#define FSL_FEATURE_USDHC_HAS_SDR50_MODE (1)
|
||||||
|
/* @brief Has SDR104 support (HOST_CTRL_CAP[SDR104_SUPPORT]) */
|
||||||
|
#define FSL_FEATURE_USDHC_HAS_SDR104_MODE (1)
|
||||||
|
|
||||||
|
/* XBARA module features */
|
||||||
|
|
||||||
|
/* @brief DMA_CH_MUX_REQ_30. */
|
||||||
|
#define FSL_FEATURE_XBARA_OUTPUT_DMA_CH_MUX_REQ_30 (1)
|
||||||
|
/* @brief DMA_CH_MUX_REQ_31. */
|
||||||
|
#define FSL_FEATURE_XBARA_OUTPUT_DMA_CH_MUX_REQ_31 (1)
|
||||||
|
/* @brief DMA_CH_MUX_REQ_94. */
|
||||||
|
#define FSL_FEATURE_XBARA_OUTPUT_DMA_CH_MUX_REQ_94 (1)
|
||||||
|
/* @brief DMA_CH_MUX_REQ_95. */
|
||||||
|
#define FSL_FEATURE_XBARA_OUTPUT_DMA_CH_MUX_REQ_95 (1)
|
||||||
|
|
||||||
|
#endif /* _MIMXRT1021_FEATURES_H_ */
|
||||||
|
|
943
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_clock.c
Normal file
943
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_clock.c
Normal file
|
@ -0,0 +1,943 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2018 NXP
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "fsl_clock.h"
|
||||||
|
/* Component ID definition, used by tools. */
|
||||||
|
#ifndef FSL_COMPONENT_ID
|
||||||
|
#define FSL_COMPONENT_ID "platform.drivers.clock"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Definitions
|
||||||
|
******************************************************************************/
|
||||||
|
/* To make full use of CM7 hardware FPU, use double instead of uint64_t in clock driver to
|
||||||
|
achieve better performance, it is depend on the IDE Floating point settings, if double precision is selected
|
||||||
|
in IDE, clock_64b_t will switch to double type automatically. only support IAR and MDK here */
|
||||||
|
#if __FPU_USED
|
||||||
|
|
||||||
|
#if ((defined(__ICCARM__)) || (defined(__GNUC__)))
|
||||||
|
|
||||||
|
#if (__ARMVFP__ >= __ARMFPV5__) && \
|
||||||
|
(__ARM_FP == 0xE) /*0xe implies support for half, single and double precision operations*/
|
||||||
|
typedef double clock_64b_t;
|
||||||
|
#else
|
||||||
|
typedef uint64_t clock_64b_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif defined(__CC_ARM) || defined(__ARMCC_VERSION)
|
||||||
|
|
||||||
|
#if defined __TARGET_FPU_FPV5_D16
|
||||||
|
typedef double clock_64b_t;
|
||||||
|
#else
|
||||||
|
typedef uint64_t clock_64b_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else
|
||||||
|
typedef uint64_t clock_64b_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#else
|
||||||
|
typedef uint64_t clock_64b_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Variables
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
/* External XTAL (OSC) clock frequency. */
|
||||||
|
volatile uint32_t g_xtalFreq;
|
||||||
|
/* External RTC XTAL clock frequency. */
|
||||||
|
volatile uint32_t g_rtcXtalFreq;
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Prototypes
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @brief Get the periph clock frequency.
|
||||||
|
*
|
||||||
|
* @return Periph clock frequency in Hz.
|
||||||
|
*/
|
||||||
|
static uint32_t CLOCK_GetPeriphClkFreq(void);
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* Code
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
static uint32_t CLOCK_GetPeriphClkFreq(void)
|
||||||
|
{
|
||||||
|
uint32_t freq;
|
||||||
|
|
||||||
|
/* Periph_clk2_clk ---> Periph_clk */
|
||||||
|
if (CCM->CBCDR & CCM_CBCDR_PERIPH_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
switch (CCM->CBCMR & CCM_CBCMR_PERIPH_CLK2_SEL_MASK)
|
||||||
|
{
|
||||||
|
/* Pll3_sw_clk ---> Periph_clk2_clk ---> Periph_clk */
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(0U):
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllUsb1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* Osc_clk ---> Periph_clk2_clk ---> Periph_clk */
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(1U):
|
||||||
|
freq = CLOCK_GetOscFreq();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(2U):
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllSys);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(3U):
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
freq /= (((CCM->CBCDR & CCM_CBCDR_PERIPH_CLK2_PODF_MASK) >> CCM_CBCDR_PERIPH_CLK2_PODF_SHIFT) + 1U);
|
||||||
|
}
|
||||||
|
/* Pre_Periph_clk ---> Periph_clk */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch (CCM->CBCMR & CCM_CBCMR_PRE_PERIPH_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
/* PLL2 */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(0U):
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllSys);
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL3 PFD3 */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(1U):
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd3);
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL2 PFD3 */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(2U):
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd3);
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL6 divided(/1) */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(3U):
|
||||||
|
freq = 500000000U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the external 24MHz clock.
|
||||||
|
*
|
||||||
|
* This function supports two modes:
|
||||||
|
* 1. Use external crystal oscillator.
|
||||||
|
* 2. Bypass the external crystal oscillator, using input source clock directly.
|
||||||
|
*
|
||||||
|
* After this function, please call ref CLOCK_SetXtal0Freq to inform clock driver
|
||||||
|
* the external clock frequency.
|
||||||
|
*
|
||||||
|
* param bypassXtalOsc Pass in true to bypass the external crystal oscillator.
|
||||||
|
* note This device does not support bypass external crystal oscillator, so
|
||||||
|
* the input parameter should always be false.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitExternalClk(bool bypassXtalOsc)
|
||||||
|
{
|
||||||
|
/* This device does not support bypass XTAL OSC. */
|
||||||
|
assert(!bypassXtalOsc);
|
||||||
|
|
||||||
|
CCM_ANALOG->MISC0_CLR = CCM_ANALOG_MISC0_XTAL_24M_PWD_MASK; /* Power up */
|
||||||
|
while ((XTALOSC24M->LOWPWR_CTRL & XTALOSC24M_LOWPWR_CTRL_XTALOSC_PWRUP_STAT_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
CCM_ANALOG->MISC0_SET = CCM_ANALOG_MISC0_OSC_XTALOK_EN_MASK; /* detect freq */
|
||||||
|
while ((CCM_ANALOG->MISC0 & CCM_ANALOG_MISC0_OSC_XTALOK_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
CCM_ANALOG->MISC0_CLR = CCM_ANALOG_MISC0_OSC_XTALOK_EN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Deinitialize the external 24MHz clock.
|
||||||
|
*
|
||||||
|
* This function disables the external 24MHz clock.
|
||||||
|
*
|
||||||
|
* After this function, please call ref CLOCK_SetXtal0Freq to set external clock
|
||||||
|
* frequency to 0.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitExternalClk(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->MISC0_SET = CCM_ANALOG_MISC0_XTAL_24M_PWD_MASK; /* Power down */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Switch the OSC.
|
||||||
|
*
|
||||||
|
* This function switches the OSC source for SoC.
|
||||||
|
*
|
||||||
|
* param osc OSC source to switch to.
|
||||||
|
*/
|
||||||
|
void CLOCK_SwitchOsc(clock_osc_t osc)
|
||||||
|
{
|
||||||
|
if (osc == kCLOCK_RcOsc)
|
||||||
|
XTALOSC24M->LOWPWR_CTRL_SET = XTALOSC24M_LOWPWR_CTRL_SET_OSC_SEL_MASK;
|
||||||
|
else
|
||||||
|
XTALOSC24M->LOWPWR_CTRL_CLR = XTALOSC24M_LOWPWR_CTRL_CLR_OSC_SEL_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the RC oscillator 24MHz clock.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitRcOsc24M(void)
|
||||||
|
{
|
||||||
|
XTALOSC24M->LOWPWR_CTRL |= XTALOSC24M_LOWPWR_CTRL_RC_OSC_EN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Power down the RCOSC 24M clock.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitRcOsc24M(void)
|
||||||
|
{
|
||||||
|
XTALOSC24M->LOWPWR_CTRL &= ~XTALOSC24M_LOWPWR_CTRL_RC_OSC_EN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Gets the AHB clock frequency.
|
||||||
|
*
|
||||||
|
* return The AHB clock frequency value in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetAhbFreq(void)
|
||||||
|
{
|
||||||
|
return CLOCK_GetPeriphClkFreq() / (((CCM->CBCDR & CCM_CBCDR_AHB_PODF_MASK) >> CCM_CBCDR_AHB_PODF_SHIFT) + 1U);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Gets the SEMC clock frequency.
|
||||||
|
*
|
||||||
|
* return The SEMC clock frequency value in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetSemcFreq(void)
|
||||||
|
{
|
||||||
|
uint32_t freq;
|
||||||
|
|
||||||
|
/* SEMC alternative clock ---> SEMC Clock */
|
||||||
|
if (CCM->CBCDR & CCM_CBCDR_SEMC_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
/* PLL3 PFD1 ---> SEMC alternative clock ---> SEMC Clock */
|
||||||
|
if (CCM->CBCDR & CCM_CBCDR_SEMC_ALT_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd1);
|
||||||
|
}
|
||||||
|
/* PLL2 PFD2 ---> SEMC alternative clock ---> SEMC Clock */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* Periph_clk ---> SEMC Clock */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
freq = CLOCK_GetPeriphClkFreq();
|
||||||
|
}
|
||||||
|
|
||||||
|
freq /= (((CCM->CBCDR & CCM_CBCDR_SEMC_PODF_MASK) >> CCM_CBCDR_SEMC_PODF_SHIFT) + 1U);
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Gets the IPG clock frequency.
|
||||||
|
*
|
||||||
|
* return The IPG clock frequency value in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetIpgFreq(void)
|
||||||
|
{
|
||||||
|
return CLOCK_GetAhbFreq() / (((CCM->CBCDR & CCM_CBCDR_IPG_PODF_MASK) >> CCM_CBCDR_IPG_PODF_SHIFT) + 1U);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Gets the PER clock frequency.
|
||||||
|
*
|
||||||
|
* return The PER clock frequency value in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetPerClkFreq(void)
|
||||||
|
{
|
||||||
|
uint32_t freq;
|
||||||
|
|
||||||
|
/* Osc_clk ---> PER Clock*/
|
||||||
|
if (CCM->CSCMR1 & CCM_CSCMR1_PERCLK_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
freq = CLOCK_GetOscFreq();
|
||||||
|
}
|
||||||
|
/* Periph_clk ---> AHB Clock ---> IPG Clock ---> PER Clock */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
freq = CLOCK_GetFreq(kCLOCK_IpgClk);
|
||||||
|
}
|
||||||
|
|
||||||
|
freq /= (((CCM->CSCMR1 & CCM_CSCMR1_PERCLK_PODF_MASK) >> CCM_CSCMR1_PERCLK_PODF_SHIFT) + 1U);
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Gets the clock frequency for a specific clock name.
|
||||||
|
*
|
||||||
|
* This function checks the current clock configurations and then calculates
|
||||||
|
* the clock frequency for a specific clock name defined in clock_name_t.
|
||||||
|
*
|
||||||
|
* param clockName Clock names defined in clock_name_t
|
||||||
|
* return Clock frequency value in hertz
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetFreq(clock_name_t name)
|
||||||
|
{
|
||||||
|
uint32_t freq;
|
||||||
|
|
||||||
|
switch (name)
|
||||||
|
{
|
||||||
|
case kCLOCK_CpuClk:
|
||||||
|
case kCLOCK_AhbClk:
|
||||||
|
freq = CLOCK_GetAhbFreq();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_SemcClk:
|
||||||
|
freq = CLOCK_GetSemcFreq();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_IpgClk:
|
||||||
|
freq = CLOCK_GetIpgFreq();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PerClk:
|
||||||
|
freq = CLOCK_GetPerClkFreq();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_OscClk:
|
||||||
|
freq = CLOCK_GetOscFreq();
|
||||||
|
break;
|
||||||
|
case kCLOCK_RtcClk:
|
||||||
|
freq = CLOCK_GetRtcFreq();
|
||||||
|
break;
|
||||||
|
case kCLOCK_Usb1PllClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllUsb1);
|
||||||
|
break;
|
||||||
|
case kCLOCK_Usb1PllPfd0Clk:
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd0);
|
||||||
|
break;
|
||||||
|
case kCLOCK_Usb1PllPfd1Clk:
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd1);
|
||||||
|
break;
|
||||||
|
case kCLOCK_Usb1PllPfd2Clk:
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd2);
|
||||||
|
break;
|
||||||
|
case kCLOCK_Usb1PllPfd3Clk:
|
||||||
|
freq = CLOCK_GetUsb1PfdFreq(kCLOCK_Pfd3);
|
||||||
|
break;
|
||||||
|
case kCLOCK_SysPllClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllSys);
|
||||||
|
break;
|
||||||
|
case kCLOCK_SysPllPfd0Clk:
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd0);
|
||||||
|
break;
|
||||||
|
case kCLOCK_SysPllPfd1Clk:
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd1);
|
||||||
|
break;
|
||||||
|
case kCLOCK_SysPllPfd2Clk:
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd2);
|
||||||
|
break;
|
||||||
|
case kCLOCK_SysPllPfd3Clk:
|
||||||
|
freq = CLOCK_GetSysPfdFreq(kCLOCK_Pfd3);
|
||||||
|
break;
|
||||||
|
case kCLOCK_EnetPllClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllEnet);
|
||||||
|
break;
|
||||||
|
case kCLOCK_EnetPll25MClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllEnet25M);
|
||||||
|
break;
|
||||||
|
case kCLOCK_EnetPll500MClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllEnet500M);
|
||||||
|
break;
|
||||||
|
case kCLOCK_AudioPllClk:
|
||||||
|
freq = CLOCK_GetPllFreq(kCLOCK_PllAudio);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! brief Enable USB HS clock.
|
||||||
|
*
|
||||||
|
* This function only enables the access to USB HS prepheral, upper layer
|
||||||
|
* should first call the ref CLOCK_EnableUsbhs0PhyPllClock to enable the PHY
|
||||||
|
* clock to use USB HS.
|
||||||
|
*
|
||||||
|
* param src USB HS does not care about the clock source, here must be ref kCLOCK_UsbSrcUnused.
|
||||||
|
* param freq USB HS does not care about the clock source, so this parameter is ignored.
|
||||||
|
* retval true The clock is set successfully.
|
||||||
|
* retval false The clock source is invalid to get proper USB HS clock.
|
||||||
|
*/
|
||||||
|
bool CLOCK_EnableUsbhs0Clock(clock_usb_src_t src, uint32_t freq)
|
||||||
|
{
|
||||||
|
CCM->CCGR6 |= CCM_CCGR6_CG0_MASK;
|
||||||
|
USB->USBCMD |= USBHS_USBCMD_RST_MASK;
|
||||||
|
for (volatile uint32_t i = 0; i < 400000;
|
||||||
|
i++) /* Add a delay between RST and RS so make sure there is a DP pullup sequence*/
|
||||||
|
{
|
||||||
|
__ASM("nop");
|
||||||
|
}
|
||||||
|
PMU->REG_3P0 = (PMU->REG_3P0 & (~PMU_REG_3P0_OUTPUT_TRG_MASK)) |
|
||||||
|
(PMU_REG_3P0_OUTPUT_TRG(0x17) | PMU_REG_3P0_ENABLE_LINREG_MASK);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! brief Enable USB HS PHY PLL clock.
|
||||||
|
*
|
||||||
|
* This function enables the internal 480MHz USB PHY PLL clock.
|
||||||
|
*
|
||||||
|
* param src USB HS PHY PLL clock source.
|
||||||
|
* param freq The frequency specified by src.
|
||||||
|
* retval true The clock is set successfully.
|
||||||
|
* retval false The clock source is invalid to get proper USB HS clock.
|
||||||
|
*/
|
||||||
|
bool CLOCK_EnableUsbhs0PhyPllClock(clock_usb_phy_src_t src, uint32_t freq)
|
||||||
|
{
|
||||||
|
const clock_usb_pll_config_t g_ccmConfigUsbPll = {.loopDivider = 0U};
|
||||||
|
if (CCM_ANALOG->PLL_USB1 & CCM_ANALOG_PLL_USB1_ENABLE_MASK)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_USB1 |= CCM_ANALOG_PLL_USB1_EN_USB_CLKS_MASK;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CLOCK_InitUsb1Pll(&g_ccmConfigUsbPll);
|
||||||
|
}
|
||||||
|
USBPHY->CTRL &= ~USBPHY_CTRL_SFTRST_MASK; /* release PHY from reset */
|
||||||
|
USBPHY->CTRL &= ~USBPHY_CTRL_CLKGATE_MASK;
|
||||||
|
|
||||||
|
USBPHY->PWD = 0;
|
||||||
|
USBPHY->CTRL |= USBPHY_CTRL_ENAUTOCLR_PHY_PWD_MASK | USBPHY_CTRL_ENAUTOCLR_CLKGATE_MASK |
|
||||||
|
USBPHY_CTRL_ENUTMILEVEL2_MASK | USBPHY_CTRL_ENUTMILEVEL3_MASK;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! brief Disable USB HS PHY PLL clock.
|
||||||
|
*
|
||||||
|
* This function disables USB HS PHY PLL clock.
|
||||||
|
*/
|
||||||
|
void CLOCK_DisableUsbhs0PhyPllClock(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_USB1 &= ~CCM_ANALOG_PLL_USB1_EN_USB_CLKS_MASK;
|
||||||
|
USBPHY->CTRL |= USBPHY_CTRL_CLKGATE_MASK; /* Set to 1U to gate clocks */
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the System PLL.
|
||||||
|
*
|
||||||
|
* This function initializes the System PLL with specific settings
|
||||||
|
*
|
||||||
|
* param config Configuration to set to PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitSysPll(const clock_sys_pll_config_t *config)
|
||||||
|
{
|
||||||
|
/* Bypass PLL first */
|
||||||
|
CCM_ANALOG->PLL_SYS = (CCM_ANALOG->PLL_SYS & (~CCM_ANALOG_PLL_SYS_BYPASS_CLK_SRC_MASK)) |
|
||||||
|
CCM_ANALOG_PLL_SYS_BYPASS_MASK | CCM_ANALOG_PLL_SYS_BYPASS_CLK_SRC(config->src);
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_SYS =
|
||||||
|
(CCM_ANALOG->PLL_SYS & (~(CCM_ANALOG_PLL_SYS_DIV_SELECT_MASK | CCM_ANALOG_PLL_SYS_POWERDOWN_MASK))) |
|
||||||
|
CCM_ANALOG_PLL_SYS_ENABLE_MASK | CCM_ANALOG_PLL_SYS_DIV_SELECT(config->loopDivider);
|
||||||
|
|
||||||
|
/* Initialize the fractional mode */
|
||||||
|
CCM_ANALOG->PLL_SYS_NUM = CCM_ANALOG_PLL_SYS_NUM_A(config->numerator);
|
||||||
|
CCM_ANALOG->PLL_SYS_DENOM = CCM_ANALOG_PLL_SYS_DENOM_B(config->denominator);
|
||||||
|
|
||||||
|
/* Initialize the spread spectrum mode */
|
||||||
|
CCM_ANALOG->PLL_SYS_SS = CCM_ANALOG_PLL_SYS_SS_STEP(config->ss_step) |
|
||||||
|
CCM_ANALOG_PLL_SYS_SS_ENABLE(config->ss_enable) |
|
||||||
|
CCM_ANALOG_PLL_SYS_SS_STOP(config->ss_stop);
|
||||||
|
|
||||||
|
while ((CCM_ANALOG->PLL_SYS & CCM_ANALOG_PLL_SYS_LOCK_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Bypass */
|
||||||
|
CCM_ANALOG->PLL_SYS &= ~CCM_ANALOG_PLL_SYS_BYPASS_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief De-initialize the System PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitSysPll(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_SYS = CCM_ANALOG_PLL_SYS_POWERDOWN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the USB1 PLL.
|
||||||
|
*
|
||||||
|
* This function initializes the USB1 PLL with specific settings
|
||||||
|
*
|
||||||
|
* param config Configuration to set to PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitUsb1Pll(const clock_usb_pll_config_t *config)
|
||||||
|
{
|
||||||
|
/* Bypass PLL first */
|
||||||
|
CCM_ANALOG->PLL_USB1 = (CCM_ANALOG->PLL_USB1 & (~CCM_ANALOG_PLL_USB1_BYPASS_CLK_SRC_MASK)) |
|
||||||
|
CCM_ANALOG_PLL_USB1_BYPASS_MASK | CCM_ANALOG_PLL_USB1_BYPASS_CLK_SRC(config->src);
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_USB1 = (CCM_ANALOG->PLL_USB1 & (~CCM_ANALOG_PLL_USB1_DIV_SELECT_MASK)) |
|
||||||
|
CCM_ANALOG_PLL_USB1_ENABLE_MASK | CCM_ANALOG_PLL_USB1_POWER_MASK |
|
||||||
|
CCM_ANALOG_PLL_USB1_EN_USB_CLKS_MASK | CCM_ANALOG_PLL_USB1_DIV_SELECT(config->loopDivider);
|
||||||
|
|
||||||
|
while ((CCM_ANALOG->PLL_USB1 & CCM_ANALOG_PLL_USB1_LOCK_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Bypass */
|
||||||
|
CCM_ANALOG->PLL_USB1 &= ~CCM_ANALOG_PLL_USB1_BYPASS_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Deinitialize the USB1 PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitUsb1Pll(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_USB1 = 0U;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initializes the Audio PLL.
|
||||||
|
*
|
||||||
|
* This function initializes the Audio PLL with specific settings
|
||||||
|
*
|
||||||
|
* param config Configuration to set to PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitAudioPll(const clock_audio_pll_config_t *config)
|
||||||
|
{
|
||||||
|
uint32_t pllAudio;
|
||||||
|
uint32_t misc2 = 0;
|
||||||
|
|
||||||
|
/* Bypass PLL first */
|
||||||
|
CCM_ANALOG->PLL_AUDIO = (CCM_ANALOG->PLL_AUDIO & (~CCM_ANALOG_PLL_AUDIO_BYPASS_CLK_SRC_MASK)) |
|
||||||
|
CCM_ANALOG_PLL_AUDIO_BYPASS_MASK | CCM_ANALOG_PLL_AUDIO_BYPASS_CLK_SRC(config->src);
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_AUDIO_NUM = CCM_ANALOG_PLL_AUDIO_NUM_A(config->numerator);
|
||||||
|
CCM_ANALOG->PLL_AUDIO_DENOM = CCM_ANALOG_PLL_AUDIO_DENOM_B(config->denominator);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set post divider:
|
||||||
|
*
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | config->postDivider | PLL_AUDIO[POST_DIV_SELECT] | MISC2[AUDIO_DIV] |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | 1 | 2 | 0 |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | 2 | 1 | 0 |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | 4 | 2 | 3 |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | 8 | 1 | 3 |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
* | 16 | 0 | 3 |
|
||||||
|
* ------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
pllAudio =
|
||||||
|
(CCM_ANALOG->PLL_AUDIO & (~(CCM_ANALOG_PLL_AUDIO_DIV_SELECT_MASK | CCM_ANALOG_PLL_AUDIO_POWERDOWN_MASK))) |
|
||||||
|
CCM_ANALOG_PLL_AUDIO_ENABLE_MASK | CCM_ANALOG_PLL_AUDIO_DIV_SELECT(config->loopDivider);
|
||||||
|
|
||||||
|
switch (config->postDivider)
|
||||||
|
{
|
||||||
|
case 16:
|
||||||
|
pllAudio |= CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(0);
|
||||||
|
misc2 = CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK | CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 8:
|
||||||
|
pllAudio |= CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(1);
|
||||||
|
misc2 = CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK | CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
pllAudio |= CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(2);
|
||||||
|
misc2 = CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK | CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
pllAudio |= CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
pllAudio |= CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(2);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
CCM_ANALOG->MISC2 =
|
||||||
|
(CCM_ANALOG->MISC2 & ~(CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK | CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK)) | misc2;
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_AUDIO = pllAudio;
|
||||||
|
|
||||||
|
while ((CCM_ANALOG->PLL_AUDIO & CCM_ANALOG_PLL_AUDIO_LOCK_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Bypass */
|
||||||
|
CCM_ANALOG->PLL_AUDIO &= ~CCM_ANALOG_PLL_AUDIO_BYPASS_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief De-initialize the Audio PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitAudioPll(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_AUDIO = CCM_ANALOG_PLL_AUDIO_POWERDOWN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the ENET PLL.
|
||||||
|
*
|
||||||
|
* This function initializes the ENET PLL with specific settings.
|
||||||
|
*
|
||||||
|
* param config Configuration to set to PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitEnetPll(const clock_enet_pll_config_t *config)
|
||||||
|
{
|
||||||
|
uint32_t enet_pll = CCM_ANALOG_PLL_ENET_DIV_SELECT(config->loopDivider);
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_ENET = (CCM_ANALOG->PLL_ENET & (~CCM_ANALOG_PLL_ENET_BYPASS_CLK_SRC_MASK)) |
|
||||||
|
CCM_ANALOG_PLL_ENET_BYPASS_MASK | CCM_ANALOG_PLL_ENET_BYPASS_CLK_SRC(config->src);
|
||||||
|
|
||||||
|
if (config->enableClkOutput)
|
||||||
|
{
|
||||||
|
enet_pll |= CCM_ANALOG_PLL_ENET_ENABLE_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (config->enableClkOutput25M)
|
||||||
|
{
|
||||||
|
enet_pll |= CCM_ANALOG_PLL_ENET_ENET_25M_REF_EN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (config->enableClkOutput500M)
|
||||||
|
{
|
||||||
|
enet_pll |= CCM_ANALOG_PLL_ENET_ENET_500M_REF_EN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
CCM_ANALOG->PLL_ENET =
|
||||||
|
(CCM_ANALOG->PLL_ENET & (~(CCM_ANALOG_PLL_ENET_DIV_SELECT_MASK | CCM_ANALOG_PLL_ENET_POWERDOWN_MASK))) |
|
||||||
|
enet_pll;
|
||||||
|
|
||||||
|
/* Wait for stable */
|
||||||
|
while ((CCM_ANALOG->PLL_ENET & CCM_ANALOG_PLL_ENET_LOCK_MASK) == 0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable Bypass */
|
||||||
|
CCM_ANALOG->PLL_ENET &= ~CCM_ANALOG_PLL_ENET_BYPASS_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Deinitialize the ENET PLL.
|
||||||
|
*
|
||||||
|
* This function disables the ENET PLL.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitEnetPll(void)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PLL_ENET = CCM_ANALOG_PLL_ENET_POWERDOWN_MASK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Get current PLL output frequency.
|
||||||
|
*
|
||||||
|
* This function get current output frequency of specific PLL
|
||||||
|
*
|
||||||
|
* param pll pll name to get frequency.
|
||||||
|
* return The PLL output frequency in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetPllFreq(clock_pll_t pll)
|
||||||
|
{
|
||||||
|
uint32_t freq;
|
||||||
|
uint32_t divSelect;
|
||||||
|
clock_64b_t freqTmp;
|
||||||
|
|
||||||
|
const uint32_t enetRefClkFreq[] = {
|
||||||
|
25000000U, /* 25M */
|
||||||
|
50000000U, /* 50M */
|
||||||
|
100000000U, /* 100M */
|
||||||
|
125000000U /* 125M */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* check if PLL is enabled */
|
||||||
|
if (!CLOCK_IsPllEnabled(CCM_ANALOG, pll))
|
||||||
|
{
|
||||||
|
return 0U;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* get pll reference clock */
|
||||||
|
freq = CLOCK_GetPllBypassRefClk(CCM_ANALOG, pll);
|
||||||
|
|
||||||
|
/* check if pll is bypassed */
|
||||||
|
if (CLOCK_IsPllBypassed(CCM_ANALOG, pll))
|
||||||
|
{
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (pll)
|
||||||
|
{
|
||||||
|
case kCLOCK_PllSys:
|
||||||
|
/* PLL output frequency = Fref * (DIV_SELECT + NUM/DENOM). */
|
||||||
|
freqTmp = ((clock_64b_t)freq * ((clock_64b_t)(CCM_ANALOG->PLL_SYS_NUM))) /
|
||||||
|
((clock_64b_t)(CCM_ANALOG->PLL_SYS_DENOM));
|
||||||
|
|
||||||
|
if (CCM_ANALOG->PLL_SYS & CCM_ANALOG_PLL_SYS_DIV_SELECT_MASK)
|
||||||
|
{
|
||||||
|
freq *= 22U;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
freq *= 20U;
|
||||||
|
}
|
||||||
|
|
||||||
|
freq += (uint32_t)freqTmp;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PllUsb1:
|
||||||
|
freq = (freq * ((CCM_ANALOG->PLL_USB1 & CCM_ANALOG_PLL_USB1_DIV_SELECT_MASK) ? 22U : 20U));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PllAudio:
|
||||||
|
/* PLL output frequency = Fref * (DIV_SELECT + NUM/DENOM). */
|
||||||
|
divSelect =
|
||||||
|
(CCM_ANALOG->PLL_AUDIO & CCM_ANALOG_PLL_AUDIO_DIV_SELECT_MASK) >> CCM_ANALOG_PLL_AUDIO_DIV_SELECT_SHIFT;
|
||||||
|
|
||||||
|
freqTmp = ((clock_64b_t)freq * ((clock_64b_t)(CCM_ANALOG->PLL_AUDIO_NUM))) /
|
||||||
|
((clock_64b_t)(CCM_ANALOG->PLL_AUDIO_DENOM));
|
||||||
|
|
||||||
|
freq = freq * divSelect + (uint32_t)freqTmp;
|
||||||
|
|
||||||
|
/* AUDIO PLL output = PLL output frequency / POSTDIV. */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Post divider:
|
||||||
|
*
|
||||||
|
* PLL_AUDIO[POST_DIV_SELECT]:
|
||||||
|
* 0x00: 4
|
||||||
|
* 0x01: 2
|
||||||
|
* 0x02: 1
|
||||||
|
*
|
||||||
|
* MISC2[AUDO_DIV]:
|
||||||
|
* 0x00: 1
|
||||||
|
* 0x01: 2
|
||||||
|
* 0x02: 1
|
||||||
|
* 0x03: 4
|
||||||
|
*/
|
||||||
|
switch (CCM_ANALOG->PLL_AUDIO & CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT_MASK)
|
||||||
|
{
|
||||||
|
case CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(0U):
|
||||||
|
freq = freq >> 2U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CCM_ANALOG_PLL_AUDIO_POST_DIV_SELECT(1U):
|
||||||
|
freq = freq >> 1U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (CCM_ANALOG->MISC2 & (CCM_ANALOG_MISC2_AUDIO_DIV_MSB_MASK | CCM_ANALOG_MISC2_AUDIO_DIV_LSB_MASK))
|
||||||
|
{
|
||||||
|
case CCM_ANALOG_MISC2_AUDIO_DIV_MSB(1) | CCM_ANALOG_MISC2_AUDIO_DIV_LSB(1):
|
||||||
|
freq >>= 2U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case CCM_ANALOG_MISC2_AUDIO_DIV_MSB(0) | CCM_ANALOG_MISC2_AUDIO_DIV_LSB(1):
|
||||||
|
freq >>= 1U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PllEnet:
|
||||||
|
divSelect =
|
||||||
|
(CCM_ANALOG->PLL_ENET & CCM_ANALOG_PLL_ENET_DIV_SELECT_MASK) >> CCM_ANALOG_PLL_ENET_DIV_SELECT_SHIFT;
|
||||||
|
freq = enetRefClkFreq[divSelect];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PllEnet25M:
|
||||||
|
/* ref_enetpll1 if fixed at 25MHz. */
|
||||||
|
freq = 25000000UL;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_PllEnet500M:
|
||||||
|
/* PLL6 is fixed at 25MHz. */
|
||||||
|
freq = 500000000UL;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the System PLL PFD.
|
||||||
|
*
|
||||||
|
* This function initializes the System PLL PFD. During new value setting,
|
||||||
|
* the clock output is disabled to prevent glitch.
|
||||||
|
*
|
||||||
|
* param pfd Which PFD clock to enable.
|
||||||
|
* param pfdFrac The PFD FRAC value.
|
||||||
|
* note It is recommended that PFD settings are kept between 12-35.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitSysPfd(clock_pfd_t pfd, uint8_t pfdFrac)
|
||||||
|
{
|
||||||
|
uint32_t pfdIndex = (uint32_t)pfd;
|
||||||
|
uint32_t pfd528;
|
||||||
|
|
||||||
|
pfd528 = CCM_ANALOG->PFD_528 &
|
||||||
|
~((CCM_ANALOG_PFD_528_PFD0_CLKGATE_MASK | CCM_ANALOG_PFD_528_PFD0_FRAC_MASK) << (8 * pfdIndex));
|
||||||
|
|
||||||
|
/* Disable the clock output first. */
|
||||||
|
CCM_ANALOG->PFD_528 = pfd528 | (CCM_ANALOG_PFD_528_PFD0_CLKGATE_MASK << (8 * pfdIndex));
|
||||||
|
|
||||||
|
/* Set the new value and enable output. */
|
||||||
|
CCM_ANALOG->PFD_528 = pfd528 | (CCM_ANALOG_PFD_528_PFD0_FRAC(pfdFrac) << (8 * pfdIndex));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief De-initialize the System PLL PFD.
|
||||||
|
*
|
||||||
|
* This function disables the System PLL PFD.
|
||||||
|
*
|
||||||
|
* param pfd Which PFD clock to disable.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitSysPfd(clock_pfd_t pfd)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PFD_528 |= CCM_ANALOG_PFD_528_PFD0_CLKGATE_MASK << (8 * pfd);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Initialize the USB1 PLL PFD.
|
||||||
|
*
|
||||||
|
* This function initializes the USB1 PLL PFD. During new value setting,
|
||||||
|
* the clock output is disabled to prevent glitch.
|
||||||
|
*
|
||||||
|
* param pfd Which PFD clock to enable.
|
||||||
|
* param pfdFrac The PFD FRAC value.
|
||||||
|
* note It is recommended that PFD settings are kept between 12-35.
|
||||||
|
*/
|
||||||
|
void CLOCK_InitUsb1Pfd(clock_pfd_t pfd, uint8_t pfdFrac)
|
||||||
|
{
|
||||||
|
uint32_t pfdIndex = (uint32_t)pfd;
|
||||||
|
uint32_t pfd480;
|
||||||
|
|
||||||
|
pfd480 = CCM_ANALOG->PFD_480 &
|
||||||
|
~((CCM_ANALOG_PFD_480_PFD0_CLKGATE_MASK | CCM_ANALOG_PFD_480_PFD0_FRAC_MASK) << (8 * pfdIndex));
|
||||||
|
|
||||||
|
/* Disable the clock output first. */
|
||||||
|
CCM_ANALOG->PFD_480 = pfd480 | (CCM_ANALOG_PFD_480_PFD0_CLKGATE_MASK << (8 * pfdIndex));
|
||||||
|
|
||||||
|
/* Set the new value and enable output. */
|
||||||
|
CCM_ANALOG->PFD_480 = pfd480 | (CCM_ANALOG_PFD_480_PFD0_FRAC(pfdFrac) << (8 * pfdIndex));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief De-initialize the USB1 PLL PFD.
|
||||||
|
*
|
||||||
|
* This function disables the USB1 PLL PFD.
|
||||||
|
*
|
||||||
|
* param pfd Which PFD clock to disable.
|
||||||
|
*/
|
||||||
|
void CLOCK_DeinitUsb1Pfd(clock_pfd_t pfd)
|
||||||
|
{
|
||||||
|
CCM_ANALOG->PFD_480 |= CCM_ANALOG_PFD_480_PFD0_CLKGATE_MASK << (8 * pfd);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Get current System PLL PFD output frequency.
|
||||||
|
*
|
||||||
|
* This function get current output frequency of specific System PLL PFD
|
||||||
|
*
|
||||||
|
* param pfd pfd name to get frequency.
|
||||||
|
* return The PFD output frequency in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetSysPfdFreq(clock_pfd_t pfd)
|
||||||
|
{
|
||||||
|
uint32_t freq = CLOCK_GetPllFreq(kCLOCK_PllSys);
|
||||||
|
|
||||||
|
switch (pfd)
|
||||||
|
{
|
||||||
|
case kCLOCK_Pfd0:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_528 & CCM_ANALOG_PFD_528_PFD0_FRAC_MASK) >> CCM_ANALOG_PFD_528_PFD0_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd1:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_528 & CCM_ANALOG_PFD_528_PFD1_FRAC_MASK) >> CCM_ANALOG_PFD_528_PFD1_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd2:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_528 & CCM_ANALOG_PFD_528_PFD2_FRAC_MASK) >> CCM_ANALOG_PFD_528_PFD2_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd3:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_528 & CCM_ANALOG_PFD_528_PFD3_FRAC_MASK) >> CCM_ANALOG_PFD_528_PFD3_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
freq *= 18U;
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* brief Get current USB1 PLL PFD output frequency.
|
||||||
|
*
|
||||||
|
* This function get current output frequency of specific USB1 PLL PFD
|
||||||
|
*
|
||||||
|
* param pfd pfd name to get frequency.
|
||||||
|
* return The PFD output frequency in hertz.
|
||||||
|
*/
|
||||||
|
uint32_t CLOCK_GetUsb1PfdFreq(clock_pfd_t pfd)
|
||||||
|
{
|
||||||
|
uint32_t freq = CLOCK_GetPllFreq(kCLOCK_PllUsb1);
|
||||||
|
|
||||||
|
switch (pfd)
|
||||||
|
{
|
||||||
|
case kCLOCK_Pfd0:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_480 & CCM_ANALOG_PFD_480_PFD0_FRAC_MASK) >> CCM_ANALOG_PFD_480_PFD0_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd1:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_480 & CCM_ANALOG_PFD_480_PFD1_FRAC_MASK) >> CCM_ANALOG_PFD_480_PFD1_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd2:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_480 & CCM_ANALOG_PFD_480_PFD2_FRAC_MASK) >> CCM_ANALOG_PFD_480_PFD2_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kCLOCK_Pfd3:
|
||||||
|
freq /= ((CCM_ANALOG->PFD_480 & CCM_ANALOG_PFD_480_PFD3_FRAC_MASK) >> CCM_ANALOG_PFD_480_PFD3_FRAC_SHIFT);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
freq *= 18U;
|
||||||
|
|
||||||
|
return freq;
|
||||||
|
}
|
1331
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_clock.h
Normal file
1331
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_clock.h
Normal file
File diff suppressed because it is too large
Load diff
35
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_device_registers.h
Normal file
35
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_device_registers.h
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2014-2016 Freescale Semiconductor, Inc.
|
||||||
|
* Copyright 2016-2018 NXP
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __FSL_DEVICE_REGISTERS_H__
|
||||||
|
#define __FSL_DEVICE_REGISTERS_H__
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Include the cpu specific register header files.
|
||||||
|
*
|
||||||
|
* The CPU macro should be declared in the project or makefile.
|
||||||
|
*/
|
||||||
|
#if (defined(CPU_MIMXRT1021CAF4A) || defined(CPU_MIMXRT1021CAG4A) || defined(CPU_MIMXRT1021DAF5A) || \
|
||||||
|
defined(CPU_MIMXRT1021DAG5A))
|
||||||
|
|
||||||
|
#define MIMXRT1021_SERIES
|
||||||
|
|
||||||
|
/* CMSIS-style register definitions */
|
||||||
|
#include "MIMXRT1021.h"
|
||||||
|
/* CPU specific feature definitions */
|
||||||
|
#include "MIMXRT1021_features.h"
|
||||||
|
|
||||||
|
#else
|
||||||
|
#error "No valid CPU defined!"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __FSL_DEVICE_REGISTERS_H__ */
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
* EOF
|
||||||
|
******************************************************************************/
|
1007
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_iomuxc.h
Normal file
1007
ext/hal/nxp/mcux/devices/MIMXRT1021/fsl_iomuxc.h
Normal file
File diff suppressed because it is too large
Load diff
214
ext/hal/nxp/mcux/devices/MIMXRT1021/system_MIMXRT1021.c
Normal file
214
ext/hal/nxp/mcux/devices/MIMXRT1021/system_MIMXRT1021.c
Normal file
|
@ -0,0 +1,214 @@
|
||||||
|
/*
|
||||||
|
** ###################################################################
|
||||||
|
** Processors: MIMXRT1021CAF4A
|
||||||
|
** MIMXRT1021CAG4A
|
||||||
|
** MIMXRT1021DAF5A
|
||||||
|
** MIMXRT1021DAG5A
|
||||||
|
**
|
||||||
|
** Compilers: Keil ARM C/C++ Compiler
|
||||||
|
** Freescale C/C++ for Embedded ARM
|
||||||
|
** GNU C Compiler
|
||||||
|
** IAR ANSI C/C++ Compiler for ARM
|
||||||
|
** MCUXpresso Compiler
|
||||||
|
**
|
||||||
|
** Reference manual: IMXRT1020RM Rev. 1RC, 05/2018
|
||||||
|
** Version: rev. 0.1, 2017-11-06
|
||||||
|
** Build: b180801
|
||||||
|
**
|
||||||
|
** Abstract:
|
||||||
|
** Provides a system configuration function and a global variable that
|
||||||
|
** contains the system frequency. It configures the device and initializes
|
||||||
|
** the oscillator (PLL) that is part of the microcontroller device.
|
||||||
|
**
|
||||||
|
** Copyright 2016 Freescale Semiconductor, Inc.
|
||||||
|
** Copyright 2016-2018 NXP
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
**
|
||||||
|
** http: www.nxp.com
|
||||||
|
** mail: support@nxp.com
|
||||||
|
**
|
||||||
|
** Revisions:
|
||||||
|
** - rev. 0.1 (2017-11-06)
|
||||||
|
** Initial version.
|
||||||
|
**
|
||||||
|
** ###################################################################
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @file MIMXRT1021
|
||||||
|
* @version 0.1
|
||||||
|
* @date 2017-11-06
|
||||||
|
* @brief Device specific configuration file for MIMXRT1021 (implementation file)
|
||||||
|
*
|
||||||
|
* Provides a system configuration function and a global variable that contains
|
||||||
|
* the system frequency. It configures the device and initializes the oscillator
|
||||||
|
* (PLL) that is part of the microcontroller device.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "fsl_device_registers.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------------
|
||||||
|
-- Core clock
|
||||||
|
---------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
uint32_t SystemCoreClock = DEFAULT_SYSTEM_CLOCK;
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------------
|
||||||
|
-- SystemInit()
|
||||||
|
---------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void SystemInit (void) {
|
||||||
|
#if ((__FPU_PRESENT == 1) && (__FPU_USED == 1))
|
||||||
|
SCB->CPACR |= ((3UL << 10*2) | (3UL << 11*2)); /* set CP10, CP11 Full Access */
|
||||||
|
#endif /* ((__FPU_PRESENT == 1) && (__FPU_USED == 1)) */
|
||||||
|
|
||||||
|
#if defined(__MCUXPRESSO)
|
||||||
|
extern uint32_t g_pfnVectors[]; // Vector table defined in startup code
|
||||||
|
SCB->VTOR = (uint32_t)g_pfnVectors;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Disable Watchdog Power Down Counter */
|
||||||
|
WDOG1->WMCR &= ~WDOG_WMCR_PDE_MASK;
|
||||||
|
WDOG2->WMCR &= ~WDOG_WMCR_PDE_MASK;
|
||||||
|
|
||||||
|
/* Watchdog disable */
|
||||||
|
|
||||||
|
#if (DISABLE_WDOG)
|
||||||
|
if (WDOG1->WCR & WDOG_WCR_WDE_MASK)
|
||||||
|
{
|
||||||
|
WDOG1->WCR &= ~WDOG_WCR_WDE_MASK;
|
||||||
|
}
|
||||||
|
if (WDOG2->WCR & WDOG_WCR_WDE_MASK)
|
||||||
|
{
|
||||||
|
WDOG2->WCR &= ~WDOG_WCR_WDE_MASK;
|
||||||
|
}
|
||||||
|
RTWDOG->CNT = 0xD928C520U; /* 0xD928C520U is the update key */
|
||||||
|
RTWDOG->TOVAL = 0xFFFF;
|
||||||
|
RTWDOG->CS = (uint32_t) ((RTWDOG->CS) & ~RTWDOG_CS_EN_MASK) | RTWDOG_CS_UPDATE_MASK;
|
||||||
|
#endif /* (DISABLE_WDOG) */
|
||||||
|
|
||||||
|
/* Disable Systick which might be enabled by bootrom */
|
||||||
|
if (SysTick->CTRL & SysTick_CTRL_ENABLE_Msk)
|
||||||
|
{
|
||||||
|
SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Enable instruction and data caches */
|
||||||
|
#if defined(__ICACHE_PRESENT) && __ICACHE_PRESENT
|
||||||
|
if (SCB_CCR_IC_Msk != (SCB_CCR_IC_Msk & SCB->CCR)) {
|
||||||
|
SCB_EnableICache();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(__DCACHE_PRESENT) && __DCACHE_PRESENT
|
||||||
|
if (SCB_CCR_DC_Msk != (SCB_CCR_DC_Msk & SCB->CCR)) {
|
||||||
|
SCB_EnableDCache();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
SystemInitHook();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------------
|
||||||
|
-- SystemCoreClockUpdate()
|
||||||
|
---------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
void SystemCoreClockUpdate (void) {
|
||||||
|
|
||||||
|
uint32_t freq;
|
||||||
|
uint32_t PLL2MainClock;
|
||||||
|
uint32_t PLL3MainClock;
|
||||||
|
|
||||||
|
/* Check if system pll is bypassed */
|
||||||
|
if(CCM_ANALOG->PLL_SYS & CCM_ANALOG_PLL_SYS_BYPASS_MASK)
|
||||||
|
{
|
||||||
|
PLL2MainClock = CPU_XTAL_CLK_HZ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
PLL2MainClock = (CPU_XTAL_CLK_HZ * ((CCM_ANALOG->PLL_SYS & CCM_ANALOG_PLL_SYS_DIV_SELECT_MASK) ? 22U : 20U));
|
||||||
|
}
|
||||||
|
PLL2MainClock += ((uint64_t)CPU_XTAL_CLK_HZ * ((uint64_t)(CCM_ANALOG->PLL_SYS_NUM))) / ((uint64_t)(CCM_ANALOG->PLL_SYS_DENOM));
|
||||||
|
|
||||||
|
/* Check if usb1 pll is bypassed */
|
||||||
|
if(CCM_ANALOG->PLL_USB1 & CCM_ANALOG_PLL_USB1_BYPASS_MASK)
|
||||||
|
{
|
||||||
|
PLL3MainClock = CPU_XTAL_CLK_HZ;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
PLL3MainClock = (CPU_XTAL_CLK_HZ * ((CCM_ANALOG->PLL_USB1 & CCM_ANALOG_PLL_USB1_DIV_SELECT_MASK) ? 22U : 20U));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Periph_clk2_clk ---> Periph_clk */
|
||||||
|
if (CCM->CBCDR & CCM_CBCDR_PERIPH_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
switch (CCM->CBCMR & CCM_CBCMR_PERIPH_CLK2_SEL_MASK)
|
||||||
|
{
|
||||||
|
/* Pll3_sw_clk ---> Periph_clk2_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(0U):
|
||||||
|
freq = PLL3MainClock;
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* Osc_clk ---> Periph_clk2_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(1U):
|
||||||
|
freq = CPU_XTAL_CLK_HZ;
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* Pll2_bypass_clk ---> Periph_clk2_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(2U):
|
||||||
|
freq = CPU_XTAL_CLK_HZ;
|
||||||
|
|
||||||
|
case CCM_CBCMR_PERIPH_CLK2_SEL(3U):
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
freq /= (((CCM->CBCDR & CCM_CBCDR_PERIPH_CLK2_PODF_MASK) >> CCM_CBCDR_PERIPH_CLK2_PODF_SHIFT) + 1U);
|
||||||
|
}
|
||||||
|
/* Pre_Periph_clk ---> Periph_clk */
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch (CCM->CBCMR & CCM_CBCMR_PRE_PERIPH_CLK_SEL_MASK)
|
||||||
|
{
|
||||||
|
/* PLL2 ---> Pre_Periph_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(0U):
|
||||||
|
freq = PLL2MainClock;
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL3 PFD3 ---> Pre_Periph_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(1U):
|
||||||
|
freq = PLL3MainClock / ((CCM_ANALOG->PFD_480 & CCM_ANALOG_PFD_480_PFD3_FRAC_MASK) >> CCM_ANALOG_PFD_480_PFD3_FRAC_SHIFT) * 18U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL2 PFD3 ---> Pre_Periph_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(2U):
|
||||||
|
freq = PLL2MainClock / ((CCM_ANALOG->PFD_528 & CCM_ANALOG_PFD_528_PFD3_FRAC_MASK) >> CCM_ANALOG_PFD_528_PFD3_FRAC_SHIFT) * 18U;
|
||||||
|
break;
|
||||||
|
|
||||||
|
/* PLL6 ---> Pre_Periph_clk ---> Periph_clk ---> Core_clock */
|
||||||
|
case CCM_CBCMR_PRE_PERIPH_CLK_SEL(3U):
|
||||||
|
freq = 500000000U / (((CCM->CACRR & CCM_CACRR_ARM_PODF_MASK) >> CCM_CACRR_ARM_PODF_SHIFT) + 1U);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
freq = 0U;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SystemCoreClock = (freq / (((CCM->CBCDR & CCM_CBCDR_AHB_PODF_MASK) >> CCM_CBCDR_AHB_PODF_SHIFT) + 1U));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ----------------------------------------------------------------------------
|
||||||
|
-- SystemInitHook()
|
||||||
|
---------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
__attribute__ ((weak)) void SystemInitHook (void) {
|
||||||
|
/* Void implementation of the weak function. */
|
||||||
|
}
|
115
ext/hal/nxp/mcux/devices/MIMXRT1021/system_MIMXRT1021.h
Normal file
115
ext/hal/nxp/mcux/devices/MIMXRT1021/system_MIMXRT1021.h
Normal file
|
@ -0,0 +1,115 @@
|
||||||
|
/*
|
||||||
|
** ###################################################################
|
||||||
|
** Processors: MIMXRT1021CAF4A
|
||||||
|
** MIMXRT1021CAG4A
|
||||||
|
** MIMXRT1021DAF5A
|
||||||
|
** MIMXRT1021DAG5A
|
||||||
|
**
|
||||||
|
** Compilers: Keil ARM C/C++ Compiler
|
||||||
|
** Freescale C/C++ for Embedded ARM
|
||||||
|
** GNU C Compiler
|
||||||
|
** IAR ANSI C/C++ Compiler for ARM
|
||||||
|
** MCUXpresso Compiler
|
||||||
|
**
|
||||||
|
** Reference manual: IMXRT1020RM Rev. 1RC, 05/2018
|
||||||
|
** Version: rev. 0.1, 2017-11-06
|
||||||
|
** Build: b180801
|
||||||
|
**
|
||||||
|
** Abstract:
|
||||||
|
** Provides a system configuration function and a global variable that
|
||||||
|
** contains the system frequency. It configures the device and initializes
|
||||||
|
** the oscillator (PLL) that is part of the microcontroller device.
|
||||||
|
**
|
||||||
|
** Copyright 2016 Freescale Semiconductor, Inc.
|
||||||
|
** Copyright 2016-2018 NXP
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
**
|
||||||
|
** http: www.nxp.com
|
||||||
|
** mail: support@nxp.com
|
||||||
|
**
|
||||||
|
** Revisions:
|
||||||
|
** - rev. 0.1 (2017-11-06)
|
||||||
|
** Initial version.
|
||||||
|
**
|
||||||
|
** ###################################################################
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* @file MIMXRT1021
|
||||||
|
* @version 0.1
|
||||||
|
* @date 2017-11-06
|
||||||
|
* @brief Device specific configuration file for MIMXRT1021 (header file)
|
||||||
|
*
|
||||||
|
* Provides a system configuration function and a global variable that contains
|
||||||
|
* the system frequency. It configures the device and initializes the oscillator
|
||||||
|
* (PLL) that is part of the microcontroller device.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SYSTEM_MIMXRT1021_H_
|
||||||
|
#define _SYSTEM_MIMXRT1021_H_ /**< Symbol preventing repeated inclusion */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef DISABLE_WDOG
|
||||||
|
#define DISABLE_WDOG 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Define clock source values */
|
||||||
|
|
||||||
|
#define CPU_XTAL_CLK_HZ 24000000UL /* Value of the external crystal or oscillator clock frequency in Hz */
|
||||||
|
|
||||||
|
#define DEFAULT_SYSTEM_CLOCK 297000000UL /* Default System clock value */
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief System clock frequency (core clock)
|
||||||
|
*
|
||||||
|
* The system clock frequency supplied to the SysTick timer and the processor
|
||||||
|
* core clock. This variable can be used by the user application to setup the
|
||||||
|
* SysTick timer or configure other parameters. It may also be used by debugger to
|
||||||
|
* query the frequency of the debug timer or configure the trace clock speed
|
||||||
|
* SystemCoreClock is initialized with a correct predefined value.
|
||||||
|
*/
|
||||||
|
extern uint32_t SystemCoreClock;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Setup the microcontroller system.
|
||||||
|
*
|
||||||
|
* Typically this function configures the oscillator (PLL) that is part of the
|
||||||
|
* microcontroller device. For systems with variable clock speed it also updates
|
||||||
|
* the variable SystemCoreClock. SystemInit is called from startup_device file.
|
||||||
|
*/
|
||||||
|
void SystemInit (void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Updates the SystemCoreClock variable.
|
||||||
|
*
|
||||||
|
* It must be called whenever the core clock is changed during program
|
||||||
|
* execution. SystemCoreClockUpdate() evaluates the clock register settings and calculates
|
||||||
|
* the current core clock.
|
||||||
|
*/
|
||||||
|
void SystemCoreClockUpdate (void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief SystemInit function hook.
|
||||||
|
*
|
||||||
|
* This weak function allows to call specific initialization code during the
|
||||||
|
* SystemInit() execution.This can be used when an application specific code needs
|
||||||
|
* to be called as close to the reset entry as possible (for example the Multicore
|
||||||
|
* Manager MCMGR_EarlyInit() function call).
|
||||||
|
* NOTE: No global r/w variables can be used in this hook function because the
|
||||||
|
* initialization of these variables happens after this function.
|
||||||
|
*/
|
||||||
|
void SystemInitHook (void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _SYSTEM_MIMXRT1021_H_ */
|
Loading…
Add table
Add a link
Reference in a new issue