修訂 | ea3e163f21b65420f0a8e17af519006e69904b43 (tree) |
---|---|
時間 | 2022-07-25 22:38:47 |
作者 | Matt Ranostay <mranostay@ti.c...> |
Commiter | Tom Rini |
phy: ti: j721e-wiz: use OF data for device specific data
Move device specific data into OF data structure so it
is easier to maintain and we can get rid of if statements.
Based on: https://lore.kernel.org/linux-phy/20220526064121.27625-1-rogerq@kernel.org/T/#u
Cc: Roger Quadros <rogerq@kernel.org>
Signed-off-by: Matt Ranostay <mranostay@ti.com>
@@ -221,6 +221,44 @@ enum wiz_type { | ||
221 | 221 | AM64_WIZ_10G, |
222 | 222 | }; |
223 | 223 | |
224 | +struct wiz_data { | |
225 | + enum wiz_type type; | |
226 | + const struct reg_field *pll0_refclk_mux_sel; | |
227 | + const struct reg_field *pll1_refclk_mux_sel; | |
228 | + const struct reg_field *refclk_dig_sel; | |
229 | + const struct reg_field *pma_cmn_refclk1_dig_div; | |
230 | + const struct wiz_clk_mux_sel *clk_mux_sel; | |
231 | + unsigned int clk_div_sel_num; | |
232 | +}; | |
233 | + | |
234 | +static const struct wiz_data j721e_16g_data = { | |
235 | + .type = J721E_WIZ_16G, | |
236 | + .pll0_refclk_mux_sel = &pll0_refclk_mux_sel, | |
237 | + .pll1_refclk_mux_sel = &pll1_refclk_mux_sel, | |
238 | + .refclk_dig_sel = &refclk_dig_sel_16g, | |
239 | + .pma_cmn_refclk1_dig_div = &pma_cmn_refclk1_dig_div, | |
240 | + .clk_mux_sel = clk_mux_sel_16g, | |
241 | + .clk_div_sel_num = WIZ_DIV_NUM_CLOCKS_16G, | |
242 | +}; | |
243 | + | |
244 | +static const struct wiz_data j721e_10g_data = { | |
245 | + .type = J721E_WIZ_10G, | |
246 | + .pll0_refclk_mux_sel = &pll0_refclk_mux_sel, | |
247 | + .pll1_refclk_mux_sel = &pll1_refclk_mux_sel, | |
248 | + .refclk_dig_sel = &refclk_dig_sel_10g, | |
249 | + .clk_mux_sel = clk_mux_sel_10g, | |
250 | + .clk_div_sel_num = WIZ_DIV_NUM_CLOCKS_10G, | |
251 | +}; | |
252 | + | |
253 | +static struct wiz_data am64_10g_data = { | |
254 | + .type = AM64_WIZ_10G, | |
255 | + .pll0_refclk_mux_sel = &pll0_refclk_mux_sel, | |
256 | + .pll1_refclk_mux_sel = &pll1_refclk_mux_sel, | |
257 | + .refclk_dig_sel = &refclk_dig_sel_10g, | |
258 | + .clk_mux_sel = clk_mux_sel_10g, | |
259 | + .clk_div_sel_num = WIZ_DIV_NUM_CLOCKS_10G, | |
260 | +}; | |
261 | + | |
224 | 262 | #define WIZ_TYPEC_DIR_DEBOUNCE_MIN 100 /* ms */ |
225 | 263 | #define WIZ_TYPEC_DIR_DEBOUNCE_MAX 1000 |
226 | 264 |
@@ -253,6 +291,7 @@ struct wiz { | ||
253 | 291 | u32 lane_phy_type[WIZ_MAX_LANES]; |
254 | 292 | struct clk *input_clks[WIZ_MAX_INPUT_CLOCKS]; |
255 | 293 | unsigned int id; |
294 | + const struct wiz_data *data; | |
256 | 295 | }; |
257 | 296 | |
258 | 297 | struct wiz_div_clk { |
@@ -667,7 +706,7 @@ static int wiz_regfield_init(struct wiz *wiz) | ||
667 | 706 | struct regmap *regmap = wiz->regmap; |
668 | 707 | int num_lanes = wiz->num_lanes; |
669 | 708 | struct udevice *dev = wiz->dev; |
670 | - enum wiz_type type; | |
709 | + const struct wiz_data *data = wiz->data; | |
671 | 710 | int i; |
672 | 711 | |
673 | 712 | wiz->por_en = devm_regmap_field_alloc(dev, regmap, por_en); |
@@ -704,36 +743,31 @@ static int wiz_regfield_init(struct wiz *wiz) | ||
704 | 743 | return PTR_ERR(wiz->div_sel_field[CMN_REFCLK]); |
705 | 744 | } |
706 | 745 | |
707 | - wiz->div_sel_field[CMN_REFCLK1] = | |
708 | - devm_regmap_field_alloc(dev, regmap, pma_cmn_refclk1_dig_div); | |
709 | - if (IS_ERR(wiz->div_sel_field[CMN_REFCLK1])) { | |
710 | - dev_err(dev, "PMA_CMN_REFCLK1_DIG_DIV reg field init failed\n"); | |
711 | - return PTR_ERR(wiz->div_sel_field[CMN_REFCLK1]); | |
746 | + if (data->pma_cmn_refclk1_dig_div) { | |
747 | + wiz->div_sel_field[CMN_REFCLK1] = | |
748 | + devm_regmap_field_alloc(dev, regmap, *data->pma_cmn_refclk1_dig_div); | |
749 | + if (IS_ERR(wiz->div_sel_field[CMN_REFCLK1])) { | |
750 | + dev_err(dev, "PMA_CMN_REFCLK1_DIG_DIV reg field init failed\n"); | |
751 | + return PTR_ERR(wiz->div_sel_field[CMN_REFCLK1]); | |
752 | + } | |
712 | 753 | } |
713 | 754 | |
714 | 755 | wiz->mux_sel_field[PLL0_REFCLK] = |
715 | - devm_regmap_field_alloc(dev, regmap, pll0_refclk_mux_sel); | |
756 | + devm_regmap_field_alloc(dev, regmap, *data->pll0_refclk_mux_sel); | |
716 | 757 | if (IS_ERR(wiz->mux_sel_field[PLL0_REFCLK])) { |
717 | 758 | dev_err(dev, "PLL0_REFCLK_SEL reg field init failed\n"); |
718 | 759 | return PTR_ERR(wiz->mux_sel_field[PLL0_REFCLK]); |
719 | 760 | } |
720 | 761 | |
721 | 762 | wiz->mux_sel_field[PLL1_REFCLK] = |
722 | - devm_regmap_field_alloc(dev, regmap, pll1_refclk_mux_sel); | |
763 | + devm_regmap_field_alloc(dev, regmap, *data->pll1_refclk_mux_sel); | |
723 | 764 | if (IS_ERR(wiz->mux_sel_field[PLL1_REFCLK])) { |
724 | 765 | dev_err(dev, "PLL1_REFCLK_SEL reg field init failed\n"); |
725 | 766 | return PTR_ERR(wiz->mux_sel_field[PLL1_REFCLK]); |
726 | 767 | } |
727 | 768 | |
728 | - type = dev_get_driver_data(dev); | |
729 | - if (type == J721E_WIZ_10G || type == AM64_WIZ_10G) | |
730 | - wiz->mux_sel_field[REFCLK_DIG] = | |
731 | - devm_regmap_field_alloc(dev, regmap, | |
732 | - refclk_dig_sel_10g); | |
733 | - else | |
734 | - wiz->mux_sel_field[REFCLK_DIG] = | |
735 | - devm_regmap_field_alloc(dev, regmap, | |
736 | - refclk_dig_sel_16g); | |
769 | + wiz->mux_sel_field[REFCLK_DIG] = | |
770 | + devm_regmap_field_alloc(dev, regmap, *data->refclk_dig_sel); | |
737 | 771 | if (IS_ERR(wiz->mux_sel_field[REFCLK_DIG])) { |
738 | 772 | dev_err(dev, "REFCLK_DIG_SEL reg field init failed\n"); |
739 | 773 | return PTR_ERR(wiz->mux_sel_field[REFCLK_DIG]); |
@@ -1059,14 +1093,12 @@ static int j721e_wiz_probe(struct udevice *dev) | ||
1059 | 1093 | wiz->num_lanes = num_lanes; |
1060 | 1094 | wiz->dev = dev; |
1061 | 1095 | wiz->clk_div_sel = clk_div_sel; |
1062 | - wiz->type = dev_get_driver_data(dev); | |
1063 | - if (wiz->type == J721E_WIZ_10G || wiz->type == AM64_WIZ_10G) { | |
1064 | - wiz->clk_mux_sel = clk_mux_sel_10g; | |
1065 | - wiz->clk_div_sel_num = WIZ_DIV_NUM_CLOCKS_10G; | |
1066 | - } else { | |
1067 | - wiz->clk_mux_sel = clk_mux_sel_16g; | |
1068 | - wiz->clk_div_sel_num = WIZ_DIV_NUM_CLOCKS_16G; | |
1069 | - } | |
1096 | + | |
1097 | + wiz->data = (struct wiz_data *)dev_get_driver_data(dev); | |
1098 | + wiz->type = wiz->data->type; | |
1099 | + | |
1100 | + wiz->clk_mux_sel = (struct wiz_clk_mux_sel *)wiz->data->clk_mux_sel; | |
1101 | + wiz->clk_div_sel_num = wiz->data->clk_div_sel_num; | |
1070 | 1102 | |
1071 | 1103 | rc = wiz_get_lane_phy_types(dev, wiz); |
1072 | 1104 | if (rc) { |
@@ -1133,13 +1165,13 @@ static int j721e_wiz_remove(struct udevice *dev) | ||
1133 | 1165 | |
1134 | 1166 | static const struct udevice_id j721e_wiz_ids[] = { |
1135 | 1167 | { |
1136 | - .compatible = "ti,j721e-wiz-16g", .data = J721E_WIZ_16G, | |
1168 | + .compatible = "ti,j721e-wiz-16g", .data = (ulong)&j721e_16g_data, | |
1137 | 1169 | }, |
1138 | 1170 | { |
1139 | - .compatible = "ti,j721e-wiz-10g", .data = J721E_WIZ_10G, | |
1171 | + .compatible = "ti,j721e-wiz-10g", .data = (ulong)&j721e_10g_data, | |
1140 | 1172 | }, |
1141 | 1173 | { |
1142 | - .compatible = "ti,am64-wiz-10g", .data = AM64_WIZ_10G, | |
1174 | + .compatible = "ti,am64-wiz-10g", .data = (ulong)&am64_10g_data, | |
1143 | 1175 | }, |
1144 | 1176 | {} |
1145 | 1177 | }; |