arch/arm/src/s32k1xx/s32k1xx_clockconfig.h: Add data structures that will eventually be used to configure clocking.
This commit is contained in:
parent
061728b440
commit
fba40c40f1
@ -222,7 +222,7 @@
|
|||||||
#define SCG_SOSCCFG_RANGE_MASK (3 << SCG_SOSCCFG_RANGE_SHIFT)
|
#define SCG_SOSCCFG_RANGE_MASK (3 << SCG_SOSCCFG_RANGE_SHIFT)
|
||||||
# define SCG_SOSCCFG_RANGE_LOW (1 << SCG_SOSCCFG_RANGE_SHIFT) /* Low frequency range */
|
# define SCG_SOSCCFG_RANGE_LOW (1 << SCG_SOSCCFG_RANGE_SHIFT) /* Low frequency range */
|
||||||
# define SCG_SOSCCFG_RANGE_MED (2 << SCG_SOSCCFG_RANGE_SHIFT) /* Medium frequency range */
|
# define SCG_SOSCCFG_RANGE_MED (2 << SCG_SOSCCFG_RANGE_SHIFT) /* Medium frequency range */
|
||||||
# define SCG_SOSCCFG_RANGE_HIGH (3 << SCG_SOSCCFG_RANGE_SHIFT) /* High frequency range
|
# define SCG_SOSCCFG_RANGE_HIGH (3 << SCG_SOSCCFG_RANGE_SHIFT) /* High frequency range */
|
||||||
|
|
||||||
/* Slow IRC Control Status Register */
|
/* Slow IRC Control Status Register */
|
||||||
|
|
||||||
|
154
arch/arm/src/s32k1xx/s32k11x/s32k11x_clocknames.h
Normal file
154
arch/arm/src/s32k1xx/s32k11x/s32k11x_clocknames.h
Normal file
@ -0,0 +1,154 @@
|
|||||||
|
/************************************************************************************
|
||||||
|
* arch/arm/src/s32k1xx/s32k11x/s32k11x_clocknames.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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 NuttX 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 OWNER 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.
|
||||||
|
*
|
||||||
|
* Some of the definitions within this file derivesfrom NXP sample code for
|
||||||
|
* the S32K1xx MCUs. That sample code has this licensing information:
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 - 2015, Freescale Semiconductor, Inc.
|
||||||
|
* Copyright 2016-2018 NXP
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY NXP "AS IS" AND ANY EXPRESSED 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 NXP OR ITS 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 __ARCH_ARM_SRC_S32K1XX_S32K11X_S32K11X_CLOCKNAMES_H
|
||||||
|
#define __ARCH_ARM_SRC_S32K1XX_S32K11X_S32K11X_CLOCKNAMES_H
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Included Files
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Types
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
enum clock_names_e
|
||||||
|
{
|
||||||
|
/* Main clocks */
|
||||||
|
|
||||||
|
CORE_CLK = 0, /* Core clock */
|
||||||
|
BUS_CLK = 1, /* Bus clock */
|
||||||
|
SLOW_CLK = 2, /* Slow clock */
|
||||||
|
CLKOUT_CLK = 3, /* CLKOUT clock */
|
||||||
|
|
||||||
|
/* Other internal clocks used by peripherals. */
|
||||||
|
|
||||||
|
SIRC_CLK = 4, /* SIRC clock */
|
||||||
|
FIRC_CLK = 5, /* FIRC clock */
|
||||||
|
SOSC_CLK = 6, /* SOSC clock */
|
||||||
|
RTC_CLKIN_CLK = 8, /* RTC_CLKIN clock */
|
||||||
|
SCG_CLKOUT_CLK = 9, /* SCG CLK_OUT clock */
|
||||||
|
SIRCDIV1_CLK = 10, /* SIRCDIV1 functional clock */
|
||||||
|
SIRCDIV2_CLK = 11, /* SIRCDIV2 functional clock */
|
||||||
|
FIRCDIV1_CLK = 12, /* FIRCDIV1 functional clock */
|
||||||
|
FIRCDIV2_CLK = 13, /* FIRCDIV2 functional clock */
|
||||||
|
SOSCDIV1_CLK = 14, /* SOSCDIV1 functional clock */
|
||||||
|
SOSCDIV2_CLK = 15, /* SOSCDIV2 functional clock */
|
||||||
|
|
||||||
|
SCG_END_OF_CLOCKS = 18, /* End of SCG clocks */
|
||||||
|
|
||||||
|
/* SIM clocks */
|
||||||
|
|
||||||
|
SIM_FTM0_CLOCKSEL = 21, /* FTM0 External Clock Pin Select */
|
||||||
|
SIM_FTM1_CLOCKSEL = 22, /* FTM1 External Clock Pin Select */
|
||||||
|
SIM_CLKOUTSELL = 23, /* CLKOUT Select */
|
||||||
|
SIM_RTCCLK_CLK = 24, /* RTCCLK clock */
|
||||||
|
SIM_LPO_CLK = 25, /* LPO clock */
|
||||||
|
SIM_LPO_1K_CLK = 26, /* LPO 1KHz clock */
|
||||||
|
SIM_LPO_32K_CLK = 27, /* LPO 32KHz clock */
|
||||||
|
SIM_LPO_128K_CLK = 28, /* LPO 128KHz clock */
|
||||||
|
SIM_EIM_CLK = 29, /* EIM clock source */
|
||||||
|
SIM_ERM_CLK = 30, /* ERM clock source */
|
||||||
|
SIM_DMA_CLK = 31, /* DMA clock source */
|
||||||
|
SIM_MPU_CLK = 32, /* MPU clock source */
|
||||||
|
SIM_MSCM_CLK = 33, /* MSCM clock source */
|
||||||
|
SIM_END_OF_CLOCKS = 34, /* End of SIM clocks */
|
||||||
|
|
||||||
|
CMP0_CLK = 41, /* CMP0 clock source */
|
||||||
|
CRC0_CLK = 42, /* CRC0 clock source */
|
||||||
|
DMAMUX0_CLK = 43, /* DMAMUX0 clock source */
|
||||||
|
PORTA_CLK = 44, /* PORTA clock source */
|
||||||
|
PORTB_CLK = 45, /* PORTB clock source */
|
||||||
|
PORTC_CLK = 46, /* PORTC clock source */
|
||||||
|
PORTD_CLK = 47, /* PORTD clock source */
|
||||||
|
PORTE_CLK = 48, /* PORTE clock source */
|
||||||
|
RTC0_CLK = 49, /* RTC0 clock source */
|
||||||
|
PCC_END_OF_BUS_CLOCKS = 50, /* End of BUS clocks */
|
||||||
|
FlexCAN0_CLK = 51, /* FlexCAN0 clock source */
|
||||||
|
PDB0_CLK = 52, /* PDB0 clock source */
|
||||||
|
PCC_END_OF_SYS_CLOCKS = 53, /* End of SYS clocks */
|
||||||
|
FTFC0_CLK = 54, /* FTFC0 clock source */
|
||||||
|
PCC_END_OF_SLOW_CLOCKS = 55, /* End of SLOW clocks */
|
||||||
|
FTM0_CLK = 56, /* FTM0 clock source */
|
||||||
|
FTM1_CLK = 57, /* FTM1 clock source */
|
||||||
|
PCC_END_OF_ASYNCH_DIV1_CLOCKS= 58, /* End of ASYNCH DIV1 clocks */
|
||||||
|
ADC0_CLK = 59, /* ADC0 clock source */
|
||||||
|
FLEXIO0_CLK = 60, /* FLEXIO0 clock source */
|
||||||
|
LPI2C0_CLK = 61, /* LPI2C0 clock source */
|
||||||
|
LPIT0_CLK = 62, /* LPIT0 clock source */
|
||||||
|
LPSPI0_CLK = 63, /* LPSPI0 clock source */
|
||||||
|
LPSPI1_CLK = 64, /* LPSPI1 clock source */
|
||||||
|
LPTMR0_CLK = 65, /* LPTMR0 clock source */
|
||||||
|
LPUART0_CLK = 66, /* LPUART0 clock source */
|
||||||
|
LPUART1_CLK = 67, /* LPUART1 clock source */
|
||||||
|
PCC_END_OF_ASYNCH_DIV2_CLOCKS= 68, /* End of ASYNCH DIV2 clocks */
|
||||||
|
PCC_END_OF_CLOCKS = 69, /* End of PCC clocks */
|
||||||
|
CLOCK_NAME_COUNT = 70, /* The total number of entries */
|
||||||
|
};
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Data
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
#endif /* __ARCH_ARM_SRC_S32K1XX_S32K11X_S32K11X_CLOCKNAMES_H */
|
185
arch/arm/src/s32k1xx/s32k14x/s32k14x_clocknames.h
Normal file
185
arch/arm/src/s32k1xx/s32k14x/s32k14x_clocknames.h
Normal file
@ -0,0 +1,185 @@
|
|||||||
|
/************************************************************************************
|
||||||
|
* arch/arm/src/s32k1xx/s32k14x/s32k14x_clocknames.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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 NuttX 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 OWNER 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.
|
||||||
|
*
|
||||||
|
* Some of the definitions within this file derivesfrom NXP sample code for
|
||||||
|
* the S32K1xx MCUs. That sample code has this licensing information:
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 - 2015, Freescale Semiconductor, Inc.
|
||||||
|
* Copyright 2016-2018 NXP
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY NXP "AS IS" AND ANY EXPRESSED 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 NXP OR ITS 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 __ARCH_ARM_SRC_S32K1XX_S32K14X_S32K14X_CLOCKNAMES_H
|
||||||
|
#define __ARCH_ARM_SRC_S32K1XX_S32K14X_S32K14X_CLOCKNAMES_H
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Included Files
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Types
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
enum clock_names_e
|
||||||
|
{
|
||||||
|
/* Main clocks */
|
||||||
|
|
||||||
|
CORE_CLK = 0, /* Core clock */
|
||||||
|
BUS_CLK = 1, /* Bus clock */
|
||||||
|
SLOW_CLK = 2, /* Slow clock */
|
||||||
|
CLKOUT_CLK = 3, /* CLKOUT clock */
|
||||||
|
|
||||||
|
/* Other internal clocks used by peripherals */
|
||||||
|
|
||||||
|
SIRC_CLK = 4, /* SIRC clock */
|
||||||
|
FIRC_CLK = 5, /* FIRC clock */
|
||||||
|
SOSC_CLK = 6, /* SOSC clock */
|
||||||
|
SPLL_CLK = 7, /* SPLL clock */
|
||||||
|
RTC_CLKIN_CLK = 8, /* RTC_CLKIN clock */
|
||||||
|
SCG_CLKOUT_CLK = 9, /* SCG CLK_OUT clock */
|
||||||
|
SIRCDIV1_CLK = 10, /* SIRCDIV1 functional clock */
|
||||||
|
SIRCDIV2_CLK = 11, /* SIRCDIV2 functional clock */
|
||||||
|
FIRCDIV1_CLK = 12, /* FIRCDIV1 functional clock */
|
||||||
|
FIRCDIV2_CLK = 13, /* FIRCDIV2 functional clock */
|
||||||
|
SOSCDIV1_CLK = 14, /* SOSCDIV1 functional clock */
|
||||||
|
SOSCDIV2_CLK = 15, /* SOSCDIV2 functional clock */
|
||||||
|
SPLLDIV1_CLK = 16, /* SPLLDIV1 functional clock */
|
||||||
|
SPLLDIV2_CLK = 17, /* SPLLDIV2 functional clock */
|
||||||
|
|
||||||
|
SCG_END_OF_CLOCKS = 18, /* End of SCG clocks */
|
||||||
|
|
||||||
|
/* SIM clocks */
|
||||||
|
|
||||||
|
SIM_FTM0_CLOCKSEL = 21, /* FTM0 External Clock Pin Select */
|
||||||
|
SIM_FTM1_CLOCKSEL = 22, /* FTM1 External Clock Pin Select */
|
||||||
|
SIM_FTM2_CLOCKSEL = 23, /* FTM2 External Clock Pin Select */
|
||||||
|
SIM_FTM3_CLOCKSEL = 24, /* FTM3 External Clock Pin Select */
|
||||||
|
SIM_FTM4_CLOCKSEL = 25, /* FTM4 External Clock Pin Select */
|
||||||
|
SIM_FTM5_CLOCKSEL = 26, /* FTM5 External Clock Pin Select */
|
||||||
|
SIM_FTM6_CLOCKSEL = 27, /* FTM6 External Clock Pin Select */
|
||||||
|
SIM_FTM7_CLOCKSEL = 28, /* FTM7 External Clock Pin Select */
|
||||||
|
SIM_CLKOUTSELL = 29, /* CLKOUT Select */
|
||||||
|
SIM_RTCCLK_CLK = 30, /* RTCCLK clock */
|
||||||
|
SIM_LPO_CLK = 31, /* LPO clock */
|
||||||
|
SIM_LPO_1K_CLK = 32, /* LPO 1KHz clock */
|
||||||
|
SIM_LPO_32K_CLK = 33, /* LPO 32KHz clock */
|
||||||
|
SIM_LPO_128K_CLK = 34, /* LPO 128KHz clock */
|
||||||
|
SIM_EIM_CLK = 35, /* EIM clock source */
|
||||||
|
SIM_ERM_CLK = 36, /* ERM clock source */
|
||||||
|
SIM_DMA_CLK = 37, /* DMA clock source */
|
||||||
|
SIM_MPU_CLK = 38, /* MPU clock source */
|
||||||
|
SIM_MSCM_CLK = 39, /* MSCM clock source */
|
||||||
|
QSPI_MODULE_SFIF_CLK_HYP = 40, /* QSPI module SFIF clock source */
|
||||||
|
QSPI_MODULE_CLK = 41, /* QSPI module clock source */
|
||||||
|
QSPI_MODULE_CLK_SFIF = 42, /* QSPI module clock source SFIF */
|
||||||
|
QSPI_MODULE_CLK_2XSFIF = 43, /* QSPI module clock source 2XSFIF*/
|
||||||
|
SIM_END_OF_CLOCKS = 44, /* End of SIM clocks */
|
||||||
|
|
||||||
|
CMP0_CLK = 45, /* CMP0 clock source */
|
||||||
|
CRC0_CLK = 46, /* CRC0 clock source */
|
||||||
|
DMAMUX0_CLK = 47, /* DMAMUX0 clock source */
|
||||||
|
EWM0_CLK = 48, /* EWM0 clock source */
|
||||||
|
PORTA_CLK = 49, /* PORTA clock source */
|
||||||
|
PORTB_CLK = 50, /* PORTB clock source */
|
||||||
|
PORTC_CLK = 51, /* PORTC clock source */
|
||||||
|
PORTD_CLK = 52, /* PORTD clock source */
|
||||||
|
PORTE_CLK = 53, /* PORTE clock source */
|
||||||
|
RTC0_CLK = 54, /* RTC0 clock source */
|
||||||
|
SAI0_CLK = 55, /* SAI0 clock source */
|
||||||
|
SAI1_CLK = 56, /* SAI1 clock source */
|
||||||
|
PCC_END_OF_BUS_CLOCKS = 57, /* End of BUS clocks */
|
||||||
|
FlexCAN0_CLK = 58, /* FlexCAN0 clock source */
|
||||||
|
FlexCAN1_CLK = 59, /* FlexCAN1 clock source */
|
||||||
|
FlexCAN2_CLK = 60, /* FlexCAN2 clock source */
|
||||||
|
PDB0_CLK = 61, /* PDB0 clock source */
|
||||||
|
PDB1_CLK = 62, /* PDB1 clock source */
|
||||||
|
PCC_END_OF_SYS_CLOCKS = 63, /* End of SYS clocks */
|
||||||
|
FTFC0_CLK = 64, /* FTFC0 clock source */
|
||||||
|
PCC_END_OF_SLOW_CLOCKS = 65, /* End of SLOW clocks */
|
||||||
|
ENET0_CLK = 66, /* ENET0 clock source */
|
||||||
|
FTM0_CLK = 67, /* FTM0 clock source */
|
||||||
|
FTM1_CLK = 68, /* FTM1 clock source */
|
||||||
|
FTM2_CLK = 69, /* FTM2 clock source */
|
||||||
|
FTM3_CLK = 70, /* FTM3 clock source */
|
||||||
|
FTM4_CLK = 71, /* FTM4 clock source */
|
||||||
|
FTM5_CLK = 72, /* FTM5 clock source */
|
||||||
|
FTM6_CLK = 73, /* FTM6 clock source */
|
||||||
|
FTM7_CLK = 74, /* FTM7 clock source */
|
||||||
|
PCC_END_OF_ASYNCH_DIV1_CLOCKS = 75, /* End of ASYNCH DIV1 clocks */
|
||||||
|
ADC0_CLK = 76, /* ADC0 clock source */
|
||||||
|
ADC1_CLK = 77, /* ADC1 clock source */
|
||||||
|
FLEXIO0_CLK = 78, /* FLEXIO0 clock source */
|
||||||
|
LPI2C0_CLK = 79, /* LPI2C0 clock source */
|
||||||
|
LPI2C1_CLK = 80, /* LPI2C1 clock source */
|
||||||
|
LPIT0_CLK = 81, /* LPIT0 clock source */
|
||||||
|
LPSPI0_CLK = 82, /* LPSPI0 clock source */
|
||||||
|
LPSPI1_CLK = 83, /* LPSPI1 clock source */
|
||||||
|
LPSPI2_CLK = 84, /* LPSPI2 clock source */
|
||||||
|
LPTMR0_CLK = 85, /* LPTMR0 clock source */
|
||||||
|
LPUART0_CLK = 86, /* LPUART0 clock source */
|
||||||
|
LPUART1_CLK = 87, /* LPUART1 clock source */
|
||||||
|
LPUART2_CLK = 88, /* LPUART2 clock source */
|
||||||
|
QSPI0_CLK = 89, /* QSPI0 clock source */
|
||||||
|
PCC_END_OF_ASYNCH_DIV2_CLOCKS = 90, /* End of ASYNCH DIV2 clocks */
|
||||||
|
PCC_END_OF_CLOCKS = 91, /* End of PCC clocks */
|
||||||
|
CLOCK_NAME_COUNT = 92, /* The total number of entries */
|
||||||
|
};
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Data
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
/************************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
************************************************************************************/
|
||||||
|
|
||||||
|
#endif /* __ARCH_ARM_SRC_S32K1XX_S32K14X_S32K14X_CLOCKNAMES_H */
|
@ -31,6 +31,25 @@
|
|||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
|
* Portions of the logic within this file derives from NXP sample code for
|
||||||
|
* the S32K1xx MCUs. That sample code has this licensing information:
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 - 2015, Freescale Semiconductor, Inc.
|
||||||
|
* Copyright 2016-2018 NXP
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY NXP "AS IS" AND ANY EXPRESSED 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 NXP OR ITS 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.
|
||||||
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -43,13 +62,15 @@
|
|||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
|
|
||||||
#include <nuttx/arch.h>
|
#include <nuttx/arch.h>
|
||||||
#include <arch/board/board.h>
|
|
||||||
|
|
||||||
#include "up_arch.h"
|
#include "up_arch.h"
|
||||||
#include "up_internal.h"
|
#include "up_internal.h"
|
||||||
|
|
||||||
|
#include "hardware/s32k1xx_scg.h"
|
||||||
#include "s32k1xx_clockconfig.h"
|
#include "s32k1xx_clockconfig.h"
|
||||||
|
|
||||||
|
#include <arch/board/board.h> /* Include last. May have dependencies */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Private Functions
|
* Private Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -69,7 +90,91 @@
|
|||||||
*
|
*
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
void s32k1xx_clockconfig(FAR const struct pll_setup_s *pllsetup)
|
void s32k1xx_clockconfig(FAR const struct clock_configuration_s *clkcfg)
|
||||||
{
|
{
|
||||||
#warning Missing logic
|
#warning Missing logic
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: s32k1xx_get_coreclk
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Return the current value of the CORE clock frequency.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Values:
|
||||||
|
* The current value of the CORE clock frequency. Zero is returned on any
|
||||||
|
* failure.
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
uint32_t s32k1xx_get_coreclk(void)
|
||||||
|
{
|
||||||
|
uint32_t coreclk = 0;
|
||||||
|
uint32_t regval;
|
||||||
|
uint32_t divider;
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
uint32_t prediv;
|
||||||
|
uint32_t mult;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Get the core clock divider */
|
||||||
|
|
||||||
|
regval = getreg32(S32K1XX_SCG_CSR);
|
||||||
|
divider = ((regval & SCG_CSR_DIVCORE_MASK) >> SCG_CSR_DIVCORE_SHIFT) + 1;
|
||||||
|
|
||||||
|
/* Handle according to the selection clock source */
|
||||||
|
|
||||||
|
switch (regval & SCG_CSR_SCS_MASK)
|
||||||
|
{
|
||||||
|
case SCG_CSR_SCS_SOSC: /* System OSC */
|
||||||
|
|
||||||
|
coreclk = BOARD_XTAL_FREQUENCY;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SCG_CSR_SCS_SIRC: /* Slow IRC */
|
||||||
|
regval = getreg32(S32K1XX_SCG_SIRCCFG) & SCG_SIRCCFG_RANGE;
|
||||||
|
if (regval == SCG_SIRCCFG_LOWRANGE)
|
||||||
|
{
|
||||||
|
/* Slow IRC low range clock (2 MHz) */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Slow IRC high range clock (8 MHz ) */
|
||||||
|
|
||||||
|
coreclk = SCG_SIRQ_HIGHRANGE_FREQUENCY;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SCG_CSR_SCS_FIRC: /* Fast IRC */
|
||||||
|
regval = getreg32(S32K1XX_SCG_FIRCCFG) & SCG_FIRCCFG_RANGE;
|
||||||
|
if (regval != SCG_FIRCCFG_48MHZ)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fast IRC is trimmed to 48 MHz */
|
||||||
|
|
||||||
|
coreclk = SCG_FIRQ_FREQUENCY0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
case 0x6SCG_CSR_SPLL_FIRC: /* System PLL */
|
||||||
|
/* Coreclock = Fxtal * mult / (2 * prediv) */
|
||||||
|
|
||||||
|
regval = getreg32(S32K1XX_SCG_SPLLCFG);
|
||||||
|
prediv = ((regval & SCG_SPLLCFG_PREDIV_MASK) >> SCG_SPLLCFG_PREDIV_SHIFT) + 1;
|
||||||
|
mult = ((regval & SCG_SPLLCFG_MULT_MASK) >> SCG_SPLLCFG_MULT_SHIFT) + 16;
|
||||||
|
|
||||||
|
coreclk = BOARD_XTAL_FREQUENCY * mult / (2 * prediv);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return coreclk / divider;
|
||||||
|
}
|
||||||
|
@ -31,6 +31,25 @@
|
|||||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
* POSSIBILITY OF SUCH DAMAGE.
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
*
|
*
|
||||||
|
* Some of the definitions within this file derivesfrom NXP sample code for
|
||||||
|
* the S32K1xx MCUs. That sample code has this licensing information:
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 - 2015, Freescale Semiconductor, Inc.
|
||||||
|
* Copyright 2016-2018 NXP
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY NXP "AS IS" AND ANY EXPRESSED 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 NXP OR ITS 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 __ARCH_ARM_SRC_S32K1XX_S32K1XX_CLKCONFIG_H
|
#ifndef __ARCH_ARM_SRC_S32K1XX_S32K1XX_CLKCONFIG_H
|
||||||
@ -41,34 +60,449 @@
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#if defined(CONFIG_ARCH_CHIP_S32K11X)
|
||||||
|
# include "s32k14x/s32k14x_clocknames.h"
|
||||||
|
#elif defined(CONFIG_ARCH_CHIP_S32K14X)
|
||||||
|
# include "s32k14x/s32k14x_clocknames.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* Nomial frequencies of internal clocks */
|
||||||
|
|
||||||
|
#define SCG_SIRQ_LOWRANGE_FREQUENCY 2000000 /* 2MHz */
|
||||||
|
#define SCG_SIRQ_HIGHRANGE_FREQUENCY 8000000 /* 8MHz */
|
||||||
|
#define SCG_FIRQ_FREQUENCY0 48000000 /* 48MHz */
|
||||||
|
|
||||||
|
#define NUMBER_OF_TCLK_INPUTS 3
|
||||||
|
|
||||||
|
/* Values for peripheral_clock_source_t. An enumeration is not appropriate
|
||||||
|
* because some of the values are duplicates.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CLK_SRC_OFF 0 /* Clock is off */
|
||||||
|
#define CLK_SRC_SOSC 1 /* OSCCLK - System Oscillator Bus Clock */
|
||||||
|
#define CLK_SRC_SIRC 2 /* SCGIRCLK - Slow IRC Clock */
|
||||||
|
#define CLK_SRC_FIRC 3 /* SCGFIRCLK - Fast IRC Clock */
|
||||||
|
#define CLK_SRC_SPLL 6 /* SCGPCLK System PLL clock */
|
||||||
|
#define CLK_SRC_SOSC_DIV1 1 /* OSCCLK - System Oscillator Bus Clock */
|
||||||
|
#define CLK_SRC_SIRC_DIV1 2 /* SCGIRCLK - Slow IRC Clock */
|
||||||
|
#define CLK_SRC_FIRC_DIV1 3 /* SCGFIRCLK - Fast IRC Clock */
|
||||||
|
#define CLK_SRC_SPLL_DIV1 6 /* SCGPCLK System PLL clock */
|
||||||
|
#define CLK_SRC_SOSC_DIV2 1 /* OSCCLK - System Oscillator Bus Clock */
|
||||||
|
#define CLK_SRC_SIRC_DIV2 2 /* SCGIRCLK - Slow IRC Clock */
|
||||||
|
#define CLK_SRC_FIRC_DIV2 3 /* SCGFIRCLK - Fast IRC Clock */
|
||||||
|
#define CLK_SRC_SPLL_DIV2 6 /* SCGPCLK System PLL clock */
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Types
|
* Public Types
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* PLL setup structure.
|
/* Clock Configuration
|
||||||
*
|
*
|
||||||
* This structure can be used to define a PLL configuration. If powering
|
* These structure are used to define the clock configuration.
|
||||||
* up or waiting for PLL lock, the PLL input clock source should be
|
|
||||||
* configured prior to PLL setup.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct pll_setup_s
|
/* SCG SIRC clock configuration */
|
||||||
|
|
||||||
|
enum scg_sirc_range_e
|
||||||
{
|
{
|
||||||
uint32_t pllclksel; /* PLL clock source register SYSPLLCLKSEL */
|
SCG_SIRC_RANGE_HIGH = 1, /* Slow IRC high range clock (8 MHz). */
|
||||||
uint32_t pllctrl; /* PLL control register SYSPLLCTRL */
|
};
|
||||||
uint32_t pllndec; /* PLL NDEC register SYSPLLNDEC */
|
|
||||||
uint32_t pllpdec; /* PLL PDEC register SYSPLLPDEC */
|
enum scg_async_clock_div_e
|
||||||
uint32_t pllmdec; /* PLL MDEC registers SYSPLLPDEC */
|
{
|
||||||
uint32_t pllfout; /* Actual PLL output frequency */
|
SCG_ASYNC_CLOCK_DISABLE = 0, /* Clock output is disabled */
|
||||||
uint32_t pllfrac; /* Only aduio PLL has this function*/
|
SCG_ASYNC_CLOCK_DIV_BY_1 = 1, /* Divided by 1 */
|
||||||
uint32_t pllflags; /* PLL setup flags */
|
SCG_ASYNC_CLOCK_DIV_BY_2 = 2, /* Divided by 2 */
|
||||||
uint32_t ahbdiv; /* AHB divider */
|
SCG_ASYNC_CLOCK_DIV_BY_4 = 3, /* Divided by 4 */
|
||||||
|
SCG_ASYNC_CLOCK_DIV_BY_8 = 4, /* Divided by 8 */
|
||||||
|
SCG_ASYNC_CLOCK_DIV_BY_16 = 5, /* Divided by 16 */
|
||||||
|
SCG_ASYNC_CLOCK_DIV_BY_32 = 6, /* Divided by 32 */
|
||||||
|
SCG_ASYNC_CLOCK_DIV_BY_64 = 7 /* Divided by 64 */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_sirc_config_s
|
||||||
|
{
|
||||||
|
enum scg_sirc_range_e range; /* Slow IRC frequency range */
|
||||||
|
enum scg_async_clock_div_e div1; /* Asynchronous peripheral source */
|
||||||
|
enum scg_async_clock_div_e div2; /* Asynchronous peripheral source */
|
||||||
|
bool initialize; /* true: Initialize the SIRC module */
|
||||||
|
bool stopmode; /* true: Enable SIRC in stop mode */
|
||||||
|
bool lowpower; /* true: Enable SIRC in low power mode */
|
||||||
|
bool locked; /* true: Lock SIRC Control Register */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SCG FIRC clock configuration */
|
||||||
|
|
||||||
|
enum scg_firc_range_e
|
||||||
|
{
|
||||||
|
SCG_FIRC_RANGE_48M = 0, /* Fast IRC is trimmed to 48MHz */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_firc_config_s
|
||||||
|
{
|
||||||
|
enum scg_firc_range_e range; /* Fast IRC frequency range */
|
||||||
|
enum scg_async_clock_div_e div1; /* Asynchronous peripheral source */
|
||||||
|
enum scg_async_clock_div_e div2; /* Asynchronous peripheral source */
|
||||||
|
bool initialize; /* true: Initialize the FIRC module */
|
||||||
|
bool stopmode; /* true: Enable FIRC in stop mode */
|
||||||
|
bool lowpower; /* true: Enable FIRC in low power mode */
|
||||||
|
bool regulator; /* true: Enable FIRC regulator */
|
||||||
|
bool locked; /* true: Lock FIRC Control Register */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SCG SOSC Clock Configuration */
|
||||||
|
|
||||||
|
enum scg_sosc_monitor_mode_e
|
||||||
|
{
|
||||||
|
SCG_SOSC_MONITOR_DISABLE = 0, /* Monitor disable */
|
||||||
|
SCG_SOSC_MONITOR_INT = 1, /* Interrupt when system OSC error detected */
|
||||||
|
SCG_SOSC_MONITOR_RESET = 2, /* Reset when system OSC error detected */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum scg_sosc_ext_ref_e
|
||||||
|
{
|
||||||
|
SCG_SOSC_REF_EXT = 0, /* External reference clock requested */
|
||||||
|
SCG_SOSC_REF_OSC = 1, /* Internal oscillator of OSC requested */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum scg_sosc_gain_e
|
||||||
|
{
|
||||||
|
SCG_SOSC_GAIN_LOW = 0, /* Configure crystal oscillator for low-power operation */
|
||||||
|
SCG_SOSC_GAIN_HIGH = 1, /* Configure crystal oscillator for high-gain operation */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum scg_sosc_range_e
|
||||||
|
{
|
||||||
|
SCG_SOSC_RANGE_MID = 2, /* Medium frequency range selected for the crystal OSC (4 Mhz to 8 Mhz). */
|
||||||
|
SCG_SOSC_RANGE_HIGH = 3, /* High frequency range selected for the crystal OSC (8 Mhz to 40 Mhz). */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_sosc_config_s
|
||||||
|
{
|
||||||
|
uint32_t freq; /* System OSC frequency */
|
||||||
|
enum scg_sosc_monitor_mode_e mod; /* System OSC Clock monitor mode */
|
||||||
|
enum scg_sosc_ext_ref_e extref; /* System OSC External Reference Select */
|
||||||
|
enum scg_sosc_gain_e gain; /* System OSC high-gain operation */
|
||||||
|
enum scg_sosc_gain_e range; /* System OSC frequency range */
|
||||||
|
enum scg_async_clock_div_e div1; /* Asynchronous peripheral source */
|
||||||
|
enum scg_async_clock_div_e div2; /* Asynchronous peripheral source */
|
||||||
|
bool initialize; /* true: Initialize the System OSC module */
|
||||||
|
bool stopmode; /* true: Enable System OSC in stop mode */
|
||||||
|
bool lowpower; /* true: Enable System OSC in low power mode */
|
||||||
|
bool locked; /* true: Lock System OSC Control Register */
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
/* SCG SPLL Clock Configuration */
|
||||||
|
|
||||||
|
enum scg_spll_monitor_mode_e
|
||||||
|
{
|
||||||
|
SCG_SPLL_MONITOR_DISABLE = 0, /* Monitor disable */
|
||||||
|
SCG_SPLL_MONITOR_INT = 1, /* Interrupt when system PLL error detected */
|
||||||
|
SCG_SPLL_MONITOR_RESET = 2 /* Reset when system PLL error detected */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_spll_config_s
|
||||||
|
{
|
||||||
|
enum scg_spll_monitor_mode_e mode; /* Clock monitor mode selected */
|
||||||
|
enum scg_async_clock_div_e div1; /* Asynchronous peripheral source */
|
||||||
|
enum scg_async_clock_div_e div2; /* Asynchronous peripheral source */
|
||||||
|
uint8_t prediv; /* PLL reference clock divider */
|
||||||
|
uint8_t mult; /* System PLL multiplier */
|
||||||
|
uint8_t src; /* System PLL source */
|
||||||
|
bool initialize; /* true: Initialize or not the System PLL clock */
|
||||||
|
bool stopmode; /* true: Enable System PLL clock in stop mode */
|
||||||
|
bool locked; /* true: Lock System PLL clock Control Register */
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* SCG RTC Clock Configuration */
|
||||||
|
|
||||||
|
struct scg_rtc_config_s
|
||||||
|
{
|
||||||
|
uint32_t clkin; /* RTC_CLKIN frequency */
|
||||||
|
bool initialize; /* true: Initialize the RTC module */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SCG ClockOut Configuration */
|
||||||
|
|
||||||
|
enum scg_clockout_src_e
|
||||||
|
{
|
||||||
|
SCG_CLOCKOUT_SRC_SCG_SLOW = 0, /* SCG SLOW */
|
||||||
|
SCG_CLOCKOUT_SRC_SOSC = 1, /* System OSC */
|
||||||
|
SCG_CLOCKOUT_SRC_SIRC = 2, /* Slow IRC */
|
||||||
|
SCG_CLOCKOUT_SRC_FIRC = 3, /* Fast IRC */
|
||||||
|
SCG_CLOCKOUT_SRC_SPLL = 6 /* System PLL */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_clockout_config_s
|
||||||
|
{
|
||||||
|
enum scg_clockout_src_e source; /* ClockOut source select */
|
||||||
|
bool initialize; /* true: Initialize the ClockOut */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SCG Clock Mode Configuration */
|
||||||
|
|
||||||
|
enum scg_system_clock_div_e
|
||||||
|
{
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_1 = 0, /* Divided by 1 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_2 = 1, /* Divided by 2 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_3 = 2, /* Divided by 3 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_4 = 3, /* Divided by 4 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_5 = 4, /* Divided by 5 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_6 = 5, /* Divided by 6 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_7 = 6, /* Divided by 7 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_8 = 7, /* Divided by 8 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_9 = 8, /* Divided by 9 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_10 = 9, /* Divided by 10 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_11 = 10, /* Divided by 11 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_12 = 11, /* Divided by 12 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_13 = 12, /* Divided by 13 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_14 = 13, /* Divided by 14 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_15 = 14, /* Divided by 15 */
|
||||||
|
SCG_SYSTEM_CLOCK_DIV_BY_16 = 15, /* Divided by 16 */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum scg_system_clock_src_e
|
||||||
|
{
|
||||||
|
SCG_SYSTEM_CLOCK_SRC_SYS_OSC = 1, /* System OSC */
|
||||||
|
SCG_SYSTEM_CLOCK_SRC_SIRC = 2, /* Slow IRC */
|
||||||
|
SCG_SYSTEM_CLOCK_SRC_FIRC = 3, /* Fast IRC */
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
SCG_SYSTEM_CLOCK_SRC_SYS_PLL = 6, /* System PLL */
|
||||||
|
#endif
|
||||||
|
SCG_SYSTEM_CLOCK_SRC_NONE = 255 /* MAX value */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_system_clock_config_s
|
||||||
|
{
|
||||||
|
enum scg_system_clock_div_e divslow; /* Slow clock divider */
|
||||||
|
enum scg_system_clock_div_e divbus; /* BUS clock divider */
|
||||||
|
enum scg_system_clock_div_e divcore; /* Core clock divider */
|
||||||
|
enum scg_system_clock_src_e src; /* System clock source */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct scg_clock_mode_config_s
|
||||||
|
{
|
||||||
|
struct scg_system_clock_config_s rccr; /* Run Clock Control configuration */
|
||||||
|
struct scg_system_clock_config_s vccr; /* VLPR Clock Control configuration */
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
struct scg_system_clock_config_s hccr; /* HSRUN Clock Control configuration */
|
||||||
|
#endif
|
||||||
|
enum scg_system_clock_src_e altclk; /* Alternate clock used during initialization */
|
||||||
|
bool initialize; /* true: Initialize the Clock Mode Configuration */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Overall SCG Configuration */
|
||||||
|
|
||||||
|
struct scg_config_s
|
||||||
|
{
|
||||||
|
struct scg_sirc_config_s sirc; /* Slow internal reference clock configuration */
|
||||||
|
struct scg_firc_config_s firc; /* Fast internal reference clock configuration */
|
||||||
|
struct scg_sosc_config_s sosc; /* System oscillator configuration */
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
struct scg_spll_config_s spll; /* System Phase locked loop configuration */
|
||||||
|
#endif
|
||||||
|
struct scg_rtc_config_s rtc; /* Real Time Clock configuration */
|
||||||
|
struct scg_clockout_config_s clockout; /* SCG ClockOut Configuration */
|
||||||
|
struct scg_clock_mode_config_s clockmode; /* SCG Clock Mode Configuration */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM ClockOut configuration */
|
||||||
|
|
||||||
|
enum sim_clkout_src_e
|
||||||
|
{
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_SCG_CLKOUT = 0, /* SCG CLKOUT */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_SOSC_DIV2_CLK = 2, /* SOSC DIV2 CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_SIRC_DIV2_CLK = 4, /* SIRC DIV2 CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_FIRC_DIV2_CLK = 6, /* FIRC DIV2 CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_HCLK = 7, /* HCLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_SPLL_DIV2_CLK = 8, /* SPLL DIV2 CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_BUS_CLK = 9, /* BUS_CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_LPO_128K_CLK = 10, /* LPO_CLK 128 Khz */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_LPO_CLK = 12, /* LPO_CLK as selected by SIM LPO CLK Select */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_RTC_CLK = 14, /* RTC CLK as selected by SIM CLK 32 KHz Select */
|
||||||
|
#ifdef CONFIG_ARCH_CHIP_S32K14X
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_SFIF_CLK_HYP = 5, /* SFIF_CLK_HYP */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_IPG_CLK = 11, /* IPG_CLK */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_IPG_CLK_SFIF = 13, /* IPG_CLK_SFIF */
|
||||||
|
SIM_CLKOUT_SEL_SYSTEM_IPG_CLK_2XSFIF = 15 /* IP_CLK_2XSFIF */
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
enum sim_clkout_div_e
|
||||||
|
{
|
||||||
|
SIM_CLKOUT_DIV_BY_1 = 0, /* Divided by 1 */
|
||||||
|
SIM_CLKOUT_DIV_BY_2 = 1, /* Divided by 2 */
|
||||||
|
SIM_CLKOUT_DIV_BY_3 = 2, /* Divided by 3 */
|
||||||
|
SIM_CLKOUT_DIV_BY_4 = 3, /* Divided by 4 */
|
||||||
|
SIM_CLKOUT_DIV_BY_5 = 4, /* Divided by 5 */
|
||||||
|
SIM_CLKOUT_DIV_BY_6 = 5, /* Divided by 6 */
|
||||||
|
SIM_CLKOUT_DIV_BY_7 = 6, /* Divided by 7 */
|
||||||
|
SIM_CLKOUT_DIV_BY_8 = 7, /* Divided by 8 */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct sim_clock_out_config_e
|
||||||
|
{
|
||||||
|
enum sim_clkout_src_e source; /* SIM ClockOut source select */
|
||||||
|
enum sim_clkout_div_e divider; /* SIM ClockOut divide ratio */
|
||||||
|
bool initialize; /* true: Initialize the ClockOut clock */
|
||||||
|
bool enable; /* true: Enable the ClockOut clock */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM LPO clock configuration */
|
||||||
|
|
||||||
|
enum sim_rtc_clk_sel_src_e
|
||||||
|
{
|
||||||
|
SIM_RTCCLK_SEL_SOSCDIV1_CLK = 0, /* SOSCDIV1 clock */
|
||||||
|
SIM_RTCCLK_SEL_LPO_32K = 1, /* 32 kHz LPO clock */
|
||||||
|
SIM_RTCCLK_SEL_RTC_CLKIN = 2, /* RTC_CLKIN clock */
|
||||||
|
SIM_RTCCLK_SEL_FIRCDIV1_CLK = 3, /* FIRCDIV1 clock */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum sim_lpoclk_sel_src_e
|
||||||
|
{
|
||||||
|
SIM_LPO_CLK_SEL_LPO_128K = 0, /* 128 kHz LPO clock */
|
||||||
|
SIM_LPO_CLK_SEL_NO_CLOCK = 1, /* No clock */
|
||||||
|
SIM_LPO_CLK_SEL_LPO_32K = 2, /* 32 kHz LPO clock which is divided by the 128 kHz LPO clock */
|
||||||
|
SIM_LPO_CLK_SEL_LPO_1K = 3, /* 1 kHz LPO clock which is divided by the 128 kHz LPO clock */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct sim_lpo_clock_config_s
|
||||||
|
{
|
||||||
|
enum sim_rtc_clk_sel_src_e rtc_source; /* RTC_CLK source select */
|
||||||
|
enum sim_lpoclk_sel_src_e lpo_source; /* LPO clock source select */
|
||||||
|
bool initialize; /* true: Initialize the LPO clock */
|
||||||
|
bool lpo32k; /* MSCM Clock Gating Control enable */
|
||||||
|
bool lpo1k; /* MSCM Clock Gating Control enable */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM TCLK clock configuration */
|
||||||
|
|
||||||
|
struct sim_tclk_config_s
|
||||||
|
{
|
||||||
|
uint32_t tclkFreq[NUMBER_OF_TCLK_INPUTS]; /* TCLKx frequency */
|
||||||
|
bool initialize; /* true: Initialize the TCLKx clock */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM clock gating control configuration */
|
||||||
|
|
||||||
|
struct sim_plat_gate_config_s
|
||||||
|
{
|
||||||
|
bool initialize; /* true: Initialize the clock gating control */
|
||||||
|
bool mscm; /* true: Enable MSCM Clock Gating Control */
|
||||||
|
bool mpu; /* true: Enable MPU Clock Gating Control */
|
||||||
|
bool dma; /* true: Enable DMA Clock Gating Control */
|
||||||
|
bool erm; /* true: Enable ERM Clock Gating Control */
|
||||||
|
bool eim; /* true: Enable EIM Clock Gating Control */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM trace clock configuration */
|
||||||
|
|
||||||
|
enum clock_trace_src_e
|
||||||
|
{
|
||||||
|
CLOCK_TRACE_SRC_CORE_CLK = 0x0 /* Core clock */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct sim_trace_clock_config_s
|
||||||
|
{
|
||||||
|
enum clock_trace_src_e source; /* Trace clock select */
|
||||||
|
uint8_t divider; /* Trace clock divider divisor */
|
||||||
|
bool initialize; /* true: Initialize the Trace clock */
|
||||||
|
bool enable; /* true: Enable Trace clock divider */
|
||||||
|
bool fraction; /* true: EnableTrace clock divider fraction */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* SIM QSPI clock configuration */
|
||||||
|
|
||||||
|
struct sim_qspi_ref_clk_gating_s
|
||||||
|
{
|
||||||
|
bool refclk; /* true: Enable QSPI internal reference clock gating */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Overall SIM clock configuration */
|
||||||
|
|
||||||
|
struct sim_clock_config_s
|
||||||
|
{
|
||||||
|
struct sim_clock_out_config_e clockout; /* Clock Out configuration */
|
||||||
|
struct sim_lpo_clock_config_s lpoclk; /* Low Power Clock configuration */
|
||||||
|
struct sim_tclk_config_s tclk; /* Platform Gate Clock configuration */
|
||||||
|
struct sim_plat_gate_config_s platgate; /* Platform Gate Clock configuration */
|
||||||
|
struct sim_trace_clock_config_s traceclk; /* Trace clock configuration */
|
||||||
|
struct sim_qspi_ref_clk_gating_s qspirefclk; /* Qspi Reference Clock Gating */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PCC clock configuration */
|
||||||
|
|
||||||
|
typedef uint8_t peripheral_clock_source_t; /* See CLK_SRC_* definitions */
|
||||||
|
|
||||||
|
enum peripheral_clock_frac_e
|
||||||
|
{
|
||||||
|
MULTIPLY_BY_ONE = 0, /* Fractional value is zero */
|
||||||
|
MULTIPLY_BY_TWO = 1 /* Fractional value is one */
|
||||||
|
};
|
||||||
|
|
||||||
|
enum peripheral_clock_divider_e
|
||||||
|
{
|
||||||
|
DIVIDE_BY_ONE = 0, /* Divide by 1 (pass-through, no clock divide) */
|
||||||
|
DIVIDE_BY_TWO = 1, /* Divide by 2 */
|
||||||
|
DIVIDE_BY_THREE = 2, /* Divide by 3 */
|
||||||
|
DIVIDE_BY_FOUR = 3, /* Divide by 4 */
|
||||||
|
DIVIDE_BY_FIVE = 4, /* Divide by 5 */
|
||||||
|
DIVIDE_BY_SIX = 5, /* Divide by 6 */
|
||||||
|
DIVIDE_BY_SEVEN = 6, /* Divide by 7 */
|
||||||
|
DIVIDE_BY_EIGTH = 7 /* Divide by 8 */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct peripheral_clock_config_s
|
||||||
|
{
|
||||||
|
/* clkname is the name of the peripheral clock. It must be one of the values
|
||||||
|
* defined in the chip specific xxxxxx_configname.h header file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
enum clock_names_e clkname; /* Peripheral clock name */
|
||||||
|
bool clkgate; /* Peripheral clock gate */
|
||||||
|
peripheral_clock_source_t clksrc; /* Peripheral clock source */
|
||||||
|
enum peripheral_clock_frac_e frac; /* Peripheral clock fractional value */
|
||||||
|
enum peripheral_clock_divider_e divider; /* Peripheral clock divider value */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pcc_config_s
|
||||||
|
{
|
||||||
|
uint32_t count; /* Number of peripherals to be configured */
|
||||||
|
struct peripheral_clock_config_s *pclks; /* Pointer to the peripheral clock configurations array */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* PMC clock configuration */
|
||||||
|
|
||||||
|
struct pmc_lpo_clock_config_s
|
||||||
|
{
|
||||||
|
int8_t trim; /* LPO trimming value */
|
||||||
|
bool initialize; /* true: Initialize the LPO */
|
||||||
|
bool enable; /* true: Enable the LPO */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct pmc_config_s
|
||||||
|
{
|
||||||
|
struct pmc_lpo_clock_config_s lpoclk; /* Low Power Clock configuration */
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Overall clock configuration */
|
||||||
|
|
||||||
|
struct clock_configuration_s
|
||||||
|
{
|
||||||
|
struct scg_config_s scg; /* SCG Clock configuration */
|
||||||
|
struct sim_clock_config_s sim; /* SIM Clock configuration */
|
||||||
|
struct pcc_config_s pcc; /* PCC Clock configuration */
|
||||||
|
struct pmc_config_s pmc; /* PMC Clock configuration */
|
||||||
};
|
};
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -105,13 +539,13 @@ extern "C"
|
|||||||
*
|
*
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
void s32k1xx_clockconfig(FAR const struct pll_setup_s *pllsetup);
|
void s32k1xx_clockconfig(FAR const struct clock_configuration_s *clkcfg);
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: s32k1xx_get_coreclk
|
* Name: s32k1xx_get_coreclk
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Return the current selection of the CORE clock.
|
* Return the current value of the CORE clock frequency.
|
||||||
*
|
*
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@
|
|||||||
|
|
||||||
/* This describes the initial PLL configuration */
|
/* This describes the initial PLL configuration */
|
||||||
|
|
||||||
static const struct pll_setup_s g_initial_pll_setup =
|
static const struct clock_configuration_s g_initial_clkconfig =
|
||||||
{
|
{
|
||||||
0 /* REVISIT */
|
0 /* REVISIT */
|
||||||
#warning Missing logic
|
#warning Missing logic
|
||||||
@ -202,7 +202,7 @@ void __start(void)
|
|||||||
* .bss or .data have beeninitialized.
|
* .bss or .data have beeninitialized.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
s32k1xx_clockconfig(&g_initial_pll_setup);
|
s32k1xx_clockconfig(&g_initial_clkconfig);
|
||||||
s32k1xx_lowsetup();
|
s32k1xx_lowsetup();
|
||||||
showprogress('A');
|
showprogress('A');
|
||||||
|
|
||||||
|
@ -72,6 +72,7 @@ SECTIONS
|
|||||||
_etext = ABSOLUTE(.);
|
_etext = ABSOLUTE(.);
|
||||||
} > flash
|
} > flash
|
||||||
|
|
||||||
|
. = ALIGN(4);
|
||||||
.init_section :
|
.init_section :
|
||||||
{
|
{
|
||||||
_sinit = ABSOLUTE(.);
|
_sinit = ABSOLUTE(.);
|
||||||
@ -79,11 +80,13 @@ SECTIONS
|
|||||||
_einit = ABSOLUTE(.);
|
_einit = ABSOLUTE(.);
|
||||||
} > flash
|
} > flash
|
||||||
|
|
||||||
|
. = ALIGN(4);
|
||||||
.ARM.extab :
|
.ARM.extab :
|
||||||
{
|
{
|
||||||
*(.ARM.extab*)
|
*(.ARM.extab*)
|
||||||
} >flash
|
} >flash
|
||||||
|
|
||||||
|
. = ALIGN(4);
|
||||||
__exidx_start = ABSOLUTE(.);
|
__exidx_start = ABSOLUTE(.);
|
||||||
.ARM.exidx :
|
.ARM.exidx :
|
||||||
{
|
{
|
||||||
@ -91,6 +94,7 @@ SECTIONS
|
|||||||
} >flash
|
} >flash
|
||||||
__exidx_end = ABSOLUTE(.);
|
__exidx_end = ABSOLUTE(.);
|
||||||
|
|
||||||
|
. = ALIGN(4);
|
||||||
.data :
|
.data :
|
||||||
{
|
{
|
||||||
_sdata = ABSOLUTE(.);
|
_sdata = ABSOLUTE(.);
|
||||||
|
Loading…
Reference in New Issue
Block a user