mirror of
https://xff.cz/git/u-boot/
synced 2025-10-10 20:46:37 +02:00
arm: imx8ulp: add clock support
Add i.MX8ULP clock support Signed-off-by: Peng Fan <peng.fan@nxp.com>
This commit is contained in:
130
arch/arm/include/asm/arch-imx8ulp/cgc.h
Normal file
130
arch/arm/include/asm/arch-imx8ulp/cgc.h
Normal file
@@ -0,0 +1,130 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||
/*
|
||||
* Copyright 2021 NXP
|
||||
*/
|
||||
|
||||
#ifndef _ASM_ARCH_CGC_H
|
||||
#define _ASM_ARCH_CGC_H
|
||||
|
||||
enum cgc1_clk {
|
||||
DUMMY0_CLK,
|
||||
DUMMY1_CLK,
|
||||
LPOSC,
|
||||
XBAR_BUSCLK,
|
||||
SOSC,
|
||||
SOSC_DIV1,
|
||||
SOSC_DIV2,
|
||||
SOSC_DIV3,
|
||||
FRO,
|
||||
FRO_DIV1,
|
||||
FRO_DIV2,
|
||||
FRO_DIV3,
|
||||
PLL2,
|
||||
PLL3,
|
||||
PLL3_VCODIV,
|
||||
PLL3_PFD0,
|
||||
PLL3_PFD1,
|
||||
PLL3_PFD2,
|
||||
PLL3_PFD3,
|
||||
PLL3_PFD0_DIV1,
|
||||
PLL3_PFD0_DIV2,
|
||||
PLL3_PFD1_DIV1,
|
||||
PLL3_PFD1_DIV2,
|
||||
PLL3_PFD2_DIV1,
|
||||
PLL3_PFD2_DIV2,
|
||||
PLL3_PFD3_DIV1,
|
||||
PLL3_PFD3_DIV2,
|
||||
};
|
||||
|
||||
struct cgc1_regs {
|
||||
u32 verid;
|
||||
u32 rsvd1[4];
|
||||
u32 ca35clk;
|
||||
u32 rsvd2[2];
|
||||
u32 clkoutcfg;
|
||||
u32 rsvd3[4];
|
||||
u32 nicclk;
|
||||
u32 xbarclk;
|
||||
u32 rsvd4[21];
|
||||
u32 clkdivrst;
|
||||
u32 rsvd5[29];
|
||||
u32 soscdiv;
|
||||
u32 rsvd6[63];
|
||||
u32 frodiv;
|
||||
u32 rsvd7[189];
|
||||
u32 pll2csr;
|
||||
u32 rsvd8[3];
|
||||
u32 pll2cfg;
|
||||
u32 rsvd9;
|
||||
u32 pll2denom;
|
||||
u32 pll2num;
|
||||
u32 pll2ss;
|
||||
u32 rsvd10[55];
|
||||
u32 pll3csr;
|
||||
u32 pll3div_vco;
|
||||
u32 pll3div_pfd0;
|
||||
u32 pll3div_pfd1;
|
||||
u32 pll3cfg;
|
||||
u32 pll3pfdcfg;
|
||||
u32 pll3denom;
|
||||
u32 pll3num;
|
||||
u32 pll3ss;
|
||||
u32 pll3lock;
|
||||
u32 rsvd11[54];
|
||||
u32 enetstamp;
|
||||
u32 rsvd12[67];
|
||||
u32 pllusbcfg;
|
||||
u32 rsvd13[59];
|
||||
u32 aud_clk1;
|
||||
u32 sai5_4_clk;
|
||||
u32 tpm6_7clk;
|
||||
u32 mqs1clk;
|
||||
u32 rsvd14[60];
|
||||
u32 lvdscfg;
|
||||
};
|
||||
|
||||
struct cgc2_regs {
|
||||
u32 verid;
|
||||
u32 rsvd1[4];
|
||||
u32 hificlk;
|
||||
u32 rsvd2[2];
|
||||
u32 clkoutcfg;
|
||||
u32 rsvd3[6];
|
||||
u32 niclpavclk;
|
||||
u32 ddrclk;
|
||||
u32 rsvd4[19];
|
||||
u32 clkdivrst;
|
||||
u32 rsvd5[29];
|
||||
u32 soscdiv;
|
||||
u32 rsvd6[63];
|
||||
u32 frodiv;
|
||||
u32 rsvd7[253];
|
||||
u32 pll4csr;
|
||||
u32 pll4div_vco;
|
||||
u32 pll4div_pfd0;
|
||||
u32 pll4div_pfd1;
|
||||
u32 pll4cfg;
|
||||
u32 pll4pfdcfg;
|
||||
u32 pll4denom;
|
||||
u32 pll4num;
|
||||
u32 pll4ss;
|
||||
u32 pll4lock;
|
||||
u32 rsvd8[128];
|
||||
u32 aud_clk2;
|
||||
u32 sai7_6_clk;
|
||||
u32 tpm8clk;
|
||||
u32 rsvd9[1];
|
||||
u32 spdifclk;
|
||||
u32 rsvd10[59];
|
||||
u32 lvdscfg;
|
||||
};
|
||||
|
||||
u32 cgc1_clk_get_rate(enum cgc1_clk clk);
|
||||
void cgc1_pll3_init(void);
|
||||
void cgc1_pll2_init(void);
|
||||
void cgc1_soscdiv_init(void);
|
||||
void cgc1_init_core_clk(void);
|
||||
void cgc2_pll4_init(void);
|
||||
void cgc2_ddrclk_config(u32 src, u32 div);
|
||||
u32 cgc1_sosc_div(enum cgc1_clk clk);
|
||||
#endif
|
@@ -1,6 +1,6 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||
/*
|
||||
* Copyright 2020 NXP
|
||||
* Copyright 2021 NXP
|
||||
*/
|
||||
|
||||
#ifndef _ASM_ARCH_IMX8ULP_CLOCK_H
|
||||
@@ -17,6 +17,7 @@ enum mxc_clock {
|
||||
MXC_DDR_CLK,
|
||||
MXC_ESDHC_CLK,
|
||||
MXC_ESDHC2_CLK,
|
||||
MXC_ESDHC3_CLK,
|
||||
MXC_I2C_CLK,
|
||||
};
|
||||
|
||||
@@ -26,9 +27,15 @@ u32 get_lpuart_clk(void);
|
||||
int enable_i2c_clk(unsigned char enable, unsigned int i2c_num);
|
||||
u32 imx_get_i2cclk(unsigned int i2c_num);
|
||||
#endif
|
||||
void enable_usboh3_clk(unsigned char enable);
|
||||
int enable_usb_pll(ulong usb_phy_base);
|
||||
#ifdef CONFIG_MXC_OCOTP
|
||||
void enable_ocotp_clk(unsigned char enable);
|
||||
#endif
|
||||
void init_clk_usdhc(u32 index);
|
||||
void init_clk_fspi(int index);
|
||||
void init_clk_ddr(void);
|
||||
int set_ddr_clk(u32 phy_freq_mhz);
|
||||
void clock_init(void);
|
||||
void cgc1_enet_stamp_sel(u32 clk_src);
|
||||
#endif
|
||||
|
@@ -7,6 +7,7 @@
|
||||
#define _IMX8ULP_REGS_H_
|
||||
#define ARCH_MXC
|
||||
|
||||
#include <linux/bitops.h>
|
||||
#include <linux/sizes.h>
|
||||
|
||||
#define PBRIDGE0_BASE 0x28000000
|
||||
|
139
arch/arm/include/asm/arch-imx8ulp/pcc.h
Normal file
139
arch/arm/include/asm/arch-imx8ulp/pcc.h
Normal file
@@ -0,0 +1,139 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||
/*
|
||||
* Copyright 2021 NXP
|
||||
*/
|
||||
|
||||
#ifndef _ASM_ARCH_IMX8ULP_PCC_H
|
||||
#define _ASM_ARCH_IMX8ULP_PCC_H
|
||||
|
||||
#include <asm/arch/cgc.h>
|
||||
|
||||
enum pcc3_entry {
|
||||
DMA1_MP_PCC3_SLOT = 1,
|
||||
DMA1_CH0_PCC3_SLOT = 2,
|
||||
DMA1_CH1_PCC3_SLOT = 3,
|
||||
DMA1_CH2_PCC3_SLOT = 4,
|
||||
DMA1_CH3_PCC3_SLOT = 5,
|
||||
DMA1_CH4_PCC3_SLOT = 6,
|
||||
DMA1_CH5_PCC3_SLOT = 7,
|
||||
DMA1_CH6_PCC3_SLOT = 8,
|
||||
DMA1_CH7_PCC3_SLOT = 9,
|
||||
DMA1_CH8_PCC3_SLOT = 10,
|
||||
DMA1_CH9_PCC3_SLOT = 11,
|
||||
DMA1_CH10_PCC3_SLOT = 12,
|
||||
DMA1_CH11_PCC3_SLOT = 13,
|
||||
DMA1_CH12_PCC3_SLOT = 14,
|
||||
DMA1_CH13_PCC3_SLOT = 15,
|
||||
DMA1_CH14_PCC3_SLOT = 16,
|
||||
DMA1_CH15_PCC3_SLOT = 17,
|
||||
DMA1_CH16_PCC3_SLOT = 18,
|
||||
DMA1_CH17_PCC3_SLOT = 19,
|
||||
DMA1_CH18_PCC3_SLOT = 20,
|
||||
DMA1_CH19_PCC3_SLOT = 21,
|
||||
DMA1_CH20_PCC3_SLOT = 22,
|
||||
DMA1_CH21_PCC3_SLOT = 23,
|
||||
DMA1_CH22_PCC3_SLOT = 24,
|
||||
DMA1_CH23_PCC3_SLOT = 25,
|
||||
DMA1_CH24_PCC3_SLOT = 26,
|
||||
DMA1_CH25_PCC3_SLOT = 27,
|
||||
DMA1_CH26_PCC3_SLOT = 28,
|
||||
DMA1_CH27_PCC3_SLOT = 29,
|
||||
DMA1_CH28_PCC3_SLOT = 30,
|
||||
DMA1_CH29_PCC3_SLOT = 31,
|
||||
DMA1_CH30_PCC3_SLOT = 32,
|
||||
DMA1_CH31_PCC3_SLOT = 33,
|
||||
MU0_B_PCC3_SLOT = 34,
|
||||
MU3_A_PCC3_SLOT = 35,
|
||||
LLWU1_PCC3_SLOT = 38,
|
||||
UPOWER_PCC3_SLOT = 40,
|
||||
WDOG3_PCC3_SLOT = 42,
|
||||
WDOG4_PCC3_SLOT = 43,
|
||||
XRDC_MGR_PCC3_SLOT = 47,
|
||||
SEMA42_1_PCC3_SLOT = 48,
|
||||
ROMCP1_PCC3_SLOT = 49,
|
||||
LPIT1_PCC3_SLOT = 50,
|
||||
TPM4_PCC3_SLOT = 51,
|
||||
TPM5_PCC3_SLOT = 52,
|
||||
FLEXIO1_PCC3_SLOT = 53,
|
||||
I3C2_PCC3_SLOT = 54,
|
||||
LPI2C4_PCC3_SLOT = 55,
|
||||
LPI2C5_PCC3_SLOT = 56,
|
||||
LPUART4_PCC3_SLOT = 57,
|
||||
LPUART5_PCC3_SLOT = 58,
|
||||
LPSPI4_PCC3_SLOT = 59,
|
||||
LPSPI5_PCC3_SLOT = 60,
|
||||
};
|
||||
|
||||
enum pcc4_entry {
|
||||
FLEXSPI2_PCC4_SLOT = 1,
|
||||
TPM6_PCC4_SLOT = 2,
|
||||
TPM7_PCC4_SLOT = 3,
|
||||
LPI2C6_PCC4_SLOT = 4,
|
||||
LPI2C7_PCC4_SLOT = 5,
|
||||
LPUART6_PCC4_SLOT = 6,
|
||||
LPUART7_PCC4_SLOT = 7,
|
||||
SAI4_PCC4_SLOT = 8,
|
||||
SAI5_PCC4_SLOT = 9,
|
||||
PCTLE_PCC4_SLOT = 10,
|
||||
PCTLF_PCC4_SLOT = 11,
|
||||
SDHC0_PCC4_SLOT = 13,
|
||||
SDHC1_PCC4_SLOT = 14,
|
||||
SDHC2_PCC4_SLOT = 15,
|
||||
USB0_PCC4_SLOT = 16,
|
||||
USBPHY_PCC4_SLOT = 17,
|
||||
USB1_PCC4_SLOT = 18,
|
||||
USB1PHY_PCC4_SLOT = 19,
|
||||
USB_XBAR_PCC4_SLOT = 20,
|
||||
ENET_PCC4_SLOT = 21,
|
||||
SFA1_PCC4_SLOT = 22,
|
||||
RGPIOE_PCC4_SLOT = 30,
|
||||
RGPIOF_PCC4_SLOT = 31,
|
||||
};
|
||||
|
||||
/* PCC registers */
|
||||
#define PCC_PR_OFFSET 31
|
||||
#define PCC_PR_MASK (0x1 << PCC_PR_OFFSET)
|
||||
#define PCC_CGC_OFFSET 30
|
||||
#define PCC_CGC_MASK (0x1 << PCC_CGC_OFFSET)
|
||||
#define PCC_INUSE_OFFSET 29
|
||||
#define PCC_INUSE_MASK (0x1 << PCC_INUSE_OFFSET)
|
||||
#define PCC_PCS_OFFSET 24
|
||||
#define PCC_PCS_MASK (0x7 << PCC_PCS_OFFSET)
|
||||
#define PCC_FRAC_OFFSET 3
|
||||
#define PCC_FRAC_MASK (0x1 << PCC_FRAC_OFFSET)
|
||||
#define PCC_PCD_OFFSET 0
|
||||
#define PCC_PCD_MASK (0x7 << PCC_PCD_OFFSET)
|
||||
|
||||
enum pcc_clksrc_type {
|
||||
CLKSRC_PER_PLAT = 0,
|
||||
CLKSRC_PER_BUS = 1,
|
||||
CLKSRC_NO_PCS = 2,
|
||||
};
|
||||
|
||||
enum pcc_div_type {
|
||||
PCC_HAS_DIV,
|
||||
PCC_NO_DIV,
|
||||
};
|
||||
|
||||
enum pcc_rst_b {
|
||||
PCC_HAS_RST_B,
|
||||
PCC_NO_RST_B,
|
||||
};
|
||||
|
||||
/* This structure keeps info for each pcc slot */
|
||||
struct pcc_entry {
|
||||
u32 pcc_base;
|
||||
u32 pcc_slot;
|
||||
enum pcc_clksrc_type clksrc;
|
||||
enum pcc_div_type div;
|
||||
enum pcc_rst_b rst_b;
|
||||
};
|
||||
|
||||
int pcc_clock_enable(int pcc_controller, int pcc_clk_slot, bool enable);
|
||||
int pcc_clock_sel(int pcc_controller, int pcc_clk_slot, enum cgc1_clk src);
|
||||
int pcc_clock_div_config(int pcc_controller, int pcc_clk_slot, bool frac, u8 div);
|
||||
bool pcc_clock_is_enable(int pcc_controller, int pcc_clk_slot);
|
||||
int pcc_clock_get_clksrc(int pcc_controller, int pcc_clk_slot, enum cgc1_clk *src);
|
||||
int pcc_reset_peripheral(int pcc_controller, int pcc_clk_slot, bool reset);
|
||||
u32 pcc_clock_get_rate(int pcc_controller, int pcc_clk_slot);
|
||||
#endif
|
Reference in New Issue
Block a user