Lines Matching +full:pcs +full:- +full:rzn1 +full:- +full:miic

1 // SPDX-License-Identifier: GPL-2.0
13 #include <linux/pcs-rzn1-miic.h>
16 #include <dt-bindings/net/pcs-rzn1-miic.h>
51 #define MIIC_MODCTRL_CONF_NONE -1
54 * struct modctrl_match - Matching table entry for convctrl configuration
58 * then index 1 - 5 are CONV1 - CONV5.
121 * struct miic - MII converter structure
126 * @lock: Lock used for read-modify-write access
128 struct miic { struct
137 * struct miic_port - Per port MII converter struct
138 * @miic: backiling to MII converter structure argument
139 * @pcs: PCS structure associated to the port
144 struct miic *miic; member
145 struct phylink_pcs pcs; member
150 static struct miic_port *phylink_pcs_to_miic_port(struct phylink_pcs *pcs) in phylink_pcs_to_miic_port() argument
152 return container_of(pcs, struct miic_port, pcs); in phylink_pcs_to_miic_port()
155 static void miic_reg_writel(struct miic *miic, int offset, u32 value) in miic_reg_writel() argument
157 writel(value, miic->base + offset); in miic_reg_writel()
160 static u32 miic_reg_readl(struct miic *miic, int offset) in miic_reg_readl() argument
162 return readl(miic->base + offset); in miic_reg_readl()
165 static void miic_reg_rmw(struct miic *miic, int offset, u32 mask, u32 val) in miic_reg_rmw() argument
169 spin_lock(&miic->lock); in miic_reg_rmw()
171 reg = miic_reg_readl(miic, offset); in miic_reg_rmw()
174 miic_reg_writel(miic, offset, reg); in miic_reg_rmw()
176 spin_unlock(&miic->lock); in miic_reg_rmw()
179 static void miic_converter_enable(struct miic *miic, int port, int enable) in miic_converter_enable() argument
186 miic_reg_rmw(miic, MIIC_CONVRST, MIIC_CONVRST_PHYIF_RST(port), val); in miic_converter_enable()
189 static int miic_config(struct phylink_pcs *pcs, unsigned int mode, in miic_config() argument
193 struct miic_port *miic_port = phylink_pcs_to_miic_port(pcs); in miic_config()
194 struct miic *miic = miic_port->miic; in miic_config() local
196 int port = miic_port->port; in miic_config()
218 return -EOPNOTSUPP; in miic_config()
228 if (interface != miic_port->interface) { in miic_config()
231 miic_port->interface = interface; in miic_config()
234 miic_reg_rmw(miic, MIIC_CONVCTRL(port), mask, val); in miic_config()
235 miic_converter_enable(miic_port->miic, miic_port->port, 1); in miic_config()
240 static void miic_link_up(struct phylink_pcs *pcs, unsigned int mode, in miic_link_up() argument
243 struct miic_port *miic_port = phylink_pcs_to_miic_port(pcs); in miic_link_up()
244 struct miic *miic = miic_port->miic; in miic_link_up() local
246 int port = miic_port->port; in miic_link_up()
251 /* No speed in MII through-mode */ in miic_link_up()
270 miic_reg_rmw(miic, MIIC_CONVCTRL(port), in miic_link_up()
274 static int miic_validate(struct phylink_pcs *pcs, unsigned long *supported, in miic_validate() argument
277 if (phy_interface_mode_is_rgmii(state->interface) || in miic_validate()
278 state->interface == PHY_INTERFACE_MODE_RMII || in miic_validate()
279 state->interface == PHY_INTERFACE_MODE_MII) in miic_validate()
282 return -EINVAL; in miic_validate()
296 struct miic *miic; in miic_create() local
300 return ERR_PTR(-ENODEV); in miic_create()
303 return ERR_PTR(-EINVAL); in miic_create()
306 return ERR_PTR(-EINVAL); in miic_create()
308 /* The PCS pdev is attached to the parent node */ in miic_create()
311 return ERR_PTR(-ENODEV); in miic_create()
315 return ERR_PTR(-ENODEV); in miic_create()
321 return ERR_PTR(-EPROBE_DEFER); in miic_create()
325 return ERR_PTR(-ENOMEM); in miic_create()
327 miic = platform_get_drvdata(pdev); in miic_create()
328 device_link_add(dev, miic->dev, DL_FLAG_AUTOREMOVE_CONSUMER); in miic_create()
330 miic_port->miic = miic; in miic_create()
331 miic_port->port = port - 1; in miic_create()
332 miic_port->pcs.ops = &miic_phylink_ops; in miic_create()
334 return &miic_port->pcs; in miic_create()
338 void miic_destroy(struct phylink_pcs *pcs) in miic_destroy() argument
340 struct miic_port *miic_port = phylink_pcs_to_miic_port(pcs); in miic_destroy()
342 miic_converter_enable(miic_port->miic, miic_port->port, 0); in miic_destroy()
347 static int miic_init_hw(struct miic *miic, u32 cfg_mode) in miic_init_hw() argument
352 * is going to be used in conjunction with the Cortex-M3, this sequence in miic_init_hw()
355 miic_reg_writel(miic, MIIC_PRCMD, 0x00A5); in miic_init_hw()
356 miic_reg_writel(miic, MIIC_PRCMD, 0x0001); in miic_init_hw()
357 miic_reg_writel(miic, MIIC_PRCMD, 0xFFFE); in miic_init_hw()
358 miic_reg_writel(miic, MIIC_PRCMD, 0x0001); in miic_init_hw()
360 miic_reg_writel(miic, MIIC_MODCTRL, in miic_init_hw()
364 miic_converter_enable(miic, port, 0); in miic_init_hw()
369 miic_reg_writel(miic, MIIC_SWCTRL, 0x0); in miic_init_hw()
370 miic_reg_writel(miic, MIIC_SWDUPC, 0x0); in miic_init_hw()
418 if (miic_modctrl_match(table_entry->conv, dt_val)) { in miic_match_dt_conf()
419 *mode_cfg = table_entry->mode_cfg; in miic_match_dt_conf()
427 return -EINVAL; in miic_match_dt_conf()
433 struct device_node *np = dev->of_node; in miic_parse_dt()
440 if (of_property_read_u32(np, "renesas,miic-switch-portin", &conf) == 0) in miic_parse_dt()
450 if (of_property_read_u32(conv, "renesas,miic-input", &conf) == 0) in miic_parse_dt()
459 struct device *dev = &pdev->dev; in miic_probe()
460 struct miic *miic; in miic_probe() local
468 miic = devm_kzalloc(dev, sizeof(*miic), GFP_KERNEL); in miic_probe()
469 if (!miic) in miic_probe()
470 return -ENOMEM; in miic_probe()
472 spin_lock_init(&miic->lock); in miic_probe()
473 miic->dev = dev; in miic_probe()
474 miic->base = devm_platform_ioremap_resource(pdev, 0); in miic_probe()
475 if (IS_ERR(miic->base)) in miic_probe()
476 return PTR_ERR(miic->base); in miic_probe()
486 ret = miic_init_hw(miic, mode_cfg); in miic_probe()
495 platform_set_drvdata(pdev, miic); in miic_probe()
507 pm_runtime_put(&pdev->dev); in miic_remove()
513 { .compatible = "renesas,rzn1-miic" },
530 MODULE_DESCRIPTION("Renesas MII converter PCS driver");