@@ -278,3 +278,4 @@ int enable_i2c_clk(unsigned char enable, unsigned int i2c_num);
int set_clk_enet(enum enet_freq type);
int set_clk_eqos(enum enet_freq type);
void hab_caam_clock_enable(unsigned char enable);
+void enable_usboh3_clk(unsigned int enable);
@@ -298,6 +298,22 @@ int intpll_configure(enum pll_clocks pll, ulong freq)
return 0;
}
+void enable_usboh3_clk(unsigned int enable)
+{
+ if (enable) {
+ clock_enable(CCGR_USB_MSCALE_PL301, 0);
+ /* 500M */
+ clock_set_target_val(USB_BUS_CLK_ROOT, CLK_ROOT_ON | CLK_ROOT_SOURCE_SEL(1));
+ /* 100M */
+ clock_set_target_val(USB_CORE_REF_CLK_ROOT, CLK_ROOT_ON | CLK_ROOT_SOURCE_SEL(1));
+ /* 100M */
+ clock_set_target_val(USB_PHY_REF_CLK_ROOT, CLK_ROOT_ON | CLK_ROOT_SOURCE_SEL(1));
+ clock_enable(CCGR_USB_MSCALE_PL301, 1);
+ } else {
+ clock_enable(CCGR_USB_MSCALE_PL301, 0);
+ }
+}
+
void init_uart_clk(u32 index)
{
/*