Skip to content

Commit 554bc24

Browse files
committed
Merge tag 'clk-meson-v6.12-1' of https://github.com/BayLibre/clk-meson into clk-amlogic
Pull Amlogic clk driver changes from Jerome Brunet: - Constify some Amlogic structs clean-up - Add SM1 eARC clocks for Amlogic - Introduce a symbol namespace for Amlogic clock specific symbols * tag 'clk-meson-v6.12-1' of https://github.com/BayLibre/clk-meson: clk: meson: introduce symbol namespace for amlogic clocks clk: meson: axg-audio: add sm1 earcrx clocks clk: meson: axg-audio: setup regmap max_register based on the SoC dt-bindings: clock: axg-audio: add earcrx clock ids clk: meson: s4: pll: Constify struct regmap_config clk: meson: s4: peripherals: Constify struct regmap_config clk: meson: c3: pll: Constify struct regmap_config clk: meson: c3: peripherals: Constify struct regmap_config clk: meson: a1: pll: Constify struct regmap_config clk: meson: a1: peripherals: Constify struct regmap_config
2 parents 8400291 + adac147 commit 554bc24

27 files changed

+100
-33
lines changed

drivers/clk/meson/a1-peripherals.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2183,7 +2183,7 @@ static struct clk_regmap *const a1_periphs_regmaps[] = {
21832183
&dmc_sel2,
21842184
};
21852185

