Message ID | 1522161443-54428-7-git-send-email-biju.das@bp.renesas.com (mailing list archive) |
---|---|
State | Changes Requested, archived |
Headers | show |
Hi Biju, On Tue, Mar 27, 2018 at 4:37 PM, Biju Das <biju.das@bp.renesas.com> wrote: > Add RZ/G1C (R8A77470) Clock Pulse Generator / Module Standby and Software > Reset support. > > Signed-off-by: Biju Das <biju.das@bp.renesas.com> > Reviewed-by: Fabrizio Castro <fabrizio.castro@bp.renesas.com> Thanks for your patch! > --- /dev/null > +++ b/drivers/clk/renesas/r8a7747x-cpg-mssr.c For consistency, I'd call this r8a77470-cpg-mssr.c. > @@ -0,0 +1,229 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * r8a7747 Clock Pulse Generator / Module Standby and Software Reset r8a77470 > +static const struct cpg_core_clk r8a77470_core_clks[] __initconst = { > + /* External Clock Inputs */ > + DEF_INPUT("extal", CLK_EXTAL), > + DEF_INPUT("usb_extal", CLK_USB_EXTAL), > + > + /* Internal Core Clocks */ > + DEF_BASE(".main", CLK_MAIN, CLK_TYPE_GEN2_MAIN, CLK_EXTAL), > + DEF_BASE(".pll0", CLK_PLL0, CLK_TYPE_GEN2_PLL0, CLK_MAIN), > + DEF_BASE(".pll1", CLK_PLL1, CLK_TYPE_GEN2_PLL1, CLK_MAIN), > + DEF_BASE(".pll3", CLK_PLL3, CLK_TYPE_GEN2_PLL3, CLK_MAIN), > + > + DEF_FIXED(".pll1_div2", CLK_PLL1_DIV2, CLK_PLL1, 2, 1), > + > + /* Core Clock Outputs */ > + DEF_BASE("lb", R8A77470_CLK_LB, CLK_TYPE_GEN2_LB, CLK_PLL1), DEF_FIXED("lb", R8A77470_CLK_LB, CLK_PLL1, 24, 1) and move it down between "b" and "p". Note: apparently the dependency on MD18 is true for R-Car H2 only, so I will fix this in the other clock drivers. > +/* > + * CPG Clock Data > + */ > + > +/* > + * MD EXTAL PLL0 PLL1 PLL3 > + * 14 13 (MHz) *1 *2 > + *--------------------------------------------------- > + * 0 0 20 x80/2 x78 x50 > + * 0 1 26 x60/2 x60 x56 > + * 1 0 Prohibitted setting > + * 1 1 30 x52/2 x52 x50 It looks like all PLL0/PLL1/PLL3 values are already the predivided values, unlike in other clock drivers? ... > + * > + * *1 : Table 7.4 indicates VCO output (PLL0 = VCO/2) > + * *2 : Table 7.4 indicates VCO output (PLL1 = VCO) > + */ > +#define CPG_PLL_CONFIG_INDEX(md) ((((md) & BIT(14)) >> 13) | \ > + (((md) & BIT(13)) >> 13)) > + > +static const struct rcar_gen2_cpg_pll_config cpg_pll_configs[8] __initconst = { cpg_pll_configs[4] > + /* EXTAL div PLL1 mult PLL3 mult */ > + { 1, 78, 50, }, > + { 1, 60, 56, }, > + { /* Invalid*/ }, > + { 1, 52, 50, }, ... so I think these should be multiplied by the predivider, which will allow to drop the corresponding test for RZ/G1C in rcar_gen2_cpg_clk_register. > +}; > + > +static int __init r8a7747x_cpg_mssr_init(struct device *dev) r8a77470_cpg_mssr_init > --- a/drivers/clk/renesas/rcar-gen2-cpg.c > +++ b/drivers/clk/renesas/rcar-gen2-cpg.c > @@ -16,6 +16,7 @@ > #include <linux/init.h> > #include <linux/io.h> > #include <linux/slab.h> > +#include <linux/sys_soc.h> > > #include "renesas-cpg-mssr.h" > #include "rcar-gen2-cpg.h" > @@ -257,10 +258,21 @@ static const struct clk_div_table cpg_sd01_div_table[] = { > { 0, 0 }, > }; > > +static const struct clk_div_table rz_g1c_cpg_sd01_div_table[] = { > + { 5, 12 }, { 6, 16 }, { 7, 18 }, { 8, 24 }, > + { 10, 36 }, { 11, 48 }, { 12, 10 }, { 0, 0 }, > +}; This table is identical to cpg_sd01_div_table[], except for the missing first entry. So perhaps you could just use &cpg_sd01_div_table[1] instead? > + > + > static const struct rcar_gen2_cpg_pll_config *cpg_pll_config __initdata; > static unsigned int cpg_pll0_div __initdata; > static u32 cpg_mode __initdata; > > +static const struct soc_device_attribute r8a7747xes[] = { > + { .soc_id = "r8a77470", .revision = "ES2.*" }, So this does not apply to ES3.0 and later? What about ES1.*? > + { /* sentinel */ } > +}; > @@ -303,7 +315,10 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, > break; > > case CLK_TYPE_GEN2_PLL1: > - mult = cpg_pll_config->pll1_mult / 2; > + if (soc_device_match(r8a7747xes)) > + mult = cpg_pll_config->pll1_mult; > + else > + mult = cpg_pll_config->pll1_mult / 2; If think this can be dropped if the values in cpg_pll_configs[] are multiplied by 2. > @@ -314,7 +329,10 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, > return cpg_z_clk_register(core->name, parent_name, base); > > case CLK_TYPE_GEN2_LB: > - div = cpg_mode & BIT(18) ? 36 : 24; > + if (soc_device_match(r8a7747xes)) > + div = 24; > + else > + div = cpg_mode & BIT(18) ? 36 : 24; Can be dropped if LB is modeled as a fixed clock instead. > break; > > case CLK_TYPE_GEN2_ADSP: > @@ -326,12 +344,20 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, > break; > > case CLK_TYPE_GEN2_SD0: > - table = cpg_sd01_div_table; > + if (soc_device_match(r8a7747xes)) > + table = rz_g1c_cpg_sd01_div_table; > + else > + table = cpg_sd01_div_table; table = cpg_sd01_div_table; if (soc_device_match(r8a7747xes)) table++; > + > shift = 4; > break; > > case CLK_TYPE_GEN2_SD1: > - table = cpg_sd01_div_table; > + if (soc_device_match(r8a7747xes)) > + table = rz_g1c_cpg_sd01_div_table; > + else > + table = cpg_sd01_div_table; Likewise. > + > shift = 0; > break; Gr{oetje,eeting}s, Geert
SGkgR2VlcnQsDQoNClRoYW5rcyBmb3IgdGhlIHJldmlldy4NCg0KPiBIaSBCaWp1LA0KPg0KPiBP biBUdWUsIE1hciAyNywgMjAxOCBhdCA0OjM3IFBNLCBCaWp1IERhcyA8YmlqdS5kYXNAYnAucmVu ZXNhcy5jb20+IHdyb3RlOg0KPiA+IEFkZCBSWi9HMUMgKFI4QTc3NDcwKSBDbG9jayBQdWxzZSBH ZW5lcmF0b3IgLyBNb2R1bGUgU3RhbmRieSBhbmQNCj4gPiBTb2Z0d2FyZSBSZXNldCBzdXBwb3J0 Lg0KPiA+DQo+ID4gU2lnbmVkLW9mZi1ieTogQmlqdSBEYXMgPGJpanUuZGFzQGJwLnJlbmVzYXMu Y29tPg0KPiA+IFJldmlld2VkLWJ5OiBGYWJyaXppbyBDYXN0cm8gPGZhYnJpemlvLmNhc3Ryb0Bi cC5yZW5lc2FzLmNvbT4NCj4NCj4gVGhhbmtzIGZvciB5b3VyIHBhdGNoIQ0KPg0KPiA+IC0tLSAv ZGV2L251bGwNCj4gPiArKysgYi9kcml2ZXJzL2Nsay9yZW5lc2FzL3I4YTc3NDd4LWNwZy1tc3Ny LmMNCj4NCj4gRm9yIGNvbnNpc3RlbmN5LCBJJ2QgY2FsbCB0aGlzIHI4YTc3NDcwLWNwZy1tc3Ny LmMuDQo+DQo+ID4gQEAgLTAsMCArMSwyMjkgQEANCj4gPiArLy8gU1BEWC1MaWNlbnNlLUlkZW50 aWZpZXI6IEdQTC0yLjANCj4gPiArLyoNCj4gPiArICogcjhhNzc0NyBDbG9jayBQdWxzZSBHZW5l cmF0b3IgLyBNb2R1bGUgU3RhbmRieSBhbmQgU29mdHdhcmUgUmVzZXQNCj4NCj4gcjhhNzc0NzAN Cg0KV2lsbCBkbw0KPiA+ICtzdGF0aWMgY29uc3Qgc3RydWN0IGNwZ19jb3JlX2NsayByOGE3NzQ3 MF9jb3JlX2Nsa3NbXSBfX2luaXRjb25zdCA9IHsNCj4gPiArICAgICAgIC8qIEV4dGVybmFsIENs b2NrIElucHV0cyAqLw0KPiA+ICsgICAgICAgREVGX0lOUFVUKCJleHRhbCIsICAgICAgQ0xLX0VY VEFMKSwNCj4gPiArICAgICAgIERFRl9JTlBVVCgidXNiX2V4dGFsIiwgIENMS19VU0JfRVhUQUwp LA0KPiA+ICsNCj4gPiArICAgICAgIC8qIEludGVybmFsIENvcmUgQ2xvY2tzICovDQo+ID4gKyAg ICAgICBERUZfQkFTRSgiLm1haW4iLCAgICAgICBDTEtfTUFJTiwgQ0xLX1RZUEVfR0VOMl9NQUlO LCBDTEtfRVhUQUwpLA0KPiA+ICsgICAgICAgREVGX0JBU0UoIi5wbGwwIiwgICAgICAgQ0xLX1BM TDAsIENMS19UWVBFX0dFTjJfUExMMCwgQ0xLX01BSU4pLA0KPiA+ICsgICAgICAgREVGX0JBU0Uo Ii5wbGwxIiwgICAgICAgQ0xLX1BMTDEsIENMS19UWVBFX0dFTjJfUExMMSwgQ0xLX01BSU4pLA0K PiA+ICsgICAgICAgREVGX0JBU0UoIi5wbGwzIiwgICAgICAgQ0xLX1BMTDMsIENMS19UWVBFX0dF TjJfUExMMywgQ0xLX01BSU4pLA0KPiA+ICsNCj4gPiArICAgICAgIERFRl9GSVhFRCgiLnBsbDFf ZGl2MiIsIENMS19QTEwxX0RJVjIsIENMS19QTEwxLCAyLCAxKSwNCj4gPiArDQo+ID4gKyAgICAg ICAvKiBDb3JlIENsb2NrIE91dHB1dHMgKi8NCj4gPiArICAgICAgIERFRl9CQVNFKCJsYiIsICAg UjhBNzc0NzBfQ0xLX0xCLCAgIENMS19UWVBFX0dFTjJfTEIsICAgQ0xLX1BMTDEpLA0KPg0KPiBE RUZfRklYRUQoImxiIiwgUjhBNzc0NzBfQ0xLX0xCLCBDTEtfUExMMSwgMjQsIDEpIGFuZCBtb3Zl IGl0IGRvd24NCj4gYmV0d2VlbiAiYiIgYW5kICJwIi4NCg0KV2lsbCBkby4NCg0KPiBOb3RlOiBh cHBhcmVudGx5IHRoZSBkZXBlbmRlbmN5IG9uIE1EMTggaXMgdHJ1ZSBmb3IgUi1DYXIgSDIgb25s eSwgc28gSSB3aWxsIGZpeA0KPiB0aGlzIGluIHRoZSBvdGhlciBjbG9jayBkcml2ZXJzLg0KPg0K PiA+ICsvKg0KPiA+ICsgKiBDUEcgQ2xvY2sgRGF0YQ0KPiA+ICsgKi8NCj4gPiArDQo+ID4gKy8q DQo+ID4gKyAqICAgIE1EICAgICAgIEVYVEFMICAgICAgICAgICBQTEwwICAgIFBMTDEgICAgUExM Mw0KPiA+ICsgKiAxNCAxMyAgICAgICAoTUh6KSAgICAgICAgICAgKjEgICAgICAqMg0KPiA+ICsg Ki0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQ0KPiA+ ICsgKiAwICAwICAgICAgICAgICAgICAgIDIwICAgICAgICAgICAgICB4ODAvMiAgIHg3OCAgICAg eDUwDQo+ID4gKyAqIDAgIDEgICAgICAgICAgICAgICAgMjYgICAgICAgICAgICAgIHg2MC8yICAg eDYwICAgICB4NTYNCj4gPiArICogMSAgMCAgICAgICAgICAgICAgICBQcm9oaWJpdHRlZCBzZXR0 aW5nDQo+ID4gKyAqIDEgIDEgICAgICAgICAgICAgICAgMzAgICAgICAgICAgICAgIHg1Mi8yICAg eDUyICAgICB4NTANCj4NCj4gSXQgbG9va3MgbGlrZSBhbGwgUExMMC9QTEwxL1BMTDMgdmFsdWVz IGFyZSBhbHJlYWR5IHRoZSBwcmVkaXZpZGVkIHZhbHVlcywgdW5saWtlDQo+IGluIG90aGVyIGNs b2NrIGRyaXZlcnM/IC4uLg0KDQpZZXMsIHlvdSBhcmUgY29ycmVjdC4gd2lsbCBjb3JyZWN0IHRo aXMgdGFibGUuDQoNCj4gPiArICoNCj4gPiArICogKjEgOiAgICAgICAgVGFibGUgNy40IGluZGlj YXRlcyBWQ08gb3V0cHV0IChQTEwwID0gVkNPLzIpDQo+ID4gKyAqICoyIDogICAgICAgIFRhYmxl IDcuNCBpbmRpY2F0ZXMgVkNPIG91dHB1dCAoUExMMSA9IFZDTykNCj4gPiArICovDQo+ID4gKyNk ZWZpbmUgQ1BHX1BMTF9DT05GSUdfSU5ERVgobWQpICAgICAgICgoKChtZCkgJiBCSVQoMTQpKSA+ PiAxMykgfCBcDQo+ID4gKyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAo KChtZCkgJiBCSVQoMTMpKSA+PiAxMykpDQo+ID4gKw0KPiA+ICtzdGF0aWMgY29uc3Qgc3RydWN0 IHJjYXJfZ2VuMl9jcGdfcGxsX2NvbmZpZyBjcGdfcGxsX2NvbmZpZ3NbOF0NCj4gPiArX19pbml0 Y29uc3QgPSB7DQo+DQo+IGNwZ19wbGxfY29uZmlnc1s0XQ0KPg0KPiA+ICsgICAgICAgLyogRVhU QUwgZGl2ICAgIFBMTDEgbXVsdCAgICAgICBQTEwzIG11bHQgKi8NCj4gPiArICAgICAgIHsgMSwg ICAgICAgICAgICA3OCwgICAgICAgICAgICAgNTAsICAgICB9LA0KPiA+ICsgICAgICAgeyAxLCAg ICAgICAgICAgIDYwLCAgICAgICAgICAgICA1NiwgICAgIH0sDQo+ID4gKyAgICAgICB7IC8qIElu dmFsaWQqLyAgICAgICAgICAgICAgICAgICAgICAgICAgfSwNCj4gPiArICAgICAgIHsgMSwgICAg ICAgICAgICA1MiwgICAgICAgICAgICAgNTAsICAgICB9LA0KPg0KPiAuLi4gc28gSSB0aGluayB0 aGVzZSBzaG91bGQgYmUgbXVsdGlwbGllZCBieSB0aGUgcHJlZGl2aWRlciwgd2hpY2ggd2lsbCBh bGxvdyB0bw0KPiBkcm9wIHRoZSBjb3JyZXNwb25kaW5nIHRlc3QgZm9yIFJaL0cxQyBpbiByY2Fy X2dlbjJfY3BnX2Nsa19yZWdpc3Rlci4NCg0KV2lsbCBjb3JyZWN0IHRoaXMuDQoNCj4gPiArfTsN Cj4gPiArDQo+ID4gK3N0YXRpYyBpbnQgX19pbml0IHI4YTc3NDd4X2NwZ19tc3NyX2luaXQoc3Ry dWN0IGRldmljZSAqZGV2KQ0KPg0KPiByOGE3NzQ3MF9jcGdfbXNzcl9pbml0DQoNCldpbGwgY29y cmVjdCB0aGlzDQoNCj4gPiAtLS0gYS9kcml2ZXJzL2Nsay9yZW5lc2FzL3JjYXItZ2VuMi1jcGcu Yw0KPiA+ICsrKyBiL2RyaXZlcnMvY2xrL3JlbmVzYXMvcmNhci1nZW4yLWNwZy5jDQo+ID4gQEAg LTE2LDYgKzE2LDcgQEANCj4gPiAgI2luY2x1ZGUgPGxpbnV4L2luaXQuaD4NCj4gPiAgI2luY2x1 ZGUgPGxpbnV4L2lvLmg+DQo+ID4gICNpbmNsdWRlIDxsaW51eC9zbGFiLmg+DQo+ID4gKyNpbmNs dWRlIDxsaW51eC9zeXNfc29jLmg+DQo+ID4NCj4gPiAgI2luY2x1ZGUgInJlbmVzYXMtY3BnLW1z c3IuaCINCj4gPiAgI2luY2x1ZGUgInJjYXItZ2VuMi1jcGcuaCINCj4gPiBAQCAtMjU3LDEwICsy NTgsMjEgQEAgc3RhdGljIGNvbnN0IHN0cnVjdCBjbGtfZGl2X3RhYmxlDQo+IGNwZ19zZDAxX2Rp dl90YWJsZVtdID0gew0KPiA+ICAgICAgICAgeyAgMCwgIDAgfSwNCj4gPiAgfTsNCj4gPg0KPiA+ ICtzdGF0aWMgY29uc3Qgc3RydWN0IGNsa19kaXZfdGFibGUgcnpfZzFjX2NwZ19zZDAxX2Rpdl90 YWJsZVtdID0gew0KPiA+ICsgICAgICAgeyAgNSwgMTIgfSwgeyAgNiwgMTYgfSwgeyAgNywgMTgg fSwgeyAgOCwgMjQgfSwNCj4gPiArICAgICAgIHsgMTAsIDM2IH0sIHsgMTEsIDQ4IH0sIHsgMTIs IDEwIH0sIHsgIDAsICAwIH0sIH07DQo+DQo+IFRoaXMgdGFibGUgaXMgaWRlbnRpY2FsIHRvIGNw Z19zZDAxX2Rpdl90YWJsZVtdLCBleGNlcHQgZm9yIHRoZSBtaXNzaW5nIGZpcnN0IGVudHJ5Lg0K PiBTbyBwZXJoYXBzIHlvdSBjb3VsZCBqdXN0IHVzZSAmY3BnX3NkMDFfZGl2X3RhYmxlWzFdIGlu c3RlYWQ/DQoNCldpbGwgdGFrZSBvdXQgdGhpcyB0YWJsZS4NCg0KPiA+ICsNCj4gPiArDQo+ID4g IHN0YXRpYyBjb25zdCBzdHJ1Y3QgcmNhcl9nZW4yX2NwZ19wbGxfY29uZmlnICpjcGdfcGxsX2Nv bmZpZw0KPiA+IF9faW5pdGRhdGE7ICBzdGF0aWMgdW5zaWduZWQgaW50IGNwZ19wbGwwX2RpdiBf X2luaXRkYXRhOyAgc3RhdGljIHUzMg0KPiA+IGNwZ19tb2RlIF9faW5pdGRhdGE7DQo+ID4NCj4g PiArc3RhdGljIGNvbnN0IHN0cnVjdCBzb2NfZGV2aWNlX2F0dHJpYnV0ZSByOGE3NzQ3eGVzW10g PSB7DQo+ID4gKyAgICAgICB7IC5zb2NfaWQgPSAicjhhNzc0NzAiLCAucmV2aXNpb24gPSAiRVMy LioiIH0sDQo+DQo+IFNvIHRoaXMgZG9lcyBub3QgYXBwbHkgdG8gRVMzLjAgYW5kIGxhdGVyPw0K PiBXaGF0IGFib3V0IEVTMS4qPw0KDQpXaWxsIHRha2Ugb3V0IHRoZSByZXZpc2lvbiBmaWVsZC4g Q3VycmVudGx5IHdlIGdvdCBvbmx5IEVTMi4wIHZlcnNpb24sDQpBcyBwZXIgbXkga25vd2xlZGdl LCB0aGVyZSBpcyBubyBFUzEuMCB2ZXJzaW9uLkl0IGlzIGJhc2ljYWxseSBkZXJpdmVkIGZyb20g Ui1DYXIgRTJYLg0KDQo+ID4gKyAgICAgICB7IC8qIHNlbnRpbmVsICovIH0NCj4gPiArfTsNCj4N Cj4gPiBAQCAtMzAzLDcgKzMxNSwxMCBAQCBzdHJ1Y3QgY2xrICogX19pbml0DQo+IHJjYXJfZ2Vu Ml9jcGdfY2xrX3JlZ2lzdGVyKHN0cnVjdCBkZXZpY2UgKmRldiwNCj4gPiAgICAgICAgICAgICAg ICAgYnJlYWs7DQo+ID4NCj4gPiAgICAgICAgIGNhc2UgQ0xLX1RZUEVfR0VOMl9QTEwxOg0KPiA+ IC0gICAgICAgICAgICAgICBtdWx0ID0gY3BnX3BsbF9jb25maWctPnBsbDFfbXVsdCAvIDI7DQo+ ID4gKyAgICAgICAgICAgICAgIGlmIChzb2NfZGV2aWNlX21hdGNoKHI4YTc3NDd4ZXMpKQ0KPiA+ ICsgICAgICAgICAgICAgICAgICAgICAgIG11bHQgPSBjcGdfcGxsX2NvbmZpZy0+cGxsMV9tdWx0 Ow0KPiA+ICsgICAgICAgICAgICAgICBlbHNlDQo+ID4gKyAgICAgICAgICAgICAgICAgICAgICAg bXVsdCA9IGNwZ19wbGxfY29uZmlnLT5wbGwxX211bHQgLyAyOw0KPg0KPiBJZiB0aGluayB0aGlz IGNhbiBiZSBkcm9wcGVkIGlmIHRoZSB2YWx1ZXMgaW4gY3BnX3BsbF9jb25maWdzW10gYXJlIG11 bHRpcGxpZWQgYnkgMi4NCg0KV2lsbCBkbw0KDQo+ID4gQEAgLTMxNCw3ICszMjksMTAgQEAgc3Ry dWN0IGNsayAqIF9faW5pdA0KPiByY2FyX2dlbjJfY3BnX2Nsa19yZWdpc3RlcihzdHJ1Y3QgZGV2 aWNlICpkZXYsDQo+ID4gICAgICAgICAgICAgICAgIHJldHVybiBjcGdfel9jbGtfcmVnaXN0ZXIo Y29yZS0+bmFtZSwgcGFyZW50X25hbWUsDQo+ID4gYmFzZSk7DQo+ID4NCj4gPiAgICAgICAgIGNh c2UgQ0xLX1RZUEVfR0VOMl9MQjoNCj4gPiAtICAgICAgICAgICAgICAgZGl2ID0gY3BnX21vZGUg JiBCSVQoMTgpID8gMzYgOiAyNDsNCj4gPiArICAgICAgICAgICAgICAgaWYgKHNvY19kZXZpY2Vf bWF0Y2gocjhhNzc0N3hlcykpDQo+ID4gKyAgICAgICAgICAgICAgICAgICAgICAgZGl2ID0gMjQ7 DQo+ID4gKyAgICAgICAgICAgICAgIGVsc2UNCj4gPiArICAgICAgICAgICAgICAgICAgICAgICBk aXYgPSBjcGdfbW9kZSAmIEJJVCgxOCkgPyAzNiA6IDI0Ow0KPg0KPiBDYW4gYmUgZHJvcHBlZCBp ZiBMQiBpcyBtb2RlbGVkIGFzIGEgZml4ZWQgY2xvY2sgaW5zdGVhZC4NCg0KV2lsbCBkby4NCj4g PiAgICAgICAgICAgICAgICAgYnJlYWs7DQo+ID4NCj4gPiAgICAgICAgIGNhc2UgQ0xLX1RZUEVf R0VOMl9BRFNQOg0KPiA+IEBAIC0zMjYsMTIgKzM0NCwyMCBAQCBzdHJ1Y3QgY2xrICogX19pbml0 DQo+IHJjYXJfZ2VuMl9jcGdfY2xrX3JlZ2lzdGVyKHN0cnVjdCBkZXZpY2UgKmRldiwNCj4gPiAg ICAgICAgICAgICAgICAgYnJlYWs7DQo+ID4NCj4gPiAgICAgICAgIGNhc2UgQ0xLX1RZUEVfR0VO Ml9TRDA6DQo+ID4gLSAgICAgICAgICAgICAgIHRhYmxlID0gY3BnX3NkMDFfZGl2X3RhYmxlOw0K PiA+ICsgICAgICAgICAgICAgICBpZiAoc29jX2RldmljZV9tYXRjaChyOGE3NzQ3eGVzKSkNCj4g PiArICAgICAgICAgICAgICAgICAgICAgICB0YWJsZSA9IHJ6X2cxY19jcGdfc2QwMV9kaXZfdGFi bGU7DQo+ID4gKyAgICAgICAgICAgICAgIGVsc2UNCj4gPiArICAgICAgICAgICAgICAgICAgICAg ICB0YWJsZSA9IGNwZ19zZDAxX2Rpdl90YWJsZTsNCj4NCj4gdGFibGUgPSBjcGdfc2QwMV9kaXZf dGFibGU7DQo+IGlmIChzb2NfZGV2aWNlX21hdGNoKHI4YTc3NDd4ZXMpKQ0KPiAgICAgICAgIHRh YmxlKys7DQpXaWxsIGRvDQo+ID4gKw0KPiA+ICAgICAgICAgICAgICAgICBzaGlmdCA9IDQ7DQo+ ID4gICAgICAgICAgICAgICAgIGJyZWFrOw0KPiA+DQo+ID4gICAgICAgICBjYXNlIENMS19UWVBF X0dFTjJfU0QxOg0KPiA+IC0gICAgICAgICAgICAgICB0YWJsZSA9IGNwZ19zZDAxX2Rpdl90YWJs ZTsNCj4gPiArICAgICAgICAgICAgICAgaWYgKHNvY19kZXZpY2VfbWF0Y2gocjhhNzc0N3hlcykp DQo+ID4gKyAgICAgICAgICAgICAgICAgICAgICAgdGFibGUgPSByel9nMWNfY3BnX3NkMDFfZGl2 X3RhYmxlOw0KPiA+ICsgICAgICAgICAgICAgICBlbHNlDQo+ID4gKyAgICAgICAgICAgICAgICAg ICAgICAgdGFibGUgPSBjcGdfc2QwMV9kaXZfdGFibGU7DQo+DQo+IExpa2V3aXNlLg0KPg0KPiA+ ICsNCj4gPiAgICAgICAgICAgICAgICAgc2hpZnQgPSAwOw0KPiA+ICAgICAgICAgICAgICAgICBi cmVhazsNCj4NCj4gR3J7b2V0amUsZWV0aW5nfXMsDQo+DQo+ICAgICAgICAgICAgICAgICAgICAg ICAgIEdlZXJ0DQo+DQo+IC0tDQo+IEdlZXJ0IFV5dHRlcmhvZXZlbiAtLSBUaGVyZSdzIGxvdHMg b2YgTGludXggYmV5b25kIGlhMzIgLS0gZ2VlcnRAbGludXgtDQo+IG02OGsub3JnDQo+DQo+IElu IHBlcnNvbmFsIGNvbnZlcnNhdGlvbnMgd2l0aCB0ZWNobmljYWwgcGVvcGxlLCBJIGNhbGwgbXlz ZWxmIGEgaGFja2VyLiBCdXQgd2hlbg0KPiBJJ20gdGFsa2luZyB0byBqb3VybmFsaXN0cyBJIGp1 c3Qgc2F5ICJwcm9ncmFtbWVyIiBvciBzb21ldGhpbmcgbGlrZSB0aGF0Lg0KPiAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgIC0tIExpbnVzIFRvcnZhbGRzDQoNCg0KDQpSZW5lc2FzIEVs ZWN0cm9uaWNzIEV1cm9wZSBMdGQsIER1a2VzIE1lYWRvdywgTWlsbGJvYXJkIFJvYWQsIEJvdXJu ZSBFbmQsIEJ1Y2tpbmdoYW1zaGlyZSwgU0w4IDVGSCwgVUsuIFJlZ2lzdGVyZWQgaW4gRW5nbGFu ZCAmIFdhbGVzIHVuZGVyIFJlZ2lzdGVyZWQgTm8uIDA0NTg2NzA5Lg0K -- To unsubscribe from this list: send the line "unsubscribe linux-clk" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/Documentation/devicetree/bindings/clock/renesas,cpg-mssr.txt b/Documentation/devicetree/bindings/clock/renesas,cpg-mssr.txt index 773a522..c3473df 100644 --- a/Documentation/devicetree/bindings/clock/renesas,cpg-mssr.txt +++ b/Documentation/devicetree/bindings/clock/renesas,cpg-mssr.txt @@ -15,6 +15,7 @@ Required Properties: - compatible: Must be one of: - "renesas,r8a7743-cpg-mssr" for the r8a7743 SoC (RZ/G1M) - "renesas,r8a7745-cpg-mssr" for the r8a7745 SoC (RZ/G1E) + - "renesas,r8a77470-cpg-mssr" for the r8a77470 SoC (RZ/G1C) - "renesas,r8a7790-cpg-mssr" for the r8a7790 SoC (R-Car H2) - "renesas,r8a7791-cpg-mssr" for the r8a7791 SoC (R-Car M2-W) - "renesas,r8a7792-cpg-mssr" for the r8a7792 SoC (R-Car V2H) @@ -33,10 +34,12 @@ Required Properties: - clocks: References to external parent clocks, one entry for each entry in clock-names - clock-names: List of external parent clock names. Valid names are: - - "extal" (r8a7743, r8a7745, r8a7790, r8a7791, r8a7792, r8a7793, r8a7794, - r8a7795, r8a7796, r8a77965, r8a77970, r8a77980, r8a77995) + - "extal" (r8a7743, r8a7745, r8a77470, r8a7790, r8a7791, r8a7792, + r8a7793, r8a7794, r8a7795, r8a7796, r8a77965, r8a77970, + r8a77980, r8a77995) - "extalr" (r8a7795, r8a7796, r8a77965, r8a77970, r8a77980) - - "usb_extal" (r8a7743, r8a7745, r8a7790, r8a7791, r8a7793, r8a7794) + - "usb_extal" (r8a7743, r8a7745, r8a77470, r8a7790, r8a7791, r8a7793, + r8a7794) - #clock-cells: Must be 2 - For CPG core clocks, the two clock specifier cells must be "CPG_CORE" diff --git a/drivers/clk/renesas/Kconfig b/drivers/clk/renesas/Kconfig index ef76c86..f32896fa 100644 --- a/drivers/clk/renesas/Kconfig +++ b/drivers/clk/renesas/Kconfig @@ -7,6 +7,7 @@ config CLK_RENESAS select CLK_R8A7740 if ARCH_R8A7740 select CLK_R8A7743 if ARCH_R8A7743 select CLK_R8A7745 if ARCH_R8A7745 + select CLK_R8A77470 if ARCH_R8A77470 select CLK_R8A7778 if ARCH_R8A7778 select CLK_R8A7779 if ARCH_R8A7779 select CLK_R8A7790 if ARCH_R8A7790 @@ -60,6 +61,10 @@ config CLK_R8A7745 bool "RZ/G1E clock support" if COMPILE_TEST select CLK_RCAR_GEN2_CPG +config CLK_R8A77470 + bool "RZ/G1C clock support" if COMPILE_TEST + select CLK_RCAR_GEN2_CPG + config CLK_R8A7778 bool "R-Car M1A clock support" if COMPILE_TEST select CLK_RENESAS_CPG_MSTP diff --git a/drivers/clk/renesas/Makefile b/drivers/clk/renesas/Makefile index 6c0f196..59c65d0 100644 --- a/drivers/clk/renesas/Makefile +++ b/drivers/clk/renesas/Makefile @@ -6,6 +6,7 @@ obj-$(CONFIG_CLK_R8A73A4) += clk-r8a73a4.o obj-$(CONFIG_CLK_R8A7740) += clk-r8a7740.o obj-$(CONFIG_CLK_R8A7743) += r8a7743-cpg-mssr.o obj-$(CONFIG_CLK_R8A7745) += r8a7745-cpg-mssr.o +obj-$(CONFIG_CLK_R8A77470) += r8a7747x-cpg-mssr.o obj-$(CONFIG_CLK_R8A7778) += clk-r8a7778.o obj-$(CONFIG_CLK_R8A7779) += clk-r8a7779.o obj-$(CONFIG_CLK_R8A7790) += r8a7790-cpg-mssr.o diff --git a/drivers/clk/renesas/r8a7747x-cpg-mssr.c b/drivers/clk/renesas/r8a7747x-cpg-mssr.c new file mode 100644 index 0000000..b6ff95f --- /dev/null +++ b/drivers/clk/renesas/r8a7747x-cpg-mssr.c @@ -0,0 +1,229 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * r8a7747 Clock Pulse Generator / Module Standby and Software Reset + * + * Copyright (C) 2018 Renesas Electronics Corp. + */ + +#include <linux/device.h> +#include <linux/init.h> +#include <linux/kernel.h> +#include <linux/soc/renesas/rcar-rst.h> + +#include <dt-bindings/clock/r8a7747x-cpg-mssr.h> + +#include "renesas-cpg-mssr.h" +#include "rcar-gen2-cpg.h" + +enum clk_ids { + /* Core Clock Outputs exported to DT */ + LAST_DT_CORE_CLK = R8A77470_CLK_OSC, + + /* External Input Clocks */ + CLK_EXTAL, + CLK_USB_EXTAL, + + /* Internal Core Clocks */ + CLK_MAIN, + CLK_PLL0, + CLK_PLL1, + CLK_PLL3, + CLK_PLL1_DIV2, + + /* Module Clocks */ + MOD_CLK_BASE +}; + +static const struct cpg_core_clk r8a77470_core_clks[] __initconst = { + /* External Clock Inputs */ + DEF_INPUT("extal", CLK_EXTAL), + DEF_INPUT("usb_extal", CLK_USB_EXTAL), + + /* Internal Core Clocks */ + DEF_BASE(".main", CLK_MAIN, CLK_TYPE_GEN2_MAIN, CLK_EXTAL), + DEF_BASE(".pll0", CLK_PLL0, CLK_TYPE_GEN2_PLL0, CLK_MAIN), + DEF_BASE(".pll1", CLK_PLL1, CLK_TYPE_GEN2_PLL1, CLK_MAIN), + DEF_BASE(".pll3", CLK_PLL3, CLK_TYPE_GEN2_PLL3, CLK_MAIN), + + DEF_FIXED(".pll1_div2", CLK_PLL1_DIV2, CLK_PLL1, 2, 1), + + /* Core Clock Outputs */ + DEF_BASE("lb", R8A77470_CLK_LB, CLK_TYPE_GEN2_LB, CLK_PLL1), + DEF_BASE("sdh", R8A77470_CLK_SDH, CLK_TYPE_GEN2_SDH, CLK_PLL1), + DEF_BASE("sd0", R8A77470_CLK_SD0, CLK_TYPE_GEN2_SD0, CLK_PLL1), + DEF_BASE("sd1", R8A77470_CLK_SD1, CLK_TYPE_GEN2_SD1, CLK_PLL1), + DEF_BASE("qspi", R8A77470_CLK_QSPI, CLK_TYPE_GEN2_QSPI, CLK_PLL1_DIV2), + DEF_BASE("rcan", R8A77470_CLK_RCAN, CLK_TYPE_GEN2_RCAN, CLK_USB_EXTAL), + + DEF_FIXED("z2", R8A77470_CLK_Z2, CLK_PLL0, 1, 1), + DEF_FIXED("zx", R8A77470_CLK_ZX, CLK_PLL1, 3, 1), + DEF_FIXED("zs", R8A77470_CLK_ZS, CLK_PLL1, 6, 1), + DEF_FIXED("hp", R8A77470_CLK_HP, CLK_PLL1, 12, 1), + DEF_FIXED("b", R8A77470_CLK_B, CLK_PLL1, 12, 1), + DEF_FIXED("p", R8A77470_CLK_P, CLK_PLL1, 24, 1), + DEF_FIXED("cl", R8A77470_CLK_CL, CLK_PLL1, 48, 1), + DEF_FIXED("cp", R8A77470_CLK_CP, CLK_PLL1, 48, 1), + DEF_FIXED("m2", R8A77470_CLK_M2, CLK_PLL1, 8, 1), + DEF_FIXED("zb3", R8A77470_CLK_ZB3, CLK_PLL3, 4, 1), + DEF_FIXED("mp", R8A77470_CLK_MP, CLK_PLL1_DIV2, 15, 1), + DEF_FIXED("cpex", R8A77470_CLK_CPEX, CLK_EXTAL, 2, 1), + DEF_FIXED("r", R8A77470_CLK_R, CLK_PLL1, 49152, 1), + DEF_FIXED("osc", R8A77470_CLK_OSC, CLK_PLL1, 12288, 1), + + DEF_DIV6P1("sd2", R8A77470_CLK_SD2, CLK_PLL1_DIV2, 0x078), +}; + +static const struct mssr_mod_clk r8a77470_mod_clks[] __initconst = { + DEF_MOD("msiof0", 0, R8A77470_CLK_MP), + DEF_MOD("vcp0", 101, R8A77470_CLK_ZS), + DEF_MOD("vpc0", 103, R8A77470_CLK_ZS), + DEF_MOD("tmu1", 111, R8A77470_CLK_P), + DEF_MOD("3dg", 112, R8A77470_CLK_ZS), + DEF_MOD("2d-dmac", 115, R8A77470_CLK_ZS), + DEF_MOD("fdp1-0", 119, R8A77470_CLK_ZS), + DEF_MOD("tmu3", 121, R8A77470_CLK_P), + DEF_MOD("tmu2", 122, R8A77470_CLK_P), + DEF_MOD("cmt0", 124, R8A77470_CLK_R), + DEF_MOD("vsp1du0", 128, R8A77470_CLK_ZS), + DEF_MOD("vsp1-sy", 131, R8A77470_CLK_ZS), + DEF_MOD("msiof2", 205, R8A77470_CLK_MP), + DEF_MOD("msiof1", 208, R8A77470_CLK_MP), + DEF_MOD("sys-dmac1", 218, R8A77470_CLK_ZS), + DEF_MOD("sys-dmac0", 219, R8A77470_CLK_ZS), + DEF_MOD("sdhi2", 312, R8A77470_CLK_SD2), + DEF_MOD("sdhi1", 313, R8A77470_CLK_SD1), + DEF_MOD("sdhi0", 314, R8A77470_CLK_SD0), + DEF_MOD("usbhs-dmac0-ch1", 326, R8A77470_CLK_HP), + DEF_MOD("usbhs-dmac1-ch1", 327, R8A77470_CLK_HP), + DEF_MOD("cmt1", 329, R8A77470_CLK_R), + DEF_MOD("usbhs-dmac0-ch0", 330, R8A77470_CLK_HP), + DEF_MOD("usbhs-dmac1-ch0", 331, R8A77470_CLK_HP), + DEF_MOD("rwdt", 402, R8A77470_CLK_R), + DEF_MOD("irqc", 407, R8A77470_CLK_CP), + DEF_MOD("intc-sys", 408, R8A77470_CLK_ZS), + DEF_MOD("audio-dmac0", 502, R8A77470_CLK_HP), + DEF_MOD("pwm", 523, R8A77470_CLK_P), + DEF_MOD("usb-ehci-0", 703, R8A77470_CLK_MP), + DEF_MOD("usbhs-0", 704, R8A77470_CLK_HP), + DEF_MOD("usb-ehci-1", 705, R8A77470_CLK_MP), + DEF_MOD("usbhs-1", 706, R8A77470_CLK_HP), + DEF_MOD("hscif2", 713, R8A77470_CLK_ZS), + DEF_MOD("scif5", 714, R8A77470_CLK_P), + DEF_MOD("scif4", 715, R8A77470_CLK_P), + DEF_MOD("hscif1", 716, R8A77470_CLK_ZS), + DEF_MOD("hscif0", 717, R8A77470_CLK_ZS), + DEF_MOD("scif3", 718, R8A77470_CLK_P), + DEF_MOD("scif2", 719, R8A77470_CLK_P), + DEF_MOD("scif1", 720, R8A77470_CLK_P), + DEF_MOD("scif0", 721, R8A77470_CLK_P), + DEF_MOD("du1", 723, R8A77470_CLK_ZX), + DEF_MOD("du0", 724, R8A77470_CLK_ZX), + DEF_MOD("ipmmu-sgx", 800, R8A77470_CLK_ZX), + DEF_MOD("etheravb", 812, R8A77470_CLK_HP), + DEF_MOD("ether", 813, R8A77470_CLK_P), + DEF_MOD("gpio5", 907, R8A77470_CLK_CP), + DEF_MOD("gpio4", 908, R8A77470_CLK_CP), + DEF_MOD("gpio3", 909, R8A77470_CLK_CP), + DEF_MOD("gpio2", 910, R8A77470_CLK_CP), + DEF_MOD("gpio1", 911, R8A77470_CLK_CP), + DEF_MOD("gpio0", 912, R8A77470_CLK_CP), + DEF_MOD("can1", 915, R8A77470_CLK_P), + DEF_MOD("can0", 916, R8A77470_CLK_P), + DEF_MOD("qspi_mod-1", 917, R8A77470_CLK_QSPI), + DEF_MOD("qspi_mod-0", 918, R8A77470_CLK_QSPI), + DEF_MOD("i2c4", 927, R8A77470_CLK_HP), + DEF_MOD("i2c3", 928, R8A77470_CLK_HP), + DEF_MOD("i2c2", 929, R8A77470_CLK_HP), + DEF_MOD("i2c1", 930, R8A77470_CLK_HP), + DEF_MOD("i2c0", 931, R8A77470_CLK_HP), + DEF_MOD("ssi-all", 1005, R8A77470_CLK_P), + DEF_MOD("ssi9", 1006, MOD_CLK_ID(1005)), + DEF_MOD("ssi8", 1007, MOD_CLK_ID(1005)), + DEF_MOD("ssi7", 1008, MOD_CLK_ID(1005)), + DEF_MOD("ssi6", 1009, MOD_CLK_ID(1005)), + DEF_MOD("ssi5", 1010, MOD_CLK_ID(1005)), + DEF_MOD("ssi4", 1011, MOD_CLK_ID(1005)), + DEF_MOD("ssi3", 1012, MOD_CLK_ID(1005)), + DEF_MOD("ssi2", 1013, MOD_CLK_ID(1005)), + DEF_MOD("ssi1", 1014, MOD_CLK_ID(1005)), + DEF_MOD("ssi0", 1015, MOD_CLK_ID(1005)), + DEF_MOD("scu-all", 1017, R8A77470_CLK_P), + DEF_MOD("scu-dvc1", 1018, MOD_CLK_ID(1017)), + DEF_MOD("scu-dvc0", 1019, MOD_CLK_ID(1017)), + DEF_MOD("scu-ctu1-mix1", 1020, MOD_CLK_ID(1017)), + DEF_MOD("scu-ctu0-mix0", 1021, MOD_CLK_ID(1017)), + DEF_MOD("scu-src6", 1025, MOD_CLK_ID(1017)), + DEF_MOD("scu-src5", 1026, MOD_CLK_ID(1017)), + DEF_MOD("scu-src4", 1027, MOD_CLK_ID(1017)), + DEF_MOD("scu-src3", 1028, MOD_CLK_ID(1017)), + DEF_MOD("scu-src2", 1029, MOD_CLK_ID(1017)), + DEF_MOD("scu-src1", 1030, MOD_CLK_ID(1017)), +}; + +static const unsigned int r8a77470_crit_mod_clks[] __initconst = { + MOD_CLK_ID(402), /* RWDT */ + MOD_CLK_ID(408), /* INTC-SYS (GIC) */ +}; + +/* + * CPG Clock Data + */ + +/* + * MD EXTAL PLL0 PLL1 PLL3 + * 14 13 (MHz) *1 *2 + *--------------------------------------------------- + * 0 0 20 x80/2 x78 x50 + * 0 1 26 x60/2 x60 x56 + * 1 0 Prohibitted setting + * 1 1 30 x52/2 x52 x50 + * + * *1 : Table 7.4 indicates VCO output (PLL0 = VCO/2) + * *2 : Table 7.4 indicates VCO output (PLL1 = VCO) + */ +#define CPG_PLL_CONFIG_INDEX(md) ((((md) & BIT(14)) >> 13) | \ + (((md) & BIT(13)) >> 13)) + +static const struct rcar_gen2_cpg_pll_config cpg_pll_configs[8] __initconst = { + /* EXTAL div PLL1 mult PLL3 mult */ + { 1, 78, 50, }, + { 1, 60, 56, }, + { /* Invalid*/ }, + { 1, 52, 50, }, +}; + +static int __init r8a7747x_cpg_mssr_init(struct device *dev) +{ + const struct rcar_gen2_cpg_pll_config *cpg_pll_config; + u32 cpg_mode; + int error; + + error = rcar_rst_read_mode_pins(&cpg_mode); + if (error) + return error; + + cpg_pll_config = &cpg_pll_configs[CPG_PLL_CONFIG_INDEX(cpg_mode)]; + + return rcar_gen2_cpg_init(cpg_pll_config, 2, cpg_mode); +} + +const struct cpg_mssr_info r8a77470_cpg_mssr_info __initconst = { + /* Core Clocks */ + .core_clks = r8a77470_core_clks, + .num_core_clks = ARRAY_SIZE(r8a77470_core_clks), + .last_dt_core_clk = LAST_DT_CORE_CLK, + .num_total_core_clks = MOD_CLK_BASE, + + /* Module Clocks */ + .mod_clks = r8a77470_mod_clks, + .num_mod_clks = ARRAY_SIZE(r8a77470_mod_clks), + .num_hw_mod_clks = 12 * 32, + + /* Critical Module Clocks */ + .crit_mod_clks = r8a77470_crit_mod_clks, + .num_crit_mod_clks = ARRAY_SIZE(r8a77470_crit_mod_clks), + + /* Callbacks */ + .init = r8a7747x_cpg_mssr_init, + .cpg_clk_register = rcar_gen2_cpg_clk_register, +}; diff --git a/drivers/clk/renesas/rcar-gen2-cpg.c b/drivers/clk/renesas/rcar-gen2-cpg.c index feb1457..dcc2447 100644 --- a/drivers/clk/renesas/rcar-gen2-cpg.c +++ b/drivers/clk/renesas/rcar-gen2-cpg.c @@ -16,6 +16,7 @@ #include <linux/init.h> #include <linux/io.h> #include <linux/slab.h> +#include <linux/sys_soc.h> #include "renesas-cpg-mssr.h" #include "rcar-gen2-cpg.h" @@ -257,10 +258,21 @@ static const struct clk_div_table cpg_sd01_div_table[] = { { 0, 0 }, }; +static const struct clk_div_table rz_g1c_cpg_sd01_div_table[] = { + { 5, 12 }, { 6, 16 }, { 7, 18 }, { 8, 24 }, + { 10, 36 }, { 11, 48 }, { 12, 10 }, { 0, 0 }, +}; + + static const struct rcar_gen2_cpg_pll_config *cpg_pll_config __initdata; static unsigned int cpg_pll0_div __initdata; static u32 cpg_mode __initdata; +static const struct soc_device_attribute r8a7747xes[] = { + { .soc_id = "r8a77470", .revision = "ES2.*" }, + { /* sentinel */ } +}; + struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, const struct cpg_core_clk *core, const struct cpg_mssr_info *info, struct clk **clks, void __iomem *base, @@ -303,7 +315,10 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, break; case CLK_TYPE_GEN2_PLL1: - mult = cpg_pll_config->pll1_mult / 2; + if (soc_device_match(r8a7747xes)) + mult = cpg_pll_config->pll1_mult; + else + mult = cpg_pll_config->pll1_mult / 2; break; case CLK_TYPE_GEN2_PLL3: @@ -314,7 +329,10 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, return cpg_z_clk_register(core->name, parent_name, base); case CLK_TYPE_GEN2_LB: - div = cpg_mode & BIT(18) ? 36 : 24; + if (soc_device_match(r8a7747xes)) + div = 24; + else + div = cpg_mode & BIT(18) ? 36 : 24; break; case CLK_TYPE_GEN2_ADSP: @@ -326,12 +344,20 @@ struct clk * __init rcar_gen2_cpg_clk_register(struct device *dev, break; case CLK_TYPE_GEN2_SD0: - table = cpg_sd01_div_table; + if (soc_device_match(r8a7747xes)) + table = rz_g1c_cpg_sd01_div_table; + else + table = cpg_sd01_div_table; + shift = 4; break; case CLK_TYPE_GEN2_SD1: - table = cpg_sd01_div_table; + if (soc_device_match(r8a7747xes)) + table = rz_g1c_cpg_sd01_div_table; + else + table = cpg_sd01_div_table; + shift = 0; break; diff --git a/drivers/clk/renesas/renesas-cpg-mssr.c b/drivers/clk/renesas/renesas-cpg-mssr.c index 4e88e98..2c467f9 100644 --- a/drivers/clk/renesas/renesas-cpg-mssr.c +++ b/drivers/clk/renesas/renesas-cpg-mssr.c @@ -652,6 +652,12 @@ static const struct of_device_id cpg_mssr_match[] = { .data = &r8a7745_cpg_mssr_info, }, #endif +#ifdef CONFIG_CLK_R8A77470 + { + .compatible = "renesas,r8a77470-cpg-mssr", + .data = &r8a77470_cpg_mssr_info, + }, +#endif #ifdef CONFIG_CLK_R8A7790 { .compatible = "renesas,r8a7790-cpg-mssr", diff --git a/drivers/clk/renesas/renesas-cpg-mssr.h b/drivers/clk/renesas/renesas-cpg-mssr.h index 97ccb09..efe2a14 100644 --- a/drivers/clk/renesas/renesas-cpg-mssr.h +++ b/drivers/clk/renesas/renesas-cpg-mssr.h @@ -133,6 +133,7 @@ struct cpg_mssr_info { extern const struct cpg_mssr_info r8a7743_cpg_mssr_info; extern const struct cpg_mssr_info r8a7745_cpg_mssr_info; +extern const struct cpg_mssr_info r8a77470_cpg_mssr_info; extern const struct cpg_mssr_info r8a7790_cpg_mssr_info; extern const struct cpg_mssr_info r8a7791_cpg_mssr_info; extern const struct cpg_mssr_info r8a7792_cpg_mssr_info;