2019-01-06 16:05:38 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* arch/arm/src/am335x/am335x_clockconfig.c
|
|
|
|
*
|
2021-03-31 13:01:49 +02:00
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
2019-01-06 16:05:38 +01:00
|
|
|
*
|
2021-03-31 13:01:49 +02:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2019-01-06 16:05:38 +01:00
|
|
|
*
|
2021-03-31 13:01:49 +02:00
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
2019-01-06 16:05:38 +01:00
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
2020-05-01 03:20:29 +02:00
|
|
|
#include "arm_arch.h"
|
2019-07-09 22:50:07 +02:00
|
|
|
#include "hardware/am335x_prcm.h"
|
2019-01-06 16:05:38 +01:00
|
|
|
#include "am335x_config.h"
|
|
|
|
#include "am335x_clockconfig.h"
|
|
|
|
|
2019-07-03 23:26:15 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Private Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
2019-12-11 00:55:08 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: am335x_power_domain_transition_enable
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
static void am335x_interface_clocks_enable(void)
|
|
|
|
{
|
|
|
|
/* Enable all the Interconnect Modules */
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_L3_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_L3_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_L4LS_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_L4LS_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_L4FW_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_L4FW_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_L4WKUP_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_L4WKUP_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_L3_INSTR_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_L3_INSTR_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_L4HS_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_L4HS_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_OCPWP_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_OCPWP_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: am335x_power_domain_transition_enable
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
static void am335x_power_domain_transition_enable(void)
|
|
|
|
{
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_L3_CLKSTCTRL);
|
|
|
|
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_L4LS_CLKSTCTRL);
|
|
|
|
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_WKUP_CLKSTCTRL);
|
|
|
|
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_L4FW_CLKSTCTRL);
|
|
|
|
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_L3S_CLKSTCTRL);
|
|
|
|
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_OCPWP_L3_CLKSTCTRL);
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_LCDC)
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_LCDC_CLKSTCTRL);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_CPSW)
|
|
|
|
putreg32(CM_CLKSTCTRL_CLKTRCTRL_SW_WKUP, AM335X_CM_PER_CPSW_CLKSTCTRL);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: am335x_peripheral_enable
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
static void am335x_peripheral_enable(void)
|
|
|
|
{
|
|
|
|
uint32_t wkup = CM_WKUP_CLKSTCTRL_L4_WKUP_GCLK;
|
|
|
|
uint32_t per_ocpwp_l3 = CM_PER_OCPWP_L3_CLKSTCTRL_OCPWP_L3_GCLK;
|
|
|
|
uint32_t per_l3 = CM_PER_L3_CLKSTCTRL_L3_GCLK;
|
|
|
|
uint32_t per_l3s = CM_PER_L3S_CLKSTCTRL_L3S_GCLK;
|
|
|
|
uint32_t per_l4ls = CM_PER_L4LS_CLKSTCTRL_L4LS_GCLK;
|
|
|
|
uint32_t per_lcdc = 0;
|
|
|
|
uint32_t per_cpsw = 0;
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_GPIO0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_GPIO0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_TIMER1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_TIMER1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_TIMER1_GCLK;
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_WDT1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_WDT1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_WDT1_GCLK;
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER0
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_TIMER0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_TIMER0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_TIMER0_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART0
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_UART0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_UART0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_UART0_GFCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_I2C0
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_I2C0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_I2C0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_I2C0_GFCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TSC
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_ADC_TSC_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_ADC_TSC_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
wkup |= CM_WKUP_CLKSTCTRL_ADC_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_GPMC_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_GPMC_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_ELM_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_ELM_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_GPIO1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_GPIO1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_GPIO2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_GPIO2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_GPIO3_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_GPIO3_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
2019-12-11 01:04:56 +01:00
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
2019-12-11 00:55:08 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER2
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER2_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER3
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER3_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER3_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER3_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER4
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER4_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER4_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER4_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER5
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER5_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER5_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER5_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER6
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER6_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER6_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER6_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_TIMER7
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TIMER7_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TIMER7_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_TIMER7_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART1
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_UART1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_UART1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_UART_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART2
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_UART2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_UART2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_UART_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART3
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_UART3_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_UART3_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_UART_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART4
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_UART4_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_UART4_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_UART_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_AM335X_UART5
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_UART5_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_UART5_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_UART_GCLK;
|
|
|
|
#endif
|
|
|
|
|
2019-12-16 00:12:54 +01:00
|
|
|
#if defined(CONFIG_AM335X_CAN0)
|
2019-12-11 00:55:08 +01:00
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_DCAN0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_DCAN0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_CAN_CLK;
|
|
|
|
#endif
|
|
|
|
|
2019-12-16 00:12:54 +01:00
|
|
|
#if defined(CONFIG_AM335X_CAN1)
|
2019-12-11 00:55:08 +01:00
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_DCAN1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_DCAN1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_CAN_CLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_SPI0)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_SPI0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_SPI0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_SPI_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_SPI1)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_SPI1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_SPI1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_SPI_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_I2C1)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_I2C1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_I2C1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_I2C_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_I2C2)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_I2C2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_I2C2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_I2C_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_USB0) || defined(CONFIG_AM335X_USB1)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_USB0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_USB0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_MMC0)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_MMC0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_MMC0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L3_CLKSTCTRL_MMC_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_MMC1)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_MMC1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_MMC1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L3_CLKSTCTRL_MMC_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_MMC2)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_MMC2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_MMC2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_l4ls |= CM_PER_L3_CLKSTCTRL_MMC_FCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_LCDC)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_LCDC_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_LCDC_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_lcdc |= CM_PER_LCDC_CLKSTCTRL_LCDC_L4_OCP_GCLK |
|
|
|
|
CM_PER_LCDC_CLKSTCTRL_LCDC_L3_OCP_GCLK;
|
|
|
|
per_l4ls |= CM_PER_L4LS_CLKSTCTRL_LCDC_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_CPSW)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_CPGMAC0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_CPGMAC0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
per_cpsw |= CM_PER_CPSW_CLKSTCTRL_CPSW_125MHZ_GCLK;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(CONFIG_AM335X_DMA)
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TPCC_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TPCC_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TPTC0_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TPTC0_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TPTC1_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TPTC1_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_PER_TPTC2_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_PER_TPTC2_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
putreg32(CM_CLKCTRL_MODULEMODE_ENABLE, AM335X_CM_WKUP_CONTROL_CLKCTRL);
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_CONTROL_CLKCTRL) &
|
|
|
|
(CM_CLKCTRL_MODULEMODE_MASK | CM_CLKCTRL_IDLEST_MASK))
|
|
|
|
!= (CM_CLKCTRL_MODULEMODE_ENABLE | CM_CLKCTRL_IDLEST_FUNC))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_PER_LCDC_CLKSTCTRL) & per_lcdc) != per_lcdc)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_PER_CPSW_CLKSTCTRL) & per_cpsw) != per_cpsw)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_WKUP_CLKSTCTRL) & wkup) != wkup)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_PER_L3S_CLKSTCTRL) & per_l3s) != per_l3s)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_PER_L3_CLKSTCTRL) & per_l3) != per_l3)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-04-01 08:20:14 +02:00
|
|
|
while ((getreg32(AM335X_CM_PER_OCPWP_L3_CLKSTCTRL) & per_ocpwp_l3) !=
|
|
|
|
per_ocpwp_l3)
|
2019-12-11 00:55:08 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2019-12-11 01:04:56 +01:00
|
|
|
while ((getreg32(AM335X_CM_PER_L4LS_CLKSTCTRL) & per_l4ls) != per_l4ls)
|
2019-12-11 00:55:08 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-03 23:26:15 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Name: am335x_dmtimer1ms_clockconfig
|
|
|
|
****************************************************************************/
|
|
|
|
|
2019-12-11 00:55:08 +01:00
|
|
|
static void am335x_dmtimer1ms_clockconfig(void)
|
2019-07-03 23:26:15 +02:00
|
|
|
{
|
|
|
|
putreg32(CM_DPLL_DMTIMER1_CLKSEL_CLK_M_OSC,
|
|
|
|
AM335X_CM_DPLL_CLKSEL_TIMER1MS_CLK);
|
|
|
|
|
|
|
|
while ((getreg32(AM335X_CM_DPLL_CLKSEL_TIMER1MS_CLK) &
|
|
|
|
CM_DPLL_DMTIMER1MS_CLKSEL_MASK)
|
|
|
|
!= CM_DPLL_DMTIMER1_CLKSEL_CLK_M_OSC)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-06 16:05:38 +01:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: am335x_clockconfig
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* Called to initialize the AM335X. This does whatever setup is needed to
|
|
|
|
* put the SoC in a usable state. This includes the initialization of
|
|
|
|
* clocking using the settings in board.h.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
void am335x_clockconfig(void)
|
|
|
|
{
|
|
|
|
/* Don't change the current basic clock configuration if we are running
|
|
|
|
* from SDRAM. In this case, some bootloader logic has already configured
|
|
|
|
* clocking and SDRAM. We are pretty much committed to using things the
|
|
|
|
* way that the bootloader has left them.
|
|
|
|
*
|
|
|
|
* Clocking will be configured at 792 MHz initially when started via
|
|
|
|
* U-Boot. The Linux kernel will uses the CPU frequency scaling code
|
|
|
|
* which will switch the processor frequency between 400 MHz and 1GHz based
|
|
|
|
* on load and temperature. For now, NuttX simply leaves the clocking at
|
|
|
|
* 792MHz.
|
|
|
|
*/
|
|
|
|
|
2019-12-11 00:55:08 +01:00
|
|
|
am335x_interface_clocks_enable();
|
|
|
|
|
|
|
|
am335x_power_domain_transition_enable();
|
|
|
|
|
|
|
|
am335x_peripheral_enable();
|
|
|
|
|
2019-07-03 23:26:15 +02:00
|
|
|
am335x_dmtimer1ms_clockconfig();
|
|
|
|
|
2019-01-06 16:05:38 +01:00
|
|
|
#ifndef CONFIG_AM335X_BOOT_SDRAM
|
|
|
|
# warning Missing logic
|
|
|
|
#endif
|
|
|
|
}
|