2186-
static struct regmap_config a1_periphs_regmap_cfg = {
2186+
static const struct regmap_config a1_periphs_regmap_cfg = {
21872187
.reg_bits = 32,
21882188
.val_bits = 32,
21892189
.reg_stride = 4,
@@ -2246,3 +2246,4 @@ MODULE_DESCRIPTION("Amlogic A1 Peripherals Clock Controller driver");
22462246
MODULE_AUTHOR("Jian Hu <[email protected]>");
22472247
MODULE_AUTHOR("Dmitry Rokosov <[email protected]>");
22482248
MODULE_LICENSE("GPL");
2249+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/a1-pll.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -295,7 +295,7 @@ static struct clk_regmap *const a1_pll_regmaps[] = {
295295
&hifi_pll,
296296
};
297297

298-
static struct regmap_config a1_pll_regmap_cfg = {
298+
static const struct regmap_config a1_pll_regmap_cfg = {
299299
.reg_bits = 32,
300300
.val_bits = 32,
301301
.reg_stride = 4,
@@ -360,3 +360,4 @@ MODULE_DESCRIPTION("Amlogic S4 PLL Clock Controller driver");
360360
MODULE_AUTHOR("Jian Hu <[email protected]>");
361361
MODULE_AUTHOR("Dmitry Rokosov <[email protected]>");
362362
MODULE_LICENSE("GPL");
363+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/axg-aoclk.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -342,3 +342,4 @@ module_platform_driver(axg_aoclkc_driver);
342342

343343
MODULE_DESCRIPTION("Amlogic AXG Always-ON Clock Controller driver");
344344
MODULE_LICENSE("GPL");
345+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/axg-audio.c

Lines changed: 37 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -753,6 +753,9 @@ static struct clk_regmap toddr_d =
753753
AUD_PCLK_GATE(toddr_d, AUDIO_CLK_GATE_EN1, 1);
754754
static struct clk_regmap loopback_b =
755755
AUD_PCLK_GATE(loopback_b, AUDIO_CLK_GATE_EN1, 2);
756+
static struct clk_regmap earcrx =
757+
AUD_PCLK_GATE(earcrx, AUDIO_CLK_GATE_EN1, 6);
758+
756759

757760
static struct clk_regmap sm1_mst_a_mclk_sel =
758761
AUD_MST_MCLK_MUX(mst_a_mclk, AUDIO_SM1_MCLK_A_CTRL);
@@ -766,6 +769,10 @@ static struct clk_regmap sm1_mst_e_mclk_sel =
766769
AUD_MST_MCLK_MUX(mst_e_mclk, AUDIO_SM1_MCLK_E_CTRL);
767770
static struct clk_regmap sm1_mst_f_mclk_sel =
768771
AUD_MST_MCLK_MUX(mst_f_mclk, AUDIO_SM1_MCLK_F_CTRL);
772+
static struct clk_regmap sm1_earcrx_cmdc_clk_sel =
773+
AUD_MST_MCLK_MUX(earcrx_cmdc_clk, AUDIO_EARCRX_CMDC_CLK_CTRL);
774+
static struct clk_regmap sm1_earcrx_dmac_clk_sel =
775+
AUD_MST_MCLK_MUX(earcrx_dmac_clk, AUDIO_EARCRX_DMAC_CLK_CTRL);
769776

770777
static struct clk_regmap sm1_mst_a_mclk_div =
771778
AUD_MST_MCLK_DIV(mst_a_mclk, AUDIO_SM1_MCLK_A_CTRL);
@@ -779,6 +786,11 @@ static struct clk_regmap sm1_mst_e_mclk_div =
779786
AUD_MST_MCLK_DIV(mst_e_mclk, AUDIO_SM1_MCLK_E_CTRL);
780787
static struct clk_regmap sm1_mst_f_mclk_div =
781788
AUD_MST_MCLK_DIV(mst_f_mclk, AUDIO_SM1_MCLK_F_CTRL);
789+
static struct clk_regmap sm1_earcrx_cmdc_clk_div =
790+
AUD_MST_MCLK_DIV(earcrx_cmdc_clk, AUDIO_EARCRX_CMDC_CLK_CTRL);
791+
static struct clk_regmap sm1_earcrx_dmac_clk_div =
792+
AUD_MST_MCLK_DIV(earcrx_dmac_clk, AUDIO_EARCRX_DMAC_CLK_CTRL);
793+
782794

783795
static struct clk_regmap sm1_mst_a_mclk =
784796
AUD_MST_MCLK_GATE(mst_a_mclk, AUDIO_SM1_MCLK_A_CTRL);
@@ -792,6 +804,10 @@ static struct clk_regmap sm1_mst_e_mclk =
792804
AUD_MST_MCLK_GATE(mst_e_mclk, AUDIO_SM1_MCLK_E_CTRL);
793805
static struct clk_regmap sm1_mst_f_mclk =
794806
AUD_MST_MCLK_GATE(mst_f_mclk, AUDIO_SM1_MCLK_F_CTRL);
807+
static struct clk_regmap sm1_earcrx_cmdc_clk =
808+
AUD_MST_MCLK_GATE(earcrx_cmdc_clk, AUDIO_EARCRX_CMDC_CLK_CTRL);
809+
static struct clk_regmap sm1_earcrx_dmac_clk =
810+
AUD_MST_MCLK_GATE(earcrx_dmac_clk, AUDIO_EARCRX_DMAC_CLK_CTRL);
795811

796812
static struct clk_regmap sm1_tdm_mclk_pad_0 = AUD_TDM_PAD_CTRL(
797813
tdm_mclk_pad_0, AUDIO_SM1_MST_PAD_CTRL0, 0, mclk_pad_ctrl_parent_data);
@@ -1232,6 +1248,13 @@ static struct clk_hw *sm1_audio_hw_clks[] = {
12321248
[AUD_CLKID_SYSCLK_A_EN] = &sm1_sysclk_a_en.hw,
12331249
[AUD_CLKID_SYSCLK_B_DIV] = &sm1_sysclk_b_div.hw,
12341250
[AUD_CLKID_SYSCLK_B_EN] = &sm1_sysclk_b_en.hw,
1251+
[AUD_CLKID_EARCRX] = &earcrx.hw,
1252+
[AUD_CLKID_EARCRX_CMDC_SEL] = &sm1_earcrx_cmdc_clk_sel.hw,
1253+
[AUD_CLKID_EARCRX_CMDC_DIV] = &sm1_earcrx_cmdc_clk_div.hw,
1254+
[AUD_CLKID_EARCRX_CMDC] = &sm1_earcrx_cmdc_clk.hw,
1255+
[AUD_CLKID_EARCRX_DMAC_SEL] = &sm1_earcrx_dmac_clk_sel.hw,
1256+
[AUD_CLKID_EARCRX_DMAC_DIV] = &sm1_earcrx_dmac_clk_div.hw,
1257+
[AUD_CLKID_EARCRX_DMAC] = &sm1_earcrx_dmac_clk.hw,
12351258
};
12361259

12371260

@@ -1646,6 +1669,13 @@ static struct clk_regmap *const sm1_clk_regmaps[] = {
16461669
&sm1_sysclk_a_en,
16471670
&sm1_sysclk_b_div,
16481671
&sm1_sysclk_b_en,
1672+
&earcrx,
1673+
&sm1_earcrx_cmdc_clk_sel,
1674+
&sm1_earcrx_cmdc_clk_div,
1675+
&sm1_earcrx_cmdc_clk,
1676+
&sm1_earcrx_dmac_clk_sel,
1677+
&sm1_earcrx_dmac_clk_div,
1678+
&sm1_earcrx_dmac_clk,
16491679
};
16501680

16511681
struct axg_audio_reset_data {
@@ -1726,11 +1756,10 @@ static const struct reset_control_ops axg_audio_rstc_ops = {
17261756
.status = axg_audio_reset_status,
17271757
};
17281758

1729-
static const struct regmap_config axg_audio_regmap_cfg = {
1759+
static struct regmap_config axg_audio_regmap_cfg = {
17301760
.reg_bits = 32,
17311761
.val_bits = 32,
17321762
.reg_stride = 4,
1733-
.max_register = AUDIO_CLK_SPDIFOUT_B_CTRL,
17341763
};
17351764

17361765
struct audioclk_data {
@@ -1739,6 +1768,7 @@ struct audioclk_data {
17391768
struct meson_clk_hw_data hw_clks;
17401769
unsigned int reset_offset;
17411770
unsigned int reset_num;
1771+
unsigned int max_register;
17421772
};
17431773

17441774
static int axg_audio_clkc_probe(struct platform_device *pdev)
@@ -1760,6 +1790,7 @@ static int axg_audio_clkc_probe(struct platform_device *pdev)
17601790
if (IS_ERR(regs))
17611791
return PTR_ERR(regs);
17621792

1793+
axg_audio_regmap_cfg.max_register = data->max_register;
17631794
map = devm_regmap_init_mmio(dev, regs, &axg_audio_regmap_cfg);
17641795
if (IS_ERR(map)) {
17651796
dev_err(dev, "failed to init regmap: %ld\n", PTR_ERR(map));
@@ -1828,6 +1859,7 @@ static const struct audioclk_data axg_audioclk_data = {
18281859
.hws = axg_audio_hw_clks,
18291860
.num = ARRAY_SIZE(axg_audio_hw_clks),
18301861
},
1862+
.max_register = AUDIO_CLK_PDMIN_CTRL1,
18311863
};
18321864

18331865
static const struct audioclk_data g12a_audioclk_data = {
@@ -1839,6 +1871,7 @@ static const struct audioclk_data g12a_audioclk_data = {
18391871
},
18401872
.reset_offset = AUDIO_SW_RESET,
18411873
.reset_num = 26,
1874+
.max_register = AUDIO_CLK_SPDIFOUT_B_CTRL,
18421875
};
18431876

18441877
static const struct audioclk_data sm1_audioclk_data = {
@@ -1850,6 +1883,7 @@ static const struct audioclk_data sm1_audioclk_data = {
18501883
},
18511884
.reset_offset = AUDIO_SM1_SW_RESET0,
18521885
.reset_num = 39,
1886+
.max_register = AUDIO_EARCRX_DMAC_CLK_CTRL,
18531887
};
18541888

18551889
static const struct of_device_id clkc_match_table[] = {
@@ -1878,3 +1912,4 @@ module_platform_driver(axg_audio_driver);
18781912
MODULE_DESCRIPTION("Amlogic AXG/G12A/SM1 Audio Clock driver");
18791913
MODULE_AUTHOR("Jerome Brunet <[email protected]>");
18801914
MODULE_LICENSE("GPL");
1915+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/axg-audio.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -64,5 +64,7 @@
6464
#define AUDIO_SM1_SW_RESET1 0x02C
6565
#define AUDIO_CLK81_CTRL 0x030
6666
#define AUDIO_CLK81_EN 0x034
67+
#define AUDIO_EARCRX_CMDC_CLK_CTRL 0x0D0
68+
#define AUDIO_EARCRX_DMAC_CLK_CTRL 0x0D4
6769

6870
#endif /*__AXG_AUDIO_CLKC_H */

drivers/clk/meson/axg.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2187,3 +2187,4 @@ module_platform_driver(axg_driver);
21872187

21882188
MODULE_DESCRIPTION("Amlogic AXG Main Clock Controller driver");
21892189
MODULE_LICENSE("GPL");
2190+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/c3-peripherals.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2296,7 +2296,7 @@ static struct clk_regmap *const c3_periphs_clk_regmaps[] = {
22962296
&vapb,
22972297
};
22982298

2299-
static struct regmap_config clkc_regmap_config = {
2299+
static const struct regmap_config clkc_regmap_config = {
23002300
.reg_bits = 32,
23012301
.val_bits = 32,
23022302
.reg_stride = 4,
@@ -2364,3 +2364,4 @@ module_platform_driver(c3_peripherals_driver);
23642364
MODULE_DESCRIPTION("Amlogic C3 Peripherals Clock Controller driver");
23652365
MODULE_AUTHOR("Chuan Liu <[email protected]>");
23662366
MODULE_LICENSE("GPL");
2367+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/c3-pll.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -678,7 +678,7 @@ static struct clk_regmap *const c3_pll_clk_regmaps[] = {
678678
&mclk1,
679679
};
680680

681-
static struct regmap_config clkc_regmap_config = {
681+
static const struct regmap_config clkc_regmap_config = {
682682
.reg_bits = 32,
683683
.val_bits = 32,
684684
.reg_stride = 4,
@@ -745,3 +745,4 @@ module_platform_driver(c3_pll_driver);
745745
MODULE_DESCRIPTION("Amlogic C3 PLL Clock Controller driver");
746746
MODULE_AUTHOR("Chuan Liu <[email protected]>");
747747
MODULE_LICENSE("GPL");
748+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/clk-cpu-dyndiv.c

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -65,8 +65,9 @@ const struct clk_ops meson_clk_cpu_dyndiv_ops = {
6565
.determine_rate = meson_clk_cpu_dyndiv_determine_rate,
6666
.set_rate = meson_clk_cpu_dyndiv_set_rate,
6767
};
68-
EXPORT_SYMBOL_GPL(meson_clk_cpu_dyndiv_ops);
68+
EXPORT_SYMBOL_NS_GPL(meson_clk_cpu_dyndiv_ops, CLK_MESON);
6969

7070
MODULE_DESCRIPTION("Amlogic CPU Dynamic Clock divider");
7171
MODULE_AUTHOR("Neil Armstrong <[email protected]>");
7272
MODULE_LICENSE("GPL");
73+
MODULE_IMPORT_NS(CLK_MESON);

drivers/clk/meson/clk-dualdiv.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -130,14 +130,15 @@ const struct clk_ops meson_clk_dualdiv_ops = {
130130
.determine_rate = meson_clk_dualdiv_determine_rate,
131131
.set_rate = meson_clk_dualdiv_set_rate,
132132
};
133-
EXPORT_SYMBOL_GPL(meson_clk_dualdiv_ops);
133+
EXPORT_SYMBOL_NS_GPL(meson_clk_dualdiv_ops, CLK_MESON);
134134

135135
const struct clk_ops meson_clk_dualdiv_ro_ops = {
136136
.recalc_rate = meson_clk_dualdiv_recalc_rate,
137137
};
138-
EXPORT_SYMBOL_GPL(meson_clk_dualdiv_ro_ops);
138+
EXPORT_SYMBOL_NS_GPL(meson_clk_dualdiv_ro_ops, CLK_MESON);
139139

140140
MODULE_DESCRIPTION("Amlogic dual divider driver");
141141
MODULE_AUTHOR("Neil Armstrong <[email protected]>");
142142
MODULE_AUTHOR("Jerome Brunet <[email protected]>");
143143
MODULE_LICENSE("GPL");
144+
MODULE_IMPORT_NS(CLK_MESON);

0 commit comments

Comments
 (0)