arch/arm/src/s32k1xx/s32k1xx_clockconfig.h: Add data structures that will eventually be used to configure clocking.

This commit is contained in:
Gregory Nutt 2019-08-15 14:02:37 -06:00
parent 061728b440
commit fba40c40f1
7 changed files with 903 additions and 21 deletions

View File

@ -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 */

View 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 */

View 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 */

View File

@ -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;
}

View File

@ -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.
* *
*****************************************************************************/ *****************************************************************************/

View File

@ -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');

View File

@ -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(.);