Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
64e771bb
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
64e771bb
编写于
5月 03, 2012
作者:
D
David S. Miller
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'master' of
git://git.kernel.org/pub/scm/linux/kernel/git/jkirsher/net-next
上级
3a7c1ee4
9cd9130d
变更
11
隐藏空白更改
内联
并排
Showing
11 changed file
with
119 addition
and
69 deletion
+119
-69
drivers/net/ethernet/intel/e1000e/80003es2lan.c
drivers/net/ethernet/intel/e1000e/80003es2lan.c
+8
-0
drivers/net/ethernet/intel/e1000e/82571.c
drivers/net/ethernet/intel/e1000e/82571.c
+12
-1
drivers/net/ethernet/intel/e1000e/e1000.h
drivers/net/ethernet/intel/e1000e/e1000.h
+10
-0
drivers/net/ethernet/intel/e1000e/ich8lan.c
drivers/net/ethernet/intel/e1000e/ich8lan.c
+26
-28
drivers/net/ethernet/intel/e1000e/netdev.c
drivers/net/ethernet/intel/e1000e/netdev.c
+5
-16
drivers/net/ethernet/intel/e1000e/phy.c
drivers/net/ethernet/intel/e1000e/phy.c
+17
-1
drivers/net/ethernet/intel/ixgbevf/defines.h
drivers/net/ethernet/intel/ixgbevf/defines.h
+2
-0
drivers/net/ethernet/intel/ixgbevf/ethtool.c
drivers/net/ethernet/intel/ixgbevf/ethtool.c
+14
-4
drivers/net/ethernet/intel/ixgbevf/ixgbevf.h
drivers/net/ethernet/intel/ixgbevf/ixgbevf.h
+1
-1
drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c
drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c
+15
-15
drivers/net/ethernet/intel/ixgbevf/vf.c
drivers/net/ethernet/intel/ixgbevf/vf.c
+9
-3
未找到文件。
drivers/net/ethernet/intel/e1000e/80003es2lan.c
浏览文件 @
64e771bb
...
...
@@ -944,6 +944,14 @@ static void e1000_initialize_hw_bits_80003es2lan(struct e1000_hw *hw)
else
reg
|=
(
1
<<
28
);
ew32
(
TARC
(
1
),
reg
);
/*
* Disable IPv6 extension header parsing because some malformed
* IPv6 headers can hang the Rx.
*/
reg
=
er32
(
RFCTL
);
reg
|=
(
E1000_RFCTL_IPV6_EX_DIS
|
E1000_RFCTL_NEW_IPV6_EXT_DIS
);
ew32
(
RFCTL
,
reg
);
}
/**
...
...
drivers/net/ethernet/intel/e1000e/82571.c
浏览文件 @
64e771bb
...
...
@@ -1279,6 +1279,16 @@ static void e1000_initialize_hw_bits_82571(struct e1000_hw *hw)
ew32
(
CTRL_EXT
,
reg
);
}
/*
* Disable IPv6 extension header parsing because some malformed
* IPv6 headers can hang the Rx.
*/
if
(
hw
->
mac
.
type
<=
e1000_82573
)
{
reg
=
er32
(
RFCTL
);
reg
|=
(
E1000_RFCTL_IPV6_EX_DIS
|
E1000_RFCTL_NEW_IPV6_EXT_DIS
);
ew32
(
RFCTL
,
reg
);
}
/* PCI-Ex Control Registers */
switch
(
hw
->
mac
.
type
)
{
case
e1000_82574
:
...
...
@@ -2062,8 +2072,9 @@ const struct e1000_info e1000_82574_info = {
|
FLAG_HAS_SMART_POWER_DOWN
|
FLAG_HAS_AMT
|
FLAG_HAS_CTRLEXT_ON_LOAD
,
.
flags2
=
FLAG2_CHECK_PHY_HANG
.
flags2
=
FLAG2_CHECK_PHY_HANG
|
FLAG2_DISABLE_ASPM_L0S
|
FLAG2_DISABLE_ASPM_L1
|
FLAG2_NO_DISABLE_RX
|
FLAG2_DMA_BURST
,
.
pba
=
32
,
...
...
drivers/net/ethernet/intel/e1000e/e1000.h
浏览文件 @
64e771bb
...
...
@@ -673,11 +673,21 @@ static inline s32 e1e_rphy(struct e1000_hw *hw, u32 offset, u16 *data)
return
hw
->
phy
.
ops
.
read_reg
(
hw
,
offset
,
data
);
}
static
inline
s32
e1e_rphy_locked
(
struct
e1000_hw
*
hw
,
u32
offset
,
u16
*
data
)
{
return
hw
->
phy
.
ops
.
read_reg_locked
(
hw
,
offset
,
data
);
}
static
inline
s32
e1e_wphy
(
struct
e1000_hw
*
hw
,
u32
offset
,
u16
data
)
{
return
hw
->
phy
.
ops
.
write_reg
(
hw
,
offset
,
data
);
}
static
inline
s32
e1e_wphy_locked
(
struct
e1000_hw
*
hw
,
u32
offset
,
u16
data
)
{
return
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
offset
,
data
);
}
static
inline
s32
e1000_get_cable_length
(
struct
e1000_hw
*
hw
)
{
return
hw
->
phy
.
ops
.
get_cable_length
(
hw
);
...
...
drivers/net/ethernet/intel/e1000e/ich8lan.c
浏览文件 @
64e771bb
...
...
@@ -304,9 +304,9 @@ static bool e1000_phy_is_accessible_pchlan(struct e1000_hw *hw)
u16
phy_reg
;
u32
phy_id
;
hw
->
phy
.
ops
.
read_reg
_locked
(
hw
,
PHY_ID1
,
&
phy_reg
);
e1e_rphy
_locked
(
hw
,
PHY_ID1
,
&
phy_reg
);
phy_id
=
(
u32
)(
phy_reg
<<
16
);
hw
->
phy
.
ops
.
read_reg
_locked
(
hw
,
PHY_ID2
,
&
phy_reg
);
e1e_rphy
_locked
(
hw
,
PHY_ID2
,
&
phy_reg
);
phy_id
|=
(
u32
)(
phy_reg
&
PHY_REVISION_MASK
);
if
(
hw
->
phy
.
id
)
{
...
...
@@ -1271,8 +1271,7 @@ static s32 e1000_sw_lcd_config_ich8lan(struct e1000_hw *hw)
reg_addr
&=
PHY_REG_MASK
;
reg_addr
|=
phy_page
;
ret_val
=
phy
->
ops
.
write_reg_locked
(
hw
,
(
u32
)
reg_addr
,
reg_data
);
ret_val
=
e1e_wphy_locked
(
hw
,
(
u32
)
reg_addr
,
reg_data
);
if
(
ret_val
)
goto
release
;
}
...
...
@@ -1309,8 +1308,8 @@ static s32 e1000_k1_gig_workaround_hv(struct e1000_hw *hw, bool link)
/* Disable K1 when link is 1Gbps, otherwise use the NVM setting */
if
(
link
)
{
if
(
hw
->
phy
.
type
==
e1000_phy_82578
)
{
ret_val
=
hw
->
phy
.
ops
.
read_reg
_locked
(
hw
,
BM_CS_STATUS
,
&
status_reg
);
ret_val
=
e1e_rphy
_locked
(
hw
,
BM_CS_STATUS
,
&
status_reg
);
if
(
ret_val
)
goto
release
;
...
...
@@ -1325,8 +1324,7 @@ static s32 e1000_k1_gig_workaround_hv(struct e1000_hw *hw, bool link)
}
if
(
hw
->
phy
.
type
==
e1000_phy_82577
)
{
ret_val
=
hw
->
phy
.
ops
.
read_reg_locked
(
hw
,
HV_M_STATUS
,
&
status_reg
);
ret_val
=
e1e_rphy_locked
(
hw
,
HV_M_STATUS
,
&
status_reg
);
if
(
ret_val
)
goto
release
;
...
...
@@ -1341,15 +1339,13 @@ static s32 e1000_k1_gig_workaround_hv(struct e1000_hw *hw, bool link)
}
/* Link stall fix for link up */
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
PHY_REG
(
770
,
19
),
0x0100
);
ret_val
=
e1e_wphy_locked
(
hw
,
PHY_REG
(
770
,
19
),
0x0100
);
if
(
ret_val
)
goto
release
;
}
else
{
/* Link stall fix for link down */
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
PHY_REG
(
770
,
19
),
0x4100
);
ret_val
=
e1e_wphy_locked
(
hw
,
PHY_REG
(
770
,
19
),
0x4100
);
if
(
ret_val
)
goto
release
;
}
...
...
@@ -1448,7 +1444,7 @@ static s32 e1000_oem_bits_config_ich8lan(struct e1000_hw *hw, bool d0_state)
mac_reg
=
er32
(
PHY_CTRL
);
ret_val
=
hw
->
phy
.
ops
.
read_reg
_locked
(
hw
,
HV_OEM_BITS
,
&
oem_reg
);
ret_val
=
e1e_rphy
_locked
(
hw
,
HV_OEM_BITS
,
&
oem_reg
);
if
(
ret_val
)
goto
release
;
...
...
@@ -1475,7 +1471,7 @@ static s32 e1000_oem_bits_config_ich8lan(struct e1000_hw *hw, bool d0_state)
!
hw
->
phy
.
ops
.
check_reset_block
(
hw
))
oem_reg
|=
HV_OEM_BITS_RESTART_AN
;
ret_val
=
hw
->
phy
.
ops
.
write_reg
_locked
(
hw
,
HV_OEM_BITS
,
oem_reg
);
ret_val
=
e1e_wphy
_locked
(
hw
,
HV_OEM_BITS
,
oem_reg
);
release:
hw
->
phy
.
ops
.
release
(
hw
);
...
...
@@ -1571,11 +1567,10 @@ static s32 e1000_hv_phy_workarounds_ich8lan(struct e1000_hw *hw)
ret_val
=
hw
->
phy
.
ops
.
acquire
(
hw
);
if
(
ret_val
)
return
ret_val
;
ret_val
=
hw
->
phy
.
ops
.
read_reg
_locked
(
hw
,
BM_PORT_GEN_CFG
,
&
phy_data
);
ret_val
=
e1e_rphy
_locked
(
hw
,
BM_PORT_GEN_CFG
,
&
phy_data
);
if
(
ret_val
)
goto
release
;
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
BM_PORT_GEN_CFG
,
phy_data
&
0x00FF
);
ret_val
=
e1e_wphy_locked
(
hw
,
BM_PORT_GEN_CFG
,
phy_data
&
0x00FF
);
release:
hw
->
phy
.
ops
.
release
(
hw
);
...
...
@@ -1807,20 +1802,18 @@ static s32 e1000_lv_phy_workarounds_ich8lan(struct e1000_hw *hw)
ret_val
=
hw
->
phy
.
ops
.
acquire
(
hw
);
if
(
ret_val
)
return
ret_val
;
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_MSE_THRESHOLD
);
ret_val
=
e1e_wphy_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_MSE_THRESHOLD
);
if
(
ret_val
)
goto
release
;
/* set MSE higher to enable link to stay up when noise is high */
ret_val
=
hw
->
phy
.
ops
.
write_reg
_locked
(
hw
,
I82579_EMI_DATA
,
0x0034
);
ret_val
=
e1e_wphy
_locked
(
hw
,
I82579_EMI_DATA
,
0x0034
);
if
(
ret_val
)
goto
release
;
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_MSE_LINK_DOWN
);
ret_val
=
e1e_wphy_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_MSE_LINK_DOWN
);
if
(
ret_val
)
goto
release
;
/* drop link after 5 times MSE threshold was reached */
ret_val
=
hw
->
phy
.
ops
.
write_reg
_locked
(
hw
,
I82579_EMI_DATA
,
0x0005
);
ret_val
=
e1e_wphy
_locked
(
hw
,
I82579_EMI_DATA
,
0x0005
);
release:
hw
->
phy
.
ops
.
release
(
hw
);
...
...
@@ -1995,12 +1988,10 @@ static s32 e1000_post_phy_reset_ich8lan(struct e1000_hw *hw)
ret_val
=
hw
->
phy
.
ops
.
acquire
(
hw
);
if
(
ret_val
)
return
ret_val
;
ret_val
=
hw
->
phy
.
ops
.
write_reg
_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_LPI_UPDATE_TIMER
);
ret_val
=
e1e_wphy
_locked
(
hw
,
I82579_EMI_ADDR
,
I82579_LPI_UPDATE_TIMER
);
if
(
!
ret_val
)
ret_val
=
hw
->
phy
.
ops
.
write_reg_locked
(
hw
,
I82579_EMI_DATA
,
0x1387
);
ret_val
=
e1e_wphy_locked
(
hw
,
I82579_EMI_DATA
,
0x1387
);
hw
->
phy
.
ops
.
release
(
hw
);
}
...
...
@@ -3477,6 +3468,13 @@ static void e1000_initialize_hw_bits_ich8lan(struct e1000_hw *hw)
*/
reg
=
er32
(
RFCTL
);
reg
|=
(
E1000_RFCTL_NFSW_DIS
|
E1000_RFCTL_NFSR_DIS
);
/*
* Disable IPv6 extension header parsing because some malformed
* IPv6 headers can hang the Rx.
*/
if
(
hw
->
mac
.
type
==
e1000_ich8lan
)
reg
|=
(
E1000_RFCTL_IPV6_EX_DIS
|
E1000_RFCTL_NEW_IPV6_EXT_DIS
);
ew32
(
RFCTL
,
reg
);
}
...
...
drivers/net/ethernet/intel/e1000e/netdev.c
浏览文件 @
64e771bb
...
...
@@ -1084,6 +1084,10 @@ static void e1000_print_hw_hang(struct work_struct *work)
phy_1000t_status
,
phy_ext_status
,
pci_status
);
/* Suggest workaround for known h/w issue */
if
((
hw
->
mac
.
type
==
e1000_pchlan
)
&&
(
er32
(
CTRL
)
&
E1000_CTRL_TFCE
))
e_err
(
"Try turning off Tx pause (flow control) via ethtool
\n
"
);
}
/**
...
...
@@ -2935,6 +2939,7 @@ static void e1000_setup_rctl(struct e1000_adapter *adapter)
/* Enable Extended Status in all Receive Descriptors */
rfctl
=
er32
(
RFCTL
);
rfctl
|=
E1000_RFCTL_EXTEN
;
ew32
(
RFCTL
,
rfctl
);
/*
* 82571 and greater support packet-split where the protocol
...
...
@@ -2960,13 +2965,6 @@ static void e1000_setup_rctl(struct e1000_adapter *adapter)
if
(
adapter
->
rx_ps_pages
)
{
u32
psrctl
=
0
;
/*
* disable packet split support for IPv6 extension headers,
* because some malformed IPv6 headers can hang the Rx
*/
rfctl
|=
(
E1000_RFCTL_IPV6_EX_DIS
|
E1000_RFCTL_NEW_IPV6_EXT_DIS
);
/* Enable Packet split descriptors */
rctl
|=
E1000_RCTL_DTYP_PS
;
...
...
@@ -3005,7 +3003,6 @@ static void e1000_setup_rctl(struct e1000_adapter *adapter)
*/
}
ew32
(
RFCTL
,
rfctl
);
ew32
(
RCTL
,
rctl
);
/* just started the receive unit, no need to restart */
adapter
->
flags
&=
~
FLAG_RX_RESTART_NOW
;
...
...
@@ -5275,14 +5272,6 @@ static int e1000_change_mtu(struct net_device *netdev, int new_mtu)
return
-
EINVAL
;
}
/* 82573 Errata 17 */
if
(((
adapter
->
hw
.
mac
.
type
==
e1000_82573
)
||
(
adapter
->
hw
.
mac
.
type
==
e1000_82574
))
&&
(
max_frame
>
ETH_FRAME_LEN
+
ETH_FCS_LEN
))
{
adapter
->
flags2
|=
FLAG2_DISABLE_ASPM_L1
;
e1000e_disable_aspm
(
adapter
->
pdev
,
PCIE_LINK_STATE_L1
);
}
while
(
test_and_set_bit
(
__E1000_RESETTING
,
&
adapter
->
state
))
usleep_range
(
1000
,
2000
);
/* e1000e_down -> e1000e_reset dependent on max_frame_size & mtu */
...
...
drivers/net/ethernet/intel/e1000e/phy.c
浏览文件 @
64e771bb
...
...
@@ -722,8 +722,24 @@ s32 e1000e_copper_link_setup_m88(struct e1000_hw *hw)
phy_data
|=
M88E1000_PSCR_POLARITY_REVERSAL
;
/* Enable downshift on BM (disabled by default) */
if
(
phy
->
type
==
e1000_phy_bm
)
if
(
phy
->
type
==
e1000_phy_bm
)
{
/* For 82574/82583, first disable then enable downshift */
if
(
phy
->
id
==
BME1000_E_PHY_ID_R2
)
{
phy_data
&=
~
BME1000_PSCR_ENABLE_DOWNSHIFT
;
ret_val
=
e1e_wphy
(
hw
,
M88E1000_PHY_SPEC_CTRL
,
phy_data
);
if
(
ret_val
)
return
ret_val
;
/* Commit the changes. */
ret_val
=
e1000e_commit_phy
(
hw
);
if
(
ret_val
)
{
e_dbg
(
"Error committing the PHY changes
\n
"
);
return
ret_val
;
}
}
phy_data
|=
BME1000_PSCR_ENABLE_DOWNSHIFT
;
}
ret_val
=
e1e_wphy
(
hw
,
M88E1000_PHY_SPEC_CTRL
,
phy_data
);
if
(
ret_val
)
...
...
drivers/net/ethernet/intel/ixgbevf/defines.h
浏览文件 @
64e771bb
...
...
@@ -40,6 +40,7 @@
typedef
u32
ixgbe_link_speed
;
#define IXGBE_LINK_SPEED_1GB_FULL 0x0020
#define IXGBE_LINK_SPEED_10GB_FULL 0x0080
#define IXGBE_LINK_SPEED_100_FULL 0x0008
#define IXGBE_CTRL_RST 0x04000000
/* Reset (SW) */
#define IXGBE_RXDCTL_ENABLE 0x02000000
/* Enable specific Rx Queue */
...
...
@@ -48,6 +49,7 @@ typedef u32 ixgbe_link_speed;
#define IXGBE_LINKS_SPEED_82599 0x30000000
#define IXGBE_LINKS_SPEED_10G_82599 0x30000000
#define IXGBE_LINKS_SPEED_1G_82599 0x20000000
#define IXGBE_LINKS_SPEED_100_82599 0x10000000
/* Number of Transmit and Receive Descriptors must be a multiple of 8 */
#define IXGBE_REQ_TX_DESCRIPTOR_MULTIPLE 8
...
...
drivers/net/ethernet/intel/ixgbevf/ethtool.c
浏览文件 @
64e771bb
...
...
@@ -107,10 +107,20 @@ static int ixgbevf_get_settings(struct net_device *netdev,
hw
->
mac
.
ops
.
check_link
(
hw
,
&
link_speed
,
&
link_up
,
false
);
if
(
link_up
)
{
ethtool_cmd_speed_set
(
ecmd
,
(
link_speed
==
IXGBE_LINK_SPEED_10GB_FULL
)
?
SPEED_10000
:
SPEED_1000
);
__u32
speed
=
SPEED_10000
;
switch
(
link_speed
)
{
case
IXGBE_LINK_SPEED_10GB_FULL
:
speed
=
SPEED_10000
;
break
;
case
IXGBE_LINK_SPEED_1GB_FULL
:
speed
=
SPEED_1000
;
break
;
case
IXGBE_LINK_SPEED_100_FULL
:
speed
=
SPEED_100
;
break
;
}
ethtool_cmd_speed_set
(
ecmd
,
speed
);
ecmd
->
duplex
=
DUPLEX_FULL
;
}
else
{
ethtool_cmd_speed_set
(
ecmd
,
-
1
);
...
...
drivers/net/ethernet/intel/ixgbevf/ixgbevf.h
浏览文件 @
64e771bb
...
...
@@ -287,7 +287,7 @@ extern const struct ixgbe_mbx_operations ixgbevf_mbx_ops;
extern
const
char
ixgbevf_driver_name
[];
extern
const
char
ixgbevf_driver_version
[];
extern
int
ixgbevf_up
(
struct
ixgbevf_adapter
*
adapter
);
extern
void
ixgbevf_up
(
struct
ixgbevf_adapter
*
adapter
);
extern
void
ixgbevf_down
(
struct
ixgbevf_adapter
*
adapter
);
extern
void
ixgbevf_reinit_locked
(
struct
ixgbevf_adapter
*
adapter
);
extern
void
ixgbevf_reset
(
struct
ixgbevf_adapter
*
adapter
);
...
...
drivers/net/ethernet/intel/ixgbevf/ixgbevf_main.c
浏览文件 @
64e771bb
...
...
@@ -57,7 +57,7 @@ const char ixgbevf_driver_name[] = "ixgbevf";
static
const
char
ixgbevf_driver_string
[]
=
"Intel(R) 10 Gigabit PCI Express Virtual Function Network Driver"
;
#define DRV_VERSION "2.
2
.0-k"
#define DRV_VERSION "2.
6
.0-k"
const
char
ixgbevf_driver_version
[]
=
DRV_VERSION
;
static
char
ixgbevf_copyright
[]
=
"Copyright (c) 2009 - 2012 Intel Corporation."
;
...
...
@@ -1608,13 +1608,14 @@ static void ixgbevf_init_last_counter_stats(struct ixgbevf_adapter *adapter)
adapter
->
stats
.
base_vfmprc
=
adapter
->
stats
.
last_vfmprc
;
}
static
int
ixgbevf_up_complete
(
struct
ixgbevf_adapter
*
adapter
)
static
void
ixgbevf_up_complete
(
struct
ixgbevf_adapter
*
adapter
)
{
struct
net_device
*
netdev
=
adapter
->
netdev
;
struct
ixgbe_hw
*
hw
=
&
adapter
->
hw
;
int
i
,
j
=
0
;
int
num_rx_rings
=
adapter
->
num_rx_queues
;
u32
txdctl
,
rxdctl
;
u32
msg
[
2
];
for
(
i
=
0
;
i
<
adapter
->
num_tx_queues
;
i
++
)
{
j
=
adapter
->
tx_ring
[
i
].
reg_idx
;
...
...
@@ -1653,6 +1654,10 @@ static int ixgbevf_up_complete(struct ixgbevf_adapter *adapter)
hw
->
mac
.
ops
.
set_rar
(
hw
,
0
,
hw
->
mac
.
perm_addr
,
0
);
}
msg
[
0
]
=
IXGBE_VF_SET_LPE
;
msg
[
1
]
=
netdev
->
mtu
+
ETH_HLEN
+
ETH_FCS_LEN
;
hw
->
mbx
.
ops
.
write_posted
(
hw
,
msg
,
2
);
clear_bit
(
__IXGBEVF_DOWN
,
&
adapter
->
state
);
ixgbevf_napi_enable_all
(
adapter
);
...
...
@@ -1667,24 +1672,20 @@ static int ixgbevf_up_complete(struct ixgbevf_adapter *adapter)
adapter
->
flags
|=
IXGBE_FLAG_NEED_LINK_UPDATE
;
adapter
->
link_check_timeout
=
jiffies
;
mod_timer
(
&
adapter
->
watchdog_timer
,
jiffies
);
return
0
;
}
int
ixgbevf_up
(
struct
ixgbevf_adapter
*
adapter
)
void
ixgbevf_up
(
struct
ixgbevf_adapter
*
adapter
)
{
int
err
;
struct
ixgbe_hw
*
hw
=
&
adapter
->
hw
;
ixgbevf_configure
(
adapter
);
err
=
ixgbevf_up_complete
(
adapter
);
ixgbevf_up_complete
(
adapter
);
/* clear any pending interrupts, may auto mask */
IXGBE_READ_REG
(
hw
,
IXGBE_VTEICR
);
ixgbevf_irq_enable
(
adapter
,
true
,
true
);
return
err
;
}
/**
...
...
@@ -2673,9 +2674,7 @@ static int ixgbevf_open(struct net_device *netdev)
*/
ixgbevf_map_rings_to_vectors
(
adapter
);
err
=
ixgbevf_up_complete
(
adapter
);
if
(
err
)
goto
err_up
;
ixgbevf_up_complete
(
adapter
);
/* clear any pending interrupts, may auto mask */
IXGBE_READ_REG
(
hw
,
IXGBE_VTEICR
);
...
...
@@ -2689,7 +2688,6 @@ static int ixgbevf_open(struct net_device *netdev)
err_req_irq:
ixgbevf_down
(
adapter
);
err_up:
ixgbevf_free_irq
(
adapter
);
err_setup_rx:
ixgbevf_free_all_rx_resources
(
adapter
);
...
...
@@ -3196,9 +3194,11 @@ static int ixgbevf_change_mtu(struct net_device *netdev, int new_mtu)
/* must set new MTU before calling down or up */
netdev
->
mtu
=
new_mtu
;
msg
[
0
]
=
IXGBE_VF_SET_LPE
;
msg
[
1
]
=
max_frame
;
hw
->
mbx
.
ops
.
write_posted
(
hw
,
msg
,
2
);
if
(
!
netif_running
(
netdev
))
{
msg
[
0
]
=
IXGBE_VF_SET_LPE
;
msg
[
1
]
=
max_frame
;
hw
->
mbx
.
ops
.
write_posted
(
hw
,
msg
,
2
);
}
if
(
netif_running
(
netdev
))
ixgbevf_reinit_locked
(
adapter
);
...
...
drivers/net/ethernet/intel/ixgbevf/vf.c
浏览文件 @
64e771bb
...
...
@@ -404,11 +404,17 @@ static s32 ixgbevf_check_mac_link_vf(struct ixgbe_hw *hw,
else
*
link_up
=
false
;
if
((
links_reg
&
IXGBE_LINKS_SPEED_82599
)
==
IXGBE_LINKS_SPEED_10G_82599
)
switch
(
links_reg
&
IXGBE_LINKS_SPEED_82599
)
{
case
IXGBE_LINKS_SPEED_10G_82599
:
*
speed
=
IXGBE_LINK_SPEED_10GB_FULL
;
else
break
;
case
IXGBE_LINKS_SPEED_1G_82599
:
*
speed
=
IXGBE_LINK_SPEED_1GB_FULL
;
break
;
case
IXGBE_LINKS_SPEED_100_82599
:
*
speed
=
IXGBE_LINK_SPEED_100_FULL
;
break
;
}
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录