[PATCH v15 6/6] clk: meson: a1: add Amlogic A1 Peripherals clock controller driver

Martin Blumenstingl martin.blumenstingl at googlemail.com
Fri May 19 14:03:54 PDT 2023


Hi Dmitry,

On Wed, May 17, 2023 at 3:33 PM Dmitry Rokosov <ddrokosov at sberdevices.ru> wrote:
[...]
> +static struct clk_regmap sys_b_sel = {
> +       .data = &(struct clk_regmap_mux_data){
> +               .offset = SYS_CLK_CTRL0,
> +               .mask = 0x7,
> +               .shift = 26,
> +               .table = mux_table_sys,
> +       },
> +       .hw.init = &(struct clk_init_data){
> +               .name = "sys_b_sel",
> +               .ops = &clk_regmap_mux_ro_ops,
the sys_*_sel muxes and sys_*_gate are _ro...

> +               .parent_data = sys_parents,
> +               .num_parents = ARRAY_SIZE(sys_parents),
> +       },
> +};
> +
> +static struct clk_regmap sys_b_div = {
> +       .data = &(struct clk_regmap_div_data){
> +               .offset = SYS_CLK_CTRL0,
> +               .shift = 16,
> +               .width = 10,
> +       },
> +       .hw.init = &(struct clk_init_data){
> +               .name = "sys_b_div",
> +               .ops = &clk_regmap_divider_ops,
...but the sys_*_div aren't
Is this on purpose? If it is: why can the divider be changed at
runtime but the mux can't?

[...]
> +/*
> + * the index 2 is sys_pll_div16, it will be implemented in the CPU clock driver,
We need to add the "sys_pll_div16" input to the dt-bindings since they
should always describe the hardware (regardless of what the driver
implements currently).
I'm not sure how to manage this while we don't have the CPU clock
driver ready yet but I'm sure Rob or Krzysztof will be able to help us
here.

> + * the index 4 is the clock measurement source, it's not supported yet
I suspect that this comes from the clock measurer IP block and if so
the dt-bindings should probably describe this input. But again, we'd
need to keep it optional for now since our clock measurer driver
doesn't even implement a clock controller.

[...]
> +static struct clk_regmap pwm_a_sel = {
> +       .data = &(struct clk_regmap_mux_data){
> +               .offset = PWM_CLK_AB_CTRL,
> +               .mask = 0x1,
> +               .shift = 9,
> +       },
> +       .hw.init = &(struct clk_init_data){
> +               .name = "pwm_a_sel",
> +               .ops = &clk_regmap_mux_ops,
> +               .parent_data = pwm_abcd_parents,
> +               .num_parents = ARRAY_SIZE(pwm_abcd_parents),
> +               /* For more information, please refer to rtc clock */
> +               .flags = CLK_SET_RATE_NO_REPARENT,
As mentioned in [0] we'll work with Heiner to see if we can improve
the decision making process of the PWM controller driver so that we
can just have .flags = 0 here.
This applies to all other occurrences of the same comment about the rtc clock.


Best regards,
Martin



More information about the linux-arm-kernel mailing list