e1000e: Separate ADP board type from TGP
We have the same LAN controller on different PCH's. Separate ADP board type from a TGP which will allow for specific fixes to be applied for ADP platforms. Suggested-by: Kai-Heng Feng <kai.heng.feng@canonical.com> Suggested-by: Dima Ruinskiy <dima.ruinskiy@intel.com> Signed-off-by: Sasha Neftin <sasha.neftin@intel.com> Tested-by: Nechama Kraus <nechamax.kraus@linux.intel.com> Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
This commit is contained in:
parent
881cc731df
commit
68defd528f
|
@ -115,7 +115,8 @@ enum e1000_boards {
|
||||||
board_pch_lpt,
|
board_pch_lpt,
|
||||||
board_pch_spt,
|
board_pch_spt,
|
||||||
board_pch_cnp,
|
board_pch_cnp,
|
||||||
board_pch_tgp
|
board_pch_tgp,
|
||||||
|
board_pch_adp
|
||||||
};
|
};
|
||||||
|
|
||||||
struct e1000_ps_page {
|
struct e1000_ps_page {
|
||||||
|
@ -502,6 +503,7 @@ extern const struct e1000_info e1000_pch_lpt_info;
|
||||||
extern const struct e1000_info e1000_pch_spt_info;
|
extern const struct e1000_info e1000_pch_spt_info;
|
||||||
extern const struct e1000_info e1000_pch_cnp_info;
|
extern const struct e1000_info e1000_pch_cnp_info;
|
||||||
extern const struct e1000_info e1000_pch_tgp_info;
|
extern const struct e1000_info e1000_pch_tgp_info;
|
||||||
|
extern const struct e1000_info e1000_pch_adp_info;
|
||||||
extern const struct e1000_info e1000_es2_info;
|
extern const struct e1000_info e1000_es2_info;
|
||||||
|
|
||||||
void e1000e_ptp_init(struct e1000_adapter *adapter);
|
void e1000e_ptp_init(struct e1000_adapter *adapter);
|
||||||
|
|
|
@ -6021,3 +6021,23 @@ const struct e1000_info e1000_pch_tgp_info = {
|
||||||
.phy_ops = &ich8_phy_ops,
|
.phy_ops = &ich8_phy_ops,
|
||||||
.nvm_ops = &spt_nvm_ops,
|
.nvm_ops = &spt_nvm_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const struct e1000_info e1000_pch_adp_info = {
|
||||||
|
.mac = e1000_pch_adp,
|
||||||
|
.flags = FLAG_IS_ICH
|
||||||
|
| FLAG_HAS_WOL
|
||||||
|
| FLAG_HAS_HW_TIMESTAMP
|
||||||
|
| FLAG_HAS_CTRLEXT_ON_LOAD
|
||||||
|
| FLAG_HAS_AMT
|
||||||
|
| FLAG_HAS_FLASH
|
||||||
|
| FLAG_HAS_JUMBO_FRAMES
|
||||||
|
| FLAG_APME_IN_WUC,
|
||||||
|
.flags2 = FLAG2_HAS_PHY_STATS
|
||||||
|
| FLAG2_HAS_EEE,
|
||||||
|
.pba = 26,
|
||||||
|
.max_hw_frame_size = 9022,
|
||||||
|
.get_variants = e1000_get_variants_ich8lan,
|
||||||
|
.mac_ops = &ich8_mac_ops,
|
||||||
|
.phy_ops = &ich8_phy_ops,
|
||||||
|
.nvm_ops = &spt_nvm_ops,
|
||||||
|
};
|
||||||
|
|
|
@ -52,6 +52,7 @@ static const struct e1000_info *e1000_info_tbl[] = {
|
||||||
[board_pch_spt] = &e1000_pch_spt_info,
|
[board_pch_spt] = &e1000_pch_spt_info,
|
||||||
[board_pch_cnp] = &e1000_pch_cnp_info,
|
[board_pch_cnp] = &e1000_pch_cnp_info,
|
||||||
[board_pch_tgp] = &e1000_pch_tgp_info,
|
[board_pch_tgp] = &e1000_pch_tgp_info,
|
||||||
|
[board_pch_adp] = &e1000_pch_adp_info,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct e1000_reg_info {
|
struct e1000_reg_info {
|
||||||
|
@ -7898,22 +7899,22 @@ static const struct pci_device_id e1000_pci_tbl[] = {
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V14), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V14), board_pch_tgp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_LM15), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_LM15), board_pch_tgp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V15), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_TGP_I219_V15), board_pch_tgp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_LM23), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_LM23), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_V23), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_V23), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM16), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM16), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V16), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V16), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM17), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_LM17), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V17), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_ADP_I219_V17), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_LM22), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_LM22), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_V22), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_RPL_I219_V22), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_LM18), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_LM18), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_V18), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_V18), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_LM19), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_LM19), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_V19), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_MTP_I219_V19), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_LM20), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_LM20), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_V20), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_V20), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_LM21), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_LM21), board_pch_adp },
|
||||||
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_V21), board_pch_tgp },
|
{ PCI_VDEVICE(INTEL, E1000_DEV_ID_PCH_LNP_I219_V21), board_pch_adp },
|
||||||
|
|
||||||
{ 0, 0, 0, 0, 0, 0, 0 } /* terminate list */
|
{ 0, 0, 0, 0, 0, 0, 0 } /* terminate list */
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue