summaryrefslogtreecommitdiff
path: root/drivers/clk/microchip/mpfs_clk_periph.c
diff options
context:
space:
mode:
authorConor Dooley <conor.dooley@microchip.com>2022-10-25 08:58:47 +0100
committerLeo Yu-Chi Liang <ycliang@andestech.com>2022-11-15 15:37:17 +0800
commit88b697fb37432b95bd87525e718726607bdb2123 (patch)
treeb406040e16430ac1a14adc107b4f518847328d28 /drivers/clk/microchip/mpfs_clk_periph.c
parent32cfdd51630506393ca078aa36fa70248d549109 (diff)
clk: microchip: mpfs: fix periph clk parentage
Not all "periph" clocks are children of the AHB clock, some have the AXI clock as their parent & the mtimer clock is derived from the external reference clock directly. Stop assuming the AHB clock to be the parent of all "periph" clocks and define their correct parents instead. Fixes: 2f27c9219e ("clk: Add Microchip PolarFire SoC clock driver") Signed-off-by: Conor Dooley <conor.dooley@microchip.com> Reviewed-by: Leo Yu-Chi Liang <ycliang@andestech.com> Reviewed-by: Padmarao Begari <padmarao.begari@microchip.com> Tested-by: Padmarao Begari <padmarao.begari@microchip.com>
Diffstat (limited to 'drivers/clk/microchip/mpfs_clk_periph.c')
-rw-r--r--drivers/clk/microchip/mpfs_clk_periph.c72
1 files changed, 39 insertions, 33 deletions
diff --git a/drivers/clk/microchip/mpfs_clk_periph.c b/drivers/clk/microchip/mpfs_clk_periph.c
index 1488ef503ed..e23eb552c36 100644
--- a/drivers/clk/microchip/mpfs_clk_periph.c
+++ b/drivers/clk/microchip/mpfs_clk_periph.c
@@ -29,12 +29,14 @@
/**
* struct mpfs_periph_clock - per instance of peripheral clock
* @id: index of a peripheral clock
+ * @parent_id: index of the parent clock
* @name: name of a peripheral clock
* @shift: shift to a peripheral clock bit field
* @flags: common clock framework flags
*/
struct mpfs_periph_clock {
unsigned int id;
+ unsigned int parent_id;
const char *name;
u8 shift;
unsigned long flags;
@@ -104,46 +106,47 @@ static ulong mpfs_periph_clk_recalc_rate(struct clk *hw)
}
-#define CLK_PERIPH(_id, _name, _shift, _flags) { \
+#define CLK_PERIPH(_id, _name, _parent_id, _shift, _flags) { \
.periph.id = _id, \
+ .periph.parent_id = _parent_id, \
.periph.name = _name, \
.periph.shift = _shift, \
.periph.flags = _flags, \
}
static struct mpfs_periph_hw_clock mpfs_periph_clks[] = {
- CLK_PERIPH(CLK_ENVM, "clk_periph_envm", 0, CLK_IS_CRITICAL),
- CLK_PERIPH(CLK_MAC0, "clk_periph_mac0", 1, 0),
- CLK_PERIPH(CLK_MAC1, "clk_periph_mac1", 2, 0),
- CLK_PERIPH(CLK_MMC, "clk_periph_mmc", 3, 0),
- CLK_PERIPH(CLK_TIMER, "clk_periph_timer", 4, 0),
- CLK_PERIPH(CLK_MMUART0, "clk_periph_mmuart0", 5, 0),
- CLK_PERIPH(CLK_MMUART1, "clk_periph_mmuart1", 6, 0),
- CLK_PERIPH(CLK_MMUART2, "clk_periph_mmuart2", 7, 0),
- CLK_PERIPH(CLK_MMUART3, "clk_periph_mmuart3", 8, 0),
- CLK_PERIPH(CLK_MMUART4, "clk_periph_mmuart4", 9, 0),
- CLK_PERIPH(CLK_SPI0, "clk_periph_spi0", 10, 0),
- CLK_PERIPH(CLK_SPI1, "clk_periph_spi1", 11, 0),
- CLK_PERIPH(CLK_I2C0, "clk_periph_i2c0", 12, 0),
- CLK_PERIPH(CLK_I2C1, "clk_periph_i2c1", 13, 0),
- CLK_PERIPH(CLK_CAN0, "clk_periph_can0", 14, 0),
- CLK_PERIPH(CLK_CAN1, "clk_periph_can1", 15, 0),
- CLK_PERIPH(CLK_USB, "clk_periph_usb", 16, 0),
- CLK_PERIPH(CLK_RTC, "clk_periph_rtc", 18, 0),
- CLK_PERIPH(CLK_QSPI, "clk_periph_qspi", 19, 0),
- CLK_PERIPH(CLK_GPIO0, "clk_periph_gpio0", 20, 0),
- CLK_PERIPH(CLK_GPIO1, "clk_periph_gpio1", 21, 0),
- CLK_PERIPH(CLK_GPIO2, "clk_periph_gpio2", 22, 0),
- CLK_PERIPH(CLK_DDRC, "clk_periph_ddrc", 23, CLK_IS_CRITICAL),
- CLK_PERIPH(CLK_FIC0, "clk_periph_fic0", 24, 0),
- CLK_PERIPH(CLK_FIC1, "clk_periph_fic1", 25, 0),
- CLK_PERIPH(CLK_FIC2, "clk_periph_fic2", 26, 0),
- CLK_PERIPH(CLK_FIC3, "clk_periph_fic3", 27, 0),
- CLK_PERIPH(CLK_ATHENA, "clk_periph_athena", 28, 0),
- CLK_PERIPH(CLK_CFM, "clk_periph_cfm", 29, 0),
+ CLK_PERIPH(CLK_ENVM, "clk_periph_envm", CLK_AHB, 0, CLK_IS_CRITICAL),
+ CLK_PERIPH(CLK_MAC0, "clk_periph_mac0", CLK_AHB, 1, 0),
+ CLK_PERIPH(CLK_MAC1, "clk_periph_mac1", CLK_AHB, 2, 0),
+ CLK_PERIPH(CLK_MMC, "clk_periph_mmc", CLK_AHB, 3, 0),
+ CLK_PERIPH(CLK_TIMER, "clk_periph_timer", CLK_RTCREF, 4, 0),
+ CLK_PERIPH(CLK_MMUART0, "clk_periph_mmuart0", CLK_AHB, 5, 0),
+ CLK_PERIPH(CLK_MMUART1, "clk_periph_mmuart1", CLK_AHB, 6, 0),
+ CLK_PERIPH(CLK_MMUART2, "clk_periph_mmuart2", CLK_AHB, 7, 0),
+ CLK_PERIPH(CLK_MMUART3, "clk_periph_mmuart3", CLK_AHB, 8, 0),
+ CLK_PERIPH(CLK_MMUART4, "clk_periph_mmuart4", CLK_AHB, 9, 0),
+ CLK_PERIPH(CLK_SPI0, "clk_periph_spi0", CLK_AHB, 10, 0),
+ CLK_PERIPH(CLK_SPI1, "clk_periph_spi1", CLK_AHB, 11, 0),
+ CLK_PERIPH(CLK_I2C0, "clk_periph_i2c0", CLK_AHB, 12, 0),
+ CLK_PERIPH(CLK_I2C1, "clk_periph_i2c1", CLK_AHB, 13, 0),
+ CLK_PERIPH(CLK_CAN0, "clk_periph_can0", CLK_AHB, 14, 0),
+ CLK_PERIPH(CLK_CAN1, "clk_periph_can1", CLK_AHB, 15, 0),
+ CLK_PERIPH(CLK_USB, "clk_periph_usb", CLK_AHB, 16, 0),
+ CLK_PERIPH(CLK_RTC, "clk_periph_rtc", CLK_AHB, 18, 0),
+ CLK_PERIPH(CLK_QSPI, "clk_periph_qspi", CLK_AHB, 19, 0),
+ CLK_PERIPH(CLK_GPIO0, "clk_periph_gpio0", CLK_AHB, 20, 0),
+ CLK_PERIPH(CLK_GPIO1, "clk_periph_gpio1", CLK_AHB, 21, 0),
+ CLK_PERIPH(CLK_GPIO2, "clk_periph_gpio2", CLK_AHB, 22, 0),
+ CLK_PERIPH(CLK_DDRC, "clk_periph_ddrc", CLK_AHB, 23, CLK_IS_CRITICAL),
+ CLK_PERIPH(CLK_FIC0, "clk_periph_fic0", CLK_AXI, 24, 0),
+ CLK_PERIPH(CLK_FIC1, "clk_periph_fic1", CLK_AXI, 25, 0),
+ CLK_PERIPH(CLK_FIC2, "clk_periph_fic2", CLK_AXI, 26, 0),
+ CLK_PERIPH(CLK_FIC3, "clk_periph_fic3", CLK_AXI, 27, 0),
+ CLK_PERIPH(CLK_ATHENA, "clk_periph_athena", CLK_AXI, 28, 0),
+ CLK_PERIPH(CLK_CFM, "clk_periph_cfm", CLK_AHB, 29, 0),
};
-int mpfs_clk_register_periphs(void __iomem *base, struct clk *parent)
+int mpfs_clk_register_periphs(void __iomem *base, struct udevice *dev)
{
int ret;
int i, id, num_clks;
@@ -152,11 +155,14 @@ int mpfs_clk_register_periphs(void __iomem *base, struct clk *parent)
num_clks = ARRAY_SIZE(mpfs_periph_clks);
for (i = 0; i < num_clks; i++) {
+ struct clk parent = { .id = mpfs_periph_clks[i].periph.parent_id };
+
+ clk_request(dev, &parent);
hw = &mpfs_periph_clks[i].hw;
mpfs_periph_clks[i].sys_base = base;
- mpfs_periph_clks[i].prate = clk_get_rate(parent);
+ mpfs_periph_clks[i].prate = clk_get_rate(&parent);
name = mpfs_periph_clks[i].periph.name;
- ret = clk_register(hw, MPFS_PERIPH_CLOCK, name, parent->dev->name);
+ ret = clk_register(hw, MPFS_PERIPH_CLOCK, name, parent.dev->name);
if (ret)
ERR_PTR(ret);
id = mpfs_periph_clks[i].periph.id;