1 // SPDX-License-Identifier: GPL-2.0
3 * Microchip KSZ9477 series register access through I2C
5 * Copyright (C) 2018-2024 Microchip Technology Inc.
9 #include <linux/kernel.h>
10 #include <linux/module.h>
11 #include <linux/regmap.h>
13 #include "ksz_common.h"
15 KSZ_REGMAP_TABLE(ksz9477, not_used, 16, 0, 0);
17 static int ksz9477_i2c_probe(struct i2c_client *i2c)
19 const struct ksz_chip_data *chip;
20 struct device *ddev = &i2c->dev;
21 struct regmap_config rc;
22 struct ksz_device *dev;
25 dev = ksz_switch_alloc(&i2c->dev, i2c);
29 chip = device_get_match_data(ddev);
33 /* Save chip id to do special initialization when probing. */
34 dev->chip_id = chip->chip_id;
35 for (i = 0; i < __KSZ_NUM_REGMAPS; i++) {
36 rc = ksz9477_regmap_config[i];
37 rc.lock_arg = &dev->regmap_mutex;
38 dev->regmap[i] = devm_regmap_init_i2c(i2c, &rc);
39 if (IS_ERR(dev->regmap[i])) {
40 return dev_err_probe(&i2c->dev, PTR_ERR(dev->regmap[i]),
41 "Failed to initialize regmap%i\n",
42 ksz9477_regmap_config[i].val_bits);
46 if (i2c->dev.platform_data)
47 dev->pdata = i2c->dev.platform_data;
51 ret = ksz_switch_register(dev);
53 /* Main DSA driver may not be started yet. */
57 i2c_set_clientdata(i2c, dev);
62 static void ksz9477_i2c_remove(struct i2c_client *i2c)
64 struct ksz_device *dev = i2c_get_clientdata(i2c);
67 ksz_switch_remove(dev);
70 static void ksz9477_i2c_shutdown(struct i2c_client *i2c)
72 struct ksz_device *dev = i2c_get_clientdata(i2c);
77 ksz_switch_shutdown(dev);
79 i2c_set_clientdata(i2c, NULL);
82 static const struct i2c_device_id ksz9477_i2c_id[] = {
87 MODULE_DEVICE_TABLE(i2c, ksz9477_i2c_id);
89 static const struct of_device_id ksz9477_dt_ids[] = {
91 .compatible = "microchip,ksz9477",
92 .data = &ksz_switch_chips[KSZ9477]
95 .compatible = "microchip,ksz9896",
96 .data = &ksz_switch_chips[KSZ9896]
99 .compatible = "microchip,ksz9897",
100 .data = &ksz_switch_chips[KSZ9897]
103 .compatible = "microchip,ksz9893",
104 .data = &ksz_switch_chips[KSZ9893]
107 .compatible = "microchip,ksz9563",
108 .data = &ksz_switch_chips[KSZ9563]
111 .compatible = "microchip,ksz8563",
112 .data = &ksz_switch_chips[KSZ8563]
115 .compatible = "microchip,ksz8567",
116 .data = &ksz_switch_chips[KSZ8567]
119 .compatible = "microchip,ksz9567",
120 .data = &ksz_switch_chips[KSZ9567]
123 .compatible = "microchip,lan9646",
124 .data = &ksz_switch_chips[LAN9646]
128 MODULE_DEVICE_TABLE(of, ksz9477_dt_ids);
130 static DEFINE_SIMPLE_DEV_PM_OPS(ksz_i2c_pm_ops,
131 ksz_switch_suspend, ksz_switch_resume);
133 static struct i2c_driver ksz9477_i2c_driver = {
135 .name = "ksz9477-switch",
136 .of_match_table = ksz9477_dt_ids,
137 .pm = &ksz_i2c_pm_ops,
139 .probe = ksz9477_i2c_probe,
140 .remove = ksz9477_i2c_remove,
141 .shutdown = ksz9477_i2c_shutdown,
142 .id_table = ksz9477_i2c_id,
145 module_i2c_driver(ksz9477_i2c_driver);
148 MODULE_DESCRIPTION("Microchip KSZ9477 Series Switch I2C access Driver");
149 MODULE_LICENSE("GPL v2");