mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-05-09 17:17:04 -04:00
net: dsa: microchip: add regmap_range for KSZ8563 chip
Add register validation for KSZ8563. Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de> Reviewed-by: Vladimir Oltean <olteanv@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
ec6ba50c65
commit
41131bac9a
@@ -412,6 +412,125 @@ static const u8 lan937x_shifts[] = {
|
||||
[ALU_STAT_INDEX] = 8,
|
||||
};
|
||||
|
||||
static const struct regmap_range ksz8563_valid_regs[] = {
|
||||
regmap_reg_range(0x0000, 0x0003),
|
||||
regmap_reg_range(0x0006, 0x0006),
|
||||
regmap_reg_range(0x000f, 0x001f),
|
||||
regmap_reg_range(0x0100, 0x0100),
|
||||
regmap_reg_range(0x0104, 0x0107),
|
||||
regmap_reg_range(0x010d, 0x010d),
|
||||
regmap_reg_range(0x0110, 0x0113),
|
||||
regmap_reg_range(0x0120, 0x012b),
|
||||
regmap_reg_range(0x0201, 0x0201),
|
||||
regmap_reg_range(0x0210, 0x0213),
|
||||
regmap_reg_range(0x0300, 0x0300),
|
||||
regmap_reg_range(0x0302, 0x031b),
|
||||
regmap_reg_range(0x0320, 0x032b),
|
||||
regmap_reg_range(0x0330, 0x0336),
|
||||
regmap_reg_range(0x0338, 0x033e),
|
||||
regmap_reg_range(0x0340, 0x035f),
|
||||
regmap_reg_range(0x0370, 0x0370),
|
||||
regmap_reg_range(0x0378, 0x0378),
|
||||
regmap_reg_range(0x037c, 0x037d),
|
||||
regmap_reg_range(0x0390, 0x0393),
|
||||
regmap_reg_range(0x0400, 0x040e),
|
||||
regmap_reg_range(0x0410, 0x042f),
|
||||
regmap_reg_range(0x0500, 0x0519),
|
||||
regmap_reg_range(0x0520, 0x054b),
|
||||
regmap_reg_range(0x0550, 0x05b3),
|
||||
|
||||
/* port 1 */
|
||||
regmap_reg_range(0x1000, 0x1001),
|
||||
regmap_reg_range(0x1004, 0x100b),
|
||||
regmap_reg_range(0x1013, 0x1013),
|
||||
regmap_reg_range(0x1017, 0x1017),
|
||||
regmap_reg_range(0x101b, 0x101b),
|
||||
regmap_reg_range(0x101f, 0x1021),
|
||||
regmap_reg_range(0x1030, 0x1030),
|
||||
regmap_reg_range(0x1100, 0x1111),
|
||||
regmap_reg_range(0x111a, 0x111d),
|
||||
regmap_reg_range(0x1122, 0x1127),
|
||||
regmap_reg_range(0x112a, 0x112b),
|
||||
regmap_reg_range(0x1136, 0x1139),
|
||||
regmap_reg_range(0x113e, 0x113f),
|
||||
regmap_reg_range(0x1400, 0x1401),
|
||||
regmap_reg_range(0x1403, 0x1403),
|
||||
regmap_reg_range(0x1410, 0x1417),
|
||||
regmap_reg_range(0x1420, 0x1423),
|
||||
regmap_reg_range(0x1500, 0x1507),
|
||||
regmap_reg_range(0x1600, 0x1612),
|
||||
regmap_reg_range(0x1800, 0x180f),
|
||||
regmap_reg_range(0x1900, 0x1907),
|
||||
regmap_reg_range(0x1914, 0x191b),
|
||||
regmap_reg_range(0x1a00, 0x1a03),
|
||||
regmap_reg_range(0x1a04, 0x1a08),
|
||||
regmap_reg_range(0x1b00, 0x1b01),
|
||||
regmap_reg_range(0x1b04, 0x1b04),
|
||||
regmap_reg_range(0x1c00, 0x1c05),
|
||||
regmap_reg_range(0x1c08, 0x1c1b),
|
||||
|
||||
/* port 2 */
|
||||
regmap_reg_range(0x2000, 0x2001),
|
||||
regmap_reg_range(0x2004, 0x200b),
|
||||
regmap_reg_range(0x2013, 0x2013),
|
||||
regmap_reg_range(0x2017, 0x2017),
|
||||
regmap_reg_range(0x201b, 0x201b),
|
||||
regmap_reg_range(0x201f, 0x2021),
|
||||
regmap_reg_range(0x2030, 0x2030),
|
||||
regmap_reg_range(0x2100, 0x2111),
|
||||
regmap_reg_range(0x211a, 0x211d),
|
||||
regmap_reg_range(0x2122, 0x2127),
|
||||
regmap_reg_range(0x212a, 0x212b),
|
||||
regmap_reg_range(0x2136, 0x2139),
|
||||
regmap_reg_range(0x213e, 0x213f),
|
||||
regmap_reg_range(0x2400, 0x2401),
|
||||
regmap_reg_range(0x2403, 0x2403),
|
||||
regmap_reg_range(0x2410, 0x2417),
|
||||
regmap_reg_range(0x2420, 0x2423),
|
||||
regmap_reg_range(0x2500, 0x2507),
|
||||
regmap_reg_range(0x2600, 0x2612),
|
||||
regmap_reg_range(0x2800, 0x280f),
|
||||
regmap_reg_range(0x2900, 0x2907),
|
||||
regmap_reg_range(0x2914, 0x291b),
|
||||
regmap_reg_range(0x2a00, 0x2a03),
|
||||
regmap_reg_range(0x2a04, 0x2a08),
|
||||
regmap_reg_range(0x2b00, 0x2b01),
|
||||
regmap_reg_range(0x2b04, 0x2b04),
|
||||
regmap_reg_range(0x2c00, 0x2c05),
|
||||
regmap_reg_range(0x2c08, 0x2c1b),
|
||||
|
||||
/* port 3 */
|
||||
regmap_reg_range(0x3000, 0x3001),
|
||||
regmap_reg_range(0x3004, 0x300b),
|
||||
regmap_reg_range(0x3013, 0x3013),
|
||||
regmap_reg_range(0x3017, 0x3017),
|
||||
regmap_reg_range(0x301b, 0x301b),
|
||||
regmap_reg_range(0x301f, 0x3021),
|
||||
regmap_reg_range(0x3030, 0x3030),
|
||||
regmap_reg_range(0x3300, 0x3301),
|
||||
regmap_reg_range(0x3303, 0x3303),
|
||||
regmap_reg_range(0x3400, 0x3401),
|
||||
regmap_reg_range(0x3403, 0x3403),
|
||||
regmap_reg_range(0x3410, 0x3417),
|
||||
regmap_reg_range(0x3420, 0x3423),
|
||||
regmap_reg_range(0x3500, 0x3507),
|
||||
regmap_reg_range(0x3600, 0x3612),
|
||||
regmap_reg_range(0x3800, 0x380f),
|
||||
regmap_reg_range(0x3900, 0x3907),
|
||||
regmap_reg_range(0x3914, 0x391b),
|
||||
regmap_reg_range(0x3a00, 0x3a03),
|
||||
regmap_reg_range(0x3a04, 0x3a08),
|
||||
regmap_reg_range(0x3b00, 0x3b01),
|
||||
regmap_reg_range(0x3b04, 0x3b04),
|
||||
regmap_reg_range(0x3c00, 0x3c05),
|
||||
regmap_reg_range(0x3c08, 0x3c1b),
|
||||
};
|
||||
|
||||
static const struct regmap_access_table ksz8563_register_set = {
|
||||
.yes_ranges = ksz8563_valid_regs,
|
||||
.n_yes_ranges = ARRAY_SIZE(ksz8563_valid_regs),
|
||||
};
|
||||
|
||||
const struct ksz_chip_data ksz_switch_chips[] = {
|
||||
[KSZ8563] = {
|
||||
.chip_id = KSZ8563_CHIP_ID,
|
||||
@@ -435,6 +554,8 @@ const struct ksz_chip_data ksz_switch_chips[] = {
|
||||
.supports_rgmii = {false, false, true},
|
||||
.internal_phy = {true, true, false},
|
||||
.gbit_capable = {false, false, true},
|
||||
.wr_table = &ksz8563_register_set,
|
||||
.rd_table = &ksz8563_register_set,
|
||||
},
|
||||
|
||||
[KSZ8795] = {
|
||||
|
||||
Reference in New Issue
Block a user