net: dsa: realtek: rtl8365mb: add RTL8367S support
Realtek's RTL8367S, a 5+2 port 10/100/1000M Ethernet switch. It shares the same driver family (RTL8367C) with other models as the RTL8365MB-VC. Its compatible string is "realtek,rtl8367s". It was tested only with MDIO interface (realtek-mdio), although it might work out-of-the-box with SMI interface (using realtek-smi). This patch was based on an unpublished patch from Alvin Šipraga <alsi@bang-olufsen.dk>. Signed-off-by: Luiz Angelo Daros de Luca <luizluca@gmail.com> Tested-by: Arınç ÜNAL <arinc.unal@arinc9.com> Reviewed-by: Alvin Šipraga <alsi@bang-olufsen.dk> Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									7fa8af30ec
								
							
						
					
					
						commit
						d40f607c18
					
				| @ -32,7 +32,7 @@ config NET_DSA_REALTEK_RTL8365MB | ||||
| 	depends on NET_DSA_REALTEK_SMI || NET_DSA_REALTEK_MDIO | ||||
| 	select NET_DSA_TAG_RTL8_4 | ||||
| 	help | ||||
| 	  Select to enable support for Realtek RTL8365MB | ||||
| 	  Select to enable support for Realtek RTL8365MB-VC and RTL8367S. | ||||
| 
 | ||||
| config NET_DSA_REALTEK_RTL8366RB | ||||
| 	tristate "Realtek RTL8366RB switch subdriver" | ||||
|  | ||||
| @ -206,6 +206,7 @@ static const struct of_device_id realtek_mdio_of_match[] = { | ||||
| #endif | ||||
| #if IS_ENABLED(CONFIG_NET_DSA_REALTEK_RTL8365MB) | ||||
| 	{ .compatible = "realtek,rtl8365mb", .data = &rtl8365mb_variant, }, | ||||
| 	{ .compatible = "realtek,rtl8367s", .data = &rtl8365mb_variant, }, | ||||
| #endif | ||||
| 	{ /* sentinel */ }, | ||||
| }; | ||||
|  | ||||
| @ -510,6 +510,10 @@ static const struct of_device_id realtek_smi_of_match[] = { | ||||
| 		.compatible = "realtek,rtl8365mb", | ||||
| 		.data = &rtl8365mb_variant, | ||||
| 	}, | ||||
| 	{ | ||||
| 		.compatible = "realtek,rtl8367s", | ||||
| 		.data = &rtl8365mb_variant, | ||||
| 	}, | ||||
| #endif | ||||
| 	{ /* sentinel */ }, | ||||
| }; | ||||
|  | ||||
| @ -102,15 +102,22 @@ | ||||
| #include "realtek.h" | ||||
| 
 | ||||
| /* Chip-specific data and limits */ | ||||
| #define RTL8365MB_CHIP_ID_8365MB_VC		0x6367 | ||||
| #define RTL8365MB_LEARN_LIMIT_MAX_8365MB_VC	2112 | ||||
| static const int rtl8365mb_extint_port_map[] = { -1, -1, -1, -1, -1, -1, 1 }; | ||||
| #define RTL8365MB_CHIP_ID_8365MB_VC	0x6367 | ||||
| #define RTL8365MB_CHIP_VER_8365MB_VC	0x0040 | ||||
| 
 | ||||
| #define RTL8365MB_CHIP_ID_8367S		0x6367 | ||||
| #define RTL8365MB_CHIP_VER_8367S	0x00A0 | ||||
| 
 | ||||
| /* Family-specific data and limits */ | ||||
| #define RTL8365MB_PHYADDRMAX	7 | ||||
| #define RTL8365MB_NUM_PHYREGS	32 | ||||
| #define RTL8365MB_PHYREGMAX	(RTL8365MB_NUM_PHYREGS - 1) | ||||
| #define RTL8365MB_MAX_NUM_PORTS  7 | ||||
| #define RTL8365MB_PHYADDRMAX		7 | ||||
| #define RTL8365MB_NUM_PHYREGS		32 | ||||
| #define RTL8365MB_PHYREGMAX		(RTL8365MB_NUM_PHYREGS - 1) | ||||
| /* RTL8370MB and RTL8310SR, possibly suportable by this driver, have 10 ports */ | ||||
| #define RTL8365MB_MAX_NUM_PORTS		10 | ||||
| #define RTL8365MB_LEARN_LIMIT_MAX	2112 | ||||
| 
 | ||||
| /* valid for all 6-port or less variants */ | ||||
| static const int rtl8365mb_extint_port_map[]  = { -1, -1, -1, -1, -1, -1, 1, 2, -1, -1}; | ||||
| 
 | ||||
| /* Chip identification registers */ | ||||
| #define RTL8365MB_CHIP_ID_REG		0x1300 | ||||
| @ -1966,9 +1973,22 @@ static int rtl8365mb_detect(struct realtek_priv *priv) | ||||
| 
 | ||||
| 	switch (chip_id) { | ||||
| 	case RTL8365MB_CHIP_ID_8365MB_VC: | ||||
| 		dev_info(priv->dev, | ||||
| 			 "found an RTL8365MB-VC switch (ver=0x%04x)\n", | ||||
| 			 chip_ver); | ||||
| 		switch (chip_ver) { | ||||
| 		case RTL8365MB_CHIP_VER_8365MB_VC: | ||||
| 			dev_info(priv->dev, | ||||
| 				 "found an RTL8365MB-VC switch (ver=0x%04x)\n", | ||||
| 				 chip_ver); | ||||
| 			break; | ||||
| 		case RTL8365MB_CHIP_VER_8367S: | ||||
| 			dev_info(priv->dev, | ||||
| 				 "found an RTL8367S switch (ver=0x%04x)\n", | ||||
| 				 chip_ver); | ||||
| 			break; | ||||
| 		default: | ||||
| 			dev_err(priv->dev, "unrecognized switch version (ver=0x%04x)", | ||||
| 				chip_ver); | ||||
| 			return -ENODEV; | ||||
| 		} | ||||
| 
 | ||||
| 		priv->num_ports = RTL8365MB_MAX_NUM_PORTS; | ||||
| 
 | ||||
| @ -1976,7 +1996,7 @@ static int rtl8365mb_detect(struct realtek_priv *priv) | ||||
| 		mb->chip_id = chip_id; | ||||
| 		mb->chip_ver = chip_ver; | ||||
| 		mb->port_mask = GENMASK(priv->num_ports - 1, 0); | ||||
| 		mb->learn_limit_max = RTL8365MB_LEARN_LIMIT_MAX_8365MB_VC; | ||||
| 		mb->learn_limit_max = RTL8365MB_LEARN_LIMIT_MAX; | ||||
| 		mb->jam_table = rtl8365mb_init_jam_8365mb_vc; | ||||
| 		mb->jam_size = ARRAY_SIZE(rtl8365mb_init_jam_8365mb_vc); | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user