mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-25 11:04:28 -04:00 
			
		
		
		
	Removed upstreamed: uml/patches-5.15/001-um-fix-default-console-kernel-parameter.patch[1] All other patches automatically rebased Build system: x86_64 Build-tested: bcm2711/RPi4B, mt7622/RT3200 Run-tested: bcm2711/RPi4B, mt7622/RT3200 1. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.71&id=e1dbe8a62098b20f5093cf75ade2f2dc9259b006 Signed-off-by: John Audia <therealgraysky@proton.me> Compile-tested: mvebu/cortexa72 (RB5009UG+S+IN) Run-tested: mvebu/cortexa72 (RB5009UG+S+IN)
		
			
				
	
	
		
			143 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			143 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From: Birger Koblitz <git@birger-koblitz.de>
 | |
| Date: Sun, 5 Sep 2021 15:13:10 +0200
 | |
| Subject: [PATCH] kernel: Add AQR113C and AQR813 support
 | |
| 
 | |
| This hack adds support for the Aquantia 4th generation, 10GBit
 | |
| PHYs AQR113C and AQR813.
 | |
| 
 | |
| Signed-off-by: Birger Koblitz <git@birger-koblitz.de>
 | |
| 
 | |
| --- a/drivers/net/phy/aquantia_main.c
 | |
| +++ b/drivers/net/phy/aquantia_main.c
 | |
| @@ -20,8 +20,10 @@
 | |
|  #define PHY_ID_AQR105	0x03a1b4a2
 | |
|  #define PHY_ID_AQR106	0x03a1b4d0
 | |
|  #define PHY_ID_AQR107	0x03a1b4e0
 | |
| +#define PHY_ID_AQR113C	0x31c31c12
 | |
|  #define PHY_ID_AQCS109	0x03a1b5c2
 | |
|  #define PHY_ID_AQR405	0x03a1b4b0
 | |
| +#define PHY_ID_AQR813	0x31c31cb2
 | |
|  
 | |
|  #define MDIO_PHYXS_VEND_IF_STATUS		0xe812
 | |
|  #define MDIO_PHYXS_VEND_IF_STATUS_TYPE_MASK	GENMASK(7, 3)
 | |
| @@ -381,6 +383,49 @@ static int aqr107_read_rate(struct phy_d
 | |
|  	return 0;
 | |
|  }
 | |
|  
 | |
| +static int aqr113c_read_status(struct phy_device *phydev)
 | |
| +{
 | |
| +	int val, ret;
 | |
| +
 | |
| +	ret = aqr_read_status(phydev);
 | |
| +	if (ret)
 | |
| +		return ret;
 | |
| +
 | |
| +	if (!phydev->link || phydev->autoneg == AUTONEG_DISABLE)
 | |
| +		return 0;
 | |
| +
 | |
| +	// On AQR113C, the speed returned by aqr_read_status is wrong
 | |
| +	aqr107_read_rate(phydev);
 | |
| +
 | |
| +	val = phy_read_mmd(phydev, MDIO_MMD_PHYXS, MDIO_PHYXS_VEND_IF_STATUS);
 | |
| +	if (val < 0)
 | |
| +		return val;
 | |
| +
 | |
| +	switch (FIELD_GET(MDIO_PHYXS_VEND_IF_STATUS_TYPE_MASK, val)) {
 | |
| +	case MDIO_PHYXS_VEND_IF_STATUS_TYPE_KR:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_10GKR;
 | |
| +		break;
 | |
| +	case MDIO_PHYXS_VEND_IF_STATUS_TYPE_XFI:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_10GBASER;
 | |
| +		break;
 | |
| +	case MDIO_PHYXS_VEND_IF_STATUS_TYPE_USXGMII:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_USXGMII;
 | |
| +		break;
 | |
| +	case MDIO_PHYXS_VEND_IF_STATUS_TYPE_SGMII:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_SGMII;
 | |
| +		break;
 | |
| +	case MDIO_PHYXS_VEND_IF_STATUS_TYPE_OCSGMII:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_2500BASEX;
 | |
| +		break;
 | |
| +	default:
 | |
| +		phydev->interface = PHY_INTERFACE_MODE_NA;
 | |
| +		break;
 | |
| +	}
 | |
| +
 | |
| +	/* Read downshifted rate from vendor register */
 | |
| +	return aqr107_read_rate(phydev);
 | |
| +}
 | |
