amd-xgbe: add the bit rate quirk for Molex cables
The offset 12 (bit-rate) of EEPROM SFP DAC (passive) cables is expected
to be in the range 0x64 to 0x68. However, the 5 meter and 7 meter Molex
passive cables have the rate ceiling 0x78 at offset 12.
Add a quirk for Molex passive cables to extend the rate ceiling to 0x78.
Fixes: abf0a1c2b2
("amd-xgbe: Add support for SFP+ modules")
Signed-off-by: Raju Rangoju <Raju.Rangoju@amd.com>
Acked-by: Tom Lendacky <thomas.lendacky@amd.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
Родитель
09c5f6bf11
Коммит
170a9e341a
|
@ -239,6 +239,7 @@ enum xgbe_sfp_speed {
|
||||||
#define XGBE_SFP_BASE_BR_1GBE_MAX 0x0d
|
#define XGBE_SFP_BASE_BR_1GBE_MAX 0x0d
|
||||||
#define XGBE_SFP_BASE_BR_10GBE_MIN 0x64
|
#define XGBE_SFP_BASE_BR_10GBE_MIN 0x64
|
||||||
#define XGBE_SFP_BASE_BR_10GBE_MAX 0x68
|
#define XGBE_SFP_BASE_BR_10GBE_MAX 0x68
|
||||||
|
#define XGBE_MOLEX_SFP_BASE_BR_10GBE_MAX 0x78
|
||||||
|
|
||||||
#define XGBE_SFP_BASE_CU_CABLE_LEN 18
|
#define XGBE_SFP_BASE_CU_CABLE_LEN 18
|
||||||
|
|
||||||
|
@ -284,6 +285,8 @@ struct xgbe_sfp_eeprom {
|
||||||
#define XGBE_BEL_FUSE_VENDOR "BEL-FUSE "
|
#define XGBE_BEL_FUSE_VENDOR "BEL-FUSE "
|
||||||
#define XGBE_BEL_FUSE_PARTNO "1GBT-SFP06 "
|
#define XGBE_BEL_FUSE_PARTNO "1GBT-SFP06 "
|
||||||
|
|
||||||
|
#define XGBE_MOLEX_VENDOR "Molex Inc. "
|
||||||
|
|
||||||
struct xgbe_sfp_ascii {
|
struct xgbe_sfp_ascii {
|
||||||
union {
|
union {
|
||||||
char vendor[XGBE_SFP_BASE_VENDOR_NAME_LEN + 1];
|
char vendor[XGBE_SFP_BASE_VENDOR_NAME_LEN + 1];
|
||||||
|
@ -834,6 +837,10 @@ static bool xgbe_phy_sfp_bit_rate(struct xgbe_sfp_eeprom *sfp_eeprom,
|
||||||
break;
|
break;
|
||||||
case XGBE_SFP_SPEED_10000:
|
case XGBE_SFP_SPEED_10000:
|
||||||
min = XGBE_SFP_BASE_BR_10GBE_MIN;
|
min = XGBE_SFP_BASE_BR_10GBE_MIN;
|
||||||
|
if (memcmp(&sfp_eeprom->base[XGBE_SFP_BASE_VENDOR_NAME],
|
||||||
|
XGBE_MOLEX_VENDOR, XGBE_SFP_BASE_VENDOR_NAME_LEN) == 0)
|
||||||
|
max = XGBE_MOLEX_SFP_BASE_BR_10GBE_MAX;
|
||||||
|
else
|
||||||
max = XGBE_SFP_BASE_BR_10GBE_MAX;
|
max = XGBE_SFP_BASE_BR_10GBE_MAX;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
Загрузка…
Ссылка в новой задаче