| +
 | |
|  static int aqr107_read_status(struct phy_device *phydev)
 | |
|  {
 | |
|  	int val, ret;
 | |
| @@ -511,7 +556,7 @@ static void aqr107_chip_info(struct phy_
 | |
|  	build_id = FIELD_GET(VEND1_GLOBAL_RSVD_STAT1_FW_BUILD_ID, val);
 | |
|  	prov_id = FIELD_GET(VEND1_GLOBAL_RSVD_STAT1_PROV_ID, val);
 | |
|  
 | |
| -	phydev_dbg(phydev, "FW %u.%u, Build %u, Provisioning %u\n",
 | |
| +	phydev_info(phydev, "FW %u.%u, Build %u, Provisioning %u\n",
 | |
|  		   fw_major, fw_minor, build_id, prov_id);
 | |
|  }
 | |
|  
 | |
| @@ -719,6 +764,24 @@ static struct phy_driver aqr_driver[] =
 | |
|  	.link_change_notify = aqr107_link_change_notify,
 | |
|  },
 | |
|  {
 | |
| +	PHY_ID_MATCH_MODEL(PHY_ID_AQR113C),
 | |
| +	.name		= "Aquantia AQR113C",
 | |
| +	.probe		= aqr107_probe,
 | |
| +	.config_init	= aqr107_config_init,
 | |
| +	.config_aneg    = aqr_config_aneg,
 | |
| +	.config_intr	= aqr_config_intr,
 | |
| +	.handle_interrupt = aqr_handle_interrupt,
 | |
| +	.read_status	= aqr113c_read_status,
 | |
| +	.get_tunable    = aqr107_get_tunable,
 | |
| +	.set_tunable    = aqr107_set_tunable,
 | |
| +	.suspend	= aqr107_suspend,
 | |
| +	.resume		= aqr107_resume,
 | |
| +	.get_sset_count	= aqr107_get_sset_count,
 | |
| +	.get_strings	= aqr107_get_strings,
 | |
| +	.get_stats	= aqr107_get_stats,
 | |
| +	.link_change_notify = aqr107_link_change_notify,
 | |
| +},
 | |
| +{
 | |
|  	PHY_ID_MATCH_MODEL(PHY_ID_AQCS109),
 | |
|  	.name		= "Aquantia AQCS109",
 | |
|  	.probe		= aqr107_probe,
 | |
| @@ -744,6 +807,24 @@ static struct phy_driver aqr_driver[] =
 | |
|  	.handle_interrupt = aqr_handle_interrupt,
 | |
|  	.read_status	= aqr_read_status,
 | |
|  },
 | |
| +{
 | |
| +	PHY_ID_MATCH_MODEL(PHY_ID_AQR813),
 | |
| +	.name		= "Aquantia AQR813",
 | |
| +	.probe		= aqr107_probe,
 | |
| +	.config_init	= aqr107_config_init,
 | |
| +	.config_aneg    = aqr_config_aneg,
 | |
| +	.config_intr	= aqr_config_intr,
 | |
| +	.handle_interrupt = aqr_handle_interrupt,
 | |
| +	.read_status	= aqr113c_read_status,
 | |
| +	.get_tunable    = aqr107_get_tunable,
 | |
| +	.set_tunable    = aqr107_set_tunable,
 | |
| +	.suspend	= aqr107_suspend,
 | |
| +	.resume		= aqr107_resume,
 | |
| +	.get_sset_count	= aqr107_get_sset_count,
 | |
| +	.get_strings	= aqr107_get_strings,
 | |
| +	.get_stats	= aqr107_get_stats,
 | |
| +	.link_change_notify = aqr107_link_change_notify,
 | |
| +},
 | |
|  };
 | |
|  
 | |
|  module_phy_driver(aqr_driver);
 | |
| @@ -754,8 +835,10 @@ static struct mdio_device_id __maybe_unu
 | |
|  	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR105) },
 | |
|  	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR106) },
 | |
|  	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR107) },
 | |
| +	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR113C) },
 | |
|  	{ PHY_ID_MATCH_MODEL(PHY_ID_AQCS109) },
 | |
|  	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR405) },
 | |
| +	{ PHY_ID_MATCH_MODEL(PHY_ID_AQR813) },
 | |
|  	{ }
 | |
|  };
 | |
|  
 |