diff options
85 files changed, 828 insertions, 355 deletions
diff --git a/Documentation/networking/filter.txt b/Documentation/networking/filter.txt index c48a9704bda8..d16f424c5e8d 100644 --- a/Documentation/networking/filter.txt +++ b/Documentation/networking/filter.txt | |||
| @@ -462,9 +462,9 @@ JIT compiler | |||
| 462 | ------------ | 462 | ------------ |
| 463 | 463 | ||
| 464 | The Linux kernel has a built-in BPF JIT compiler for x86_64, SPARC, PowerPC, | 464 | The Linux kernel has a built-in BPF JIT compiler for x86_64, SPARC, PowerPC, |
| 465 | ARM and s390 and can be enabled through CONFIG_BPF_JIT. The JIT compiler is | 465 | ARM, MIPS and s390 and can be enabled through CONFIG_BPF_JIT. The JIT compiler |
| 466 | transparently invoked for each attached filter from user space or for internal | 466 | is transparently invoked for each attached filter from user space or for |
| 467 | kernel users if it has been previously enabled by root: | 467 | internal kernel users if it has been previously enabled by root: |
| 468 | 468 | ||
| 469 | echo 1 > /proc/sys/net/core/bpf_jit_enable | 469 | echo 1 > /proc/sys/net/core/bpf_jit_enable |
| 470 | 470 | ||
diff --git a/arch/sparc/net/bpf_jit_comp.c b/arch/sparc/net/bpf_jit_comp.c index 1f76c22a6a75..51ae87b483e0 100644 --- a/arch/sparc/net/bpf_jit_comp.c +++ b/arch/sparc/net/bpf_jit_comp.c | |||
| @@ -234,12 +234,18 @@ do { BUILD_BUG_ON(FIELD_SIZEOF(STRUCT, FIELD) != sizeof(u8)); \ | |||
| 234 | __emit_load8(BASE, STRUCT, FIELD, DEST); \ | 234 | __emit_load8(BASE, STRUCT, FIELD, DEST); \ |
| 235 | } while (0) | 235 | } while (0) |
| 236 | 236 | ||
| 237 | #define emit_ldmem(OFF, DEST) \ | 237 | #ifdef CONFIG_SPARC64 |
| 238 | do { *prog++ = LD32I | RS1(FP) | S13(-(OFF)) | RD(DEST); \ | 238 | #define BIAS (STACK_BIAS - 4) |
| 239 | #else | ||
| 240 | #define BIAS (-4) | ||
| 241 | #endif | ||
| 242 | |||
| 243 | #define emit_ldmem(OFF, DEST) \ | ||
| 244 | do { *prog++ = LD32I | RS1(SP) | S13(BIAS - (OFF)) | RD(DEST); \ | ||
| 239 | } while (0) | 245 | } while (0) |
| 240 | 246 | ||
| 241 | #define emit_stmem(OFF, SRC) \ | 247 | #define emit_stmem(OFF, SRC) \ |
| 242 | do { *prog++ = LD32I | RS1(FP) | S13(-(OFF)) | RD(SRC); \ | 248 | do { *prog++ = ST32I | RS1(SP) | S13(BIAS - (OFF)) | RD(SRC); \ |
| 243 | } while (0) | 249 | } while (0) |
| 244 | 250 | ||
| 245 | #ifdef CONFIG_SMP | 251 | #ifdef CONFIG_SMP |
| @@ -615,10 +621,11 @@ void bpf_jit_compile(struct bpf_prog *fp) | |||
| 615 | case BPF_ANC | SKF_AD_VLAN_TAG: | 621 | case BPF_ANC | SKF_AD_VLAN_TAG: |
| 616 | case BPF_ANC | SKF_AD_VLAN_TAG_PRESENT: | 622 | case BPF_ANC | SKF_AD_VLAN_TAG_PRESENT: |
| 617 | emit_skb_load16(vlan_tci, r_A); | 623 | emit_skb_load16(vlan_tci, r_A); |
| 618 | if (code == (BPF_ANC | SKF_AD_VLAN_TAG)) { | 624 | if (code != (BPF_ANC | SKF_AD_VLAN_TAG)) { |
| 619 | emit_andi(r_A, VLAN_VID_MASK, r_A); | 625 | emit_alu_K(SRL, 12); |
| 626 | emit_andi(r_A, 1, r_A); | ||
| 620 | } else { | 627 | } else { |
| 621 | emit_loadimm(VLAN_TAG_PRESENT, r_TMP); | 628 | emit_loadimm(~VLAN_TAG_PRESENT, r_TMP); |
| 622 | emit_and(r_A, r_TMP, r_A); | 629 | emit_and(r_A, r_TMP, r_A); |
| 623 | } | 630 | } |
| 624 | break; | 631 | break; |
| @@ -630,15 +637,19 @@ void bpf_jit_compile(struct bpf_prog *fp) | |||
| 630 | emit_loadimm(K, r_X); | 637 | emit_loadimm(K, r_X); |
| 631 | break; | 638 | break; |
| 632 | case BPF_LD | BPF_MEM: | 639 | case BPF_LD | BPF_MEM: |
| 640 | seen |= SEEN_MEM; | ||
| 633 | emit_ldmem(K * 4, r_A); | 641 | emit_ldmem(K * 4, r_A); |
| 634 | break; | 642 | break; |
| 635 | case BPF_LDX | BPF_MEM: | 643 | case BPF_LDX | BPF_MEM: |
| 644 | seen |= SEEN_MEM | SEEN_XREG; | ||
| 636 | emit_ldmem(K * 4, r_X); | 645 | emit_ldmem(K * 4, r_X); |
| 637 | break; | 646 | break; |
| 638 | case BPF_ST: | 647 | case BPF_ST: |
| 648 | seen |= SEEN_MEM; | ||
| 639 | emit_stmem(K * 4, r_A); | 649 | emit_stmem(K * 4, r_A); |
| 640 | break; | 650 | break; |
| 641 | case BPF_STX: | 651 | case BPF_STX: |
| 652 | seen |= SEEN_MEM | SEEN_XREG; | ||
| 642 | emit_stmem(K * 4, r_X); | 653 | emit_stmem(K * 4, r_X); |
| 643 | break; | 654 | break; |
| 644 | 655 | ||
diff --git a/drivers/infiniband/hw/mlx4/main.c b/drivers/infiniband/hw/mlx4/main.c index af8256353c7d..162b82c1dde4 100644 --- a/drivers/infiniband/hw/mlx4/main.c +++ b/drivers/infiniband/hw/mlx4/main.c | |||
| @@ -1680,7 +1680,7 @@ static void mlx4_ib_update_qps(struct mlx4_ib_dev *ibdev, | |||
| 1680 | goto unlock; | 1680 | goto unlock; |
| 1681 | 1681 | ||
| 1682 | update_params.smac_index = new_smac_index; | 1682 | update_params.smac_index = new_smac_index; |
| 1683 | if (mlx4_update_qp(ibdev->dev, &qp->mqp, MLX4_UPDATE_QP_SMAC, | 1683 | if (mlx4_update_qp(ibdev->dev, qp->mqp.qpn, MLX4_UPDATE_QP_SMAC, |
| 1684 | &update_params)) { | 1684 | &update_params)) { |
| 1685 | release_mac = new_smac; | 1685 | release_mac = new_smac; |
| 1686 | goto unlock; | 1686 | goto unlock; |
diff --git a/drivers/infiniband/hw/mlx4/qp.c b/drivers/infiniband/hw/mlx4/qp.c index efb9eff8906c..836503927dea 100644 --- a/drivers/infiniband/hw/mlx4/qp.c +++ b/drivers/infiniband/hw/mlx4/qp.c | |||
| @@ -1682,7 +1682,7 @@ static int __mlx4_ib_modify_qp(struct ib_qp *ibqp, | |||
| 1682 | MLX4_IB_LINK_TYPE_ETH; | 1682 | MLX4_IB_LINK_TYPE_ETH; |
| 1683 | if (dev->dev->caps.tunnel_offload_mode == MLX4_TUNNEL_OFFLOAD_MODE_VXLAN) { | 1683 | if (dev->dev->caps.tunnel_offload_mode == MLX4_TUNNEL_OFFLOAD_MODE_VXLAN) { |
| 1684 | /* set QP to receive both tunneled & non-tunneled packets */ | 1684 | /* set QP to receive both tunneled & non-tunneled packets */ |
| 1685 | if (!(context->flags & (1 << MLX4_RSS_QPC_FLAG_OFFSET))) | 1685 | if (!(context->flags & cpu_to_be32(1 << MLX4_RSS_QPC_FLAG_OFFSET))) |
| 1686 | context->srqn = cpu_to_be32(7 << 28); | 1686 | context->srqn = cpu_to_be32(7 << 28); |
| 1687 | } | 1687 | } |
| 1688 | } | 1688 | } |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib.h b/drivers/infiniband/ulp/ipoib/ipoib.h index 3edce617c31b..d7562beb5423 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib.h +++ b/drivers/infiniband/ulp/ipoib/ipoib.h | |||
| @@ -131,6 +131,12 @@ struct ipoib_cb { | |||
| 131 | u8 hwaddr[INFINIBAND_ALEN]; | 131 | u8 hwaddr[INFINIBAND_ALEN]; |
| 132 | }; | 132 | }; |
| 133 | 133 | ||
| 134 | static inline struct ipoib_cb *ipoib_skb_cb(const struct sk_buff *skb) | ||
| 135 | { | ||
| 136 | BUILD_BUG_ON(sizeof(skb->cb) < sizeof(struct ipoib_cb)); | ||
| 137 | return (struct ipoib_cb *)skb->cb; | ||
| 138 | } | ||
| 139 | |||
| 134 | /* Used for all multicast joins (broadcast, IPv4 mcast and IPv6 mcast) */ | 140 | /* Used for all multicast joins (broadcast, IPv4 mcast and IPv6 mcast) */ |
| 135 | struct ipoib_mcast { | 141 | struct ipoib_mcast { |
| 136 | struct ib_sa_mcmember_rec mcmember; | 142 | struct ib_sa_mcmember_rec mcmember; |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_main.c b/drivers/infiniband/ulp/ipoib/ipoib_main.c index 1310acf6bf92..13e6e0431592 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_main.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_main.c | |||
| @@ -716,7 +716,7 @@ static int ipoib_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 716 | { | 716 | { |
| 717 | struct ipoib_dev_priv *priv = netdev_priv(dev); | 717 | struct ipoib_dev_priv *priv = netdev_priv(dev); |
| 718 | struct ipoib_neigh *neigh; | 718 | struct ipoib_neigh *neigh; |
| 719 | struct ipoib_cb *cb = (struct ipoib_cb *) skb->cb; | 719 | struct ipoib_cb *cb = ipoib_skb_cb(skb); |
| 720 | struct ipoib_header *header; | 720 | struct ipoib_header *header; |
| 721 | unsigned long flags; | 721 | unsigned long flags; |
| 722 | 722 | ||
| @@ -813,7 +813,7 @@ static int ipoib_hard_header(struct sk_buff *skb, | |||
| 813 | const void *daddr, const void *saddr, unsigned len) | 813 | const void *daddr, const void *saddr, unsigned len) |
| 814 | { | 814 | { |
| 815 | struct ipoib_header *header; | 815 | struct ipoib_header *header; |
| 816 | struct ipoib_cb *cb = (struct ipoib_cb *) skb->cb; | 816 | struct ipoib_cb *cb = ipoib_skb_cb(skb); |
| 817 | 817 | ||
| 818 | header = (struct ipoib_header *) skb_push(skb, sizeof *header); | 818 | header = (struct ipoib_header *) skb_push(skb, sizeof *header); |
| 819 | 819 | ||
diff --git a/drivers/message/fusion/Kconfig b/drivers/message/fusion/Kconfig index a34a11d2fef2..63ca9841db10 100644 --- a/drivers/message/fusion/Kconfig +++ b/drivers/message/fusion/Kconfig | |||
| @@ -29,7 +29,7 @@ config FUSION_SPI | |||
| 29 | config FUSION_FC | 29 | config FUSION_FC |
| 30 | tristate "Fusion MPT ScsiHost drivers for FC" | 30 | tristate "Fusion MPT ScsiHost drivers for FC" |
| 31 | depends on PCI && SCSI | 31 | depends on PCI && SCSI |
| 32 | select SCSI_FC_ATTRS | 32 | depends on SCSI_FC_ATTRS |
| 33 | ---help--- | 33 | ---help--- |
| 34 | SCSI HOST support for a Fiber Channel host adapters. | 34 | SCSI HOST support for a Fiber Channel host adapters. |
| 35 | 35 | ||
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index f0f5eab0fab1..798ae69fb63c 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
| @@ -175,7 +175,7 @@ MODULE_PARM_DESC(fail_over_mac, "For active-backup, do not set all slaves to " | |||
| 175 | "the same MAC; 0 for none (default), " | 175 | "the same MAC; 0 for none (default), " |
| 176 | "1 for active, 2 for follow"); | 176 | "1 for active, 2 for follow"); |
| 177 | module_param(all_slaves_active, int, 0); | 177 | module_param(all_slaves_active, int, 0); |
| 178 | MODULE_PARM_DESC(all_slaves_active, "Keep all frames received on an interface" | 178 | MODULE_PARM_DESC(all_slaves_active, "Keep all frames received on an interface " |
| 179 | "by setting active flag for all slaves; " | 179 | "by setting active flag for all slaves; " |
| 180 | "0 for never (default), 1 for always."); | 180 | "0 for never (default), 1 for always."); |
| 181 | module_param(resend_igmp, int, 0); | 181 | module_param(resend_igmp, int, 0); |
| @@ -3659,8 +3659,14 @@ static int bond_xmit_roundrobin(struct sk_buff *skb, struct net_device *bond_dev | |||
| 3659 | else | 3659 | else |
| 3660 | bond_xmit_slave_id(bond, skb, 0); | 3660 | bond_xmit_slave_id(bond, skb, 0); |
| 3661 | } else { | 3661 | } else { |
| 3662 | slave_id = bond_rr_gen_slave_id(bond); | 3662 | int slave_cnt = ACCESS_ONCE(bond->slave_cnt); |
| 3663 | bond_xmit_slave_id(bond, skb, slave_id % bond->slave_cnt); | 3663 | |
| 3664 | if (likely(slave_cnt)) { | ||
| 3665 | slave_id = bond_rr_gen_slave_id(bond); | ||
| 3666 | bond_xmit_slave_id(bond, skb, slave_id % slave_cnt); | ||
| 3667 | } else { | ||
| 3668 | dev_kfree_skb_any(skb); | ||
| 3669 | } | ||
| 3664 | } | 3670 | } |
| 3665 | 3671 | ||
| 3666 | return NETDEV_TX_OK; | 3672 | return NETDEV_TX_OK; |
| @@ -3691,8 +3697,13 @@ static int bond_xmit_activebackup(struct sk_buff *skb, struct net_device *bond_d | |||
| 3691 | static int bond_xmit_xor(struct sk_buff *skb, struct net_device *bond_dev) | 3697 | static int bond_xmit_xor(struct sk_buff *skb, struct net_device *bond_dev) |
| 3692 | { | 3698 | { |
| 3693 | struct bonding *bond = netdev_priv(bond_dev); | 3699 | struct bonding *bond = netdev_priv(bond_dev); |
| 3700 | int slave_cnt = ACCESS_ONCE(bond->slave_cnt); | ||
| 3694 | 3701 | ||
| 3695 | bond_xmit_slave_id(bond, skb, bond_xmit_hash(bond, skb) % bond->slave_cnt); | 3702 | if (likely(slave_cnt)) |
| 3703 | bond_xmit_slave_id(bond, skb, | ||
| 3704 | bond_xmit_hash(bond, skb) % slave_cnt); | ||
| 3705 | else | ||
| 3706 | dev_kfree_skb_any(skb); | ||
| 3696 | 3707 | ||
| 3697 | return NETDEV_TX_OK; | 3708 | return NETDEV_TX_OK; |
| 3698 | } | 3709 | } |
diff --git a/drivers/net/can/at91_can.c b/drivers/net/can/at91_can.c index f07fa89b5fd5..05e1aa090add 100644 --- a/drivers/net/can/at91_can.c +++ b/drivers/net/can/at91_can.c | |||
| @@ -1123,7 +1123,9 @@ static int at91_open(struct net_device *dev) | |||
| 1123 | struct at91_priv *priv = netdev_priv(dev); | 1123 | struct at91_priv *priv = netdev_priv(dev); |
| 1124 | int err; | 1124 | int err; |
| 1125 | 1125 | ||
| 1126 | clk_enable(priv->clk); | 1126 | err = clk_prepare_enable(priv->clk); |
| 1127 | if (err) | ||
| 1128 | return err; | ||
| 1127 | 1129 | ||
| 1128 | /* check or determine and set bittime */ | 1130 | /* check or determine and set bittime */ |
| 1129 | err = open_candev(dev); | 1131 | err = open_candev(dev); |
| @@ -1149,7 +1151,7 @@ static int at91_open(struct net_device *dev) | |||
| 1149 | out_close: | 1151 | out_close: |
| 1150 | close_candev(dev); | 1152 | close_candev(dev); |
| 1151 | out: | 1153 | out: |
| 1152 | clk_disable(priv->clk); | 1154 | clk_disable_unprepare(priv->clk); |
| 1153 | 1155 | ||
| 1154 | return err; | 1156 | return err; |
| 1155 | } | 1157 | } |
| @@ -1166,7 +1168,7 @@ static int at91_close(struct net_device *dev) | |||
| 1166 | at91_chip_stop(dev, CAN_STATE_STOPPED); | 1168 | at91_chip_stop(dev, CAN_STATE_STOPPED); |
| 1167 | 1169 | ||
| 1168 | free_irq(dev->irq, dev); | 1170 | free_irq(dev->irq, dev); |
| 1169 | clk_disable(priv->clk); | 1171 | clk_disable_unprepare(priv->clk); |
| 1170 | 1172 | ||
| 1171 | close_candev(dev); | 1173 | close_candev(dev); |
| 1172 | 1174 | ||
diff --git a/drivers/net/can/c_can/c_can_platform.c b/drivers/net/can/c_can/c_can_platform.c index 109cb44291f5..fb279d6ae484 100644 --- a/drivers/net/can/c_can/c_can_platform.c +++ b/drivers/net/can/c_can/c_can_platform.c | |||
| @@ -97,14 +97,14 @@ static void c_can_hw_raminit_ti(const struct c_can_priv *priv, bool enable) | |||
| 97 | ctrl |= CAN_RAMINIT_DONE_MASK(priv->instance); | 97 | ctrl |= CAN_RAMINIT_DONE_MASK(priv->instance); |
| 98 | writel(ctrl, priv->raminit_ctrlreg); | 98 | writel(ctrl, priv->raminit_ctrlreg); |
| 99 | ctrl &= ~CAN_RAMINIT_DONE_MASK(priv->instance); | 99 | ctrl &= ~CAN_RAMINIT_DONE_MASK(priv->instance); |
| 100 | c_can_hw_raminit_wait_ti(priv, ctrl, mask); | 100 | c_can_hw_raminit_wait_ti(priv, mask, ctrl); |
| 101 | 101 | ||
| 102 | if (enable) { | 102 | if (enable) { |
| 103 | /* Set start bit and wait for the done bit. */ | 103 | /* Set start bit and wait for the done bit. */ |
| 104 | ctrl |= CAN_RAMINIT_START_MASK(priv->instance); | 104 | ctrl |= CAN_RAMINIT_START_MASK(priv->instance); |
| 105 | writel(ctrl, priv->raminit_ctrlreg); | 105 | writel(ctrl, priv->raminit_ctrlreg); |
| 106 | ctrl |= CAN_RAMINIT_DONE_MASK(priv->instance); | 106 | ctrl |= CAN_RAMINIT_DONE_MASK(priv->instance); |
| 107 | c_can_hw_raminit_wait_ti(priv, ctrl, mask); | 107 | c_can_hw_raminit_wait_ti(priv, mask, ctrl); |
| 108 | } | 108 | } |
| 109 | spin_unlock(&raminit_lock); | 109 | spin_unlock(&raminit_lock); |
| 110 | } | 110 | } |
diff --git a/drivers/net/can/flexcan.c b/drivers/net/can/flexcan.c index 944aa5d3af6e..6586309329e6 100644 --- a/drivers/net/can/flexcan.c +++ b/drivers/net/can/flexcan.c | |||
| @@ -62,7 +62,7 @@ | |||
| 62 | #define FLEXCAN_MCR_BCC BIT(16) | 62 | #define FLEXCAN_MCR_BCC BIT(16) |
| 63 | #define FLEXCAN_MCR_LPRIO_EN BIT(13) | 63 | #define FLEXCAN_MCR_LPRIO_EN BIT(13) |
| 64 | #define FLEXCAN_MCR_AEN BIT(12) | 64 | #define FLEXCAN_MCR_AEN BIT(12) |
| 65 | #define FLEXCAN_MCR_MAXMB(x) ((x) & 0x1f) | 65 | #define FLEXCAN_MCR_MAXMB(x) ((x) & 0x7f) |
| 66 | #define FLEXCAN_MCR_IDAM_A (0 << 8) | 66 | #define FLEXCAN_MCR_IDAM_A (0 << 8) |
| 67 | #define FLEXCAN_MCR_IDAM_B (1 << 8) | 67 | #define FLEXCAN_MCR_IDAM_B (1 << 8) |
| 68 | #define FLEXCAN_MCR_IDAM_C (2 << 8) | 68 | #define FLEXCAN_MCR_IDAM_C (2 << 8) |
| @@ -125,7 +125,9 @@ | |||
| 125 | FLEXCAN_ESR_BOFF_INT | FLEXCAN_ESR_ERR_INT) | 125 | FLEXCAN_ESR_BOFF_INT | FLEXCAN_ESR_ERR_INT) |
| 126 | 126 | ||
| 127 | /* FLEXCAN interrupt flag register (IFLAG) bits */ | 127 | /* FLEXCAN interrupt flag register (IFLAG) bits */ |
| 128 | #define FLEXCAN_TX_BUF_ID 8 | 128 | /* Errata ERR005829 step7: Reserve first valid MB */ |
| 129 | #define FLEXCAN_TX_BUF_RESERVED 8 | ||
| 130 | #define FLEXCAN_TX_BUF_ID 9 | ||
| 129 | #define FLEXCAN_IFLAG_BUF(x) BIT(x) | 131 | #define FLEXCAN_IFLAG_BUF(x) BIT(x) |
| 130 | #define FLEXCAN_IFLAG_RX_FIFO_OVERFLOW BIT(7) | 132 | #define FLEXCAN_IFLAG_RX_FIFO_OVERFLOW BIT(7) |
| 131 | #define FLEXCAN_IFLAG_RX_FIFO_WARN BIT(6) | 133 | #define FLEXCAN_IFLAG_RX_FIFO_WARN BIT(6) |
| @@ -136,6 +138,17 @@ | |||
| 136 | 138 | ||
| 137 | /* FLEXCAN message buffers */ | 139 | /* FLEXCAN message buffers */ |
| 138 | #define FLEXCAN_MB_CNT_CODE(x) (((x) & 0xf) << 24) | 140 | #define FLEXCAN_MB_CNT_CODE(x) (((x) & 0xf) << 24) |
| 141 | #define FLEXCAN_MB_CODE_RX_INACTIVE (0x0 << 24) | ||
| 142 | #define FLEXCAN_MB_CODE_RX_EMPTY (0x4 << 24) | ||
| 143 | #define FLEXCAN_MB_CODE_RX_FULL (0x2 << 24) | ||
| 144 | #define FLEXCAN_MB_CODE_RX_OVERRRUN (0x6 << 24) | ||
| 145 | #define FLEXCAN_MB_CODE_RX_RANSWER (0xa << 24) | ||
| 146 | |||
| 147 | #define FLEXCAN_MB_CODE_TX_INACTIVE (0x8 << 24) | ||
| 148 | #define FLEXCAN_MB_CODE_TX_ABORT (0x9 << 24) | ||
| 149 | #define FLEXCAN_MB_CODE_TX_DATA (0xc << 24) | ||
| 150 | #define FLEXCAN_MB_CODE_TX_TANSWER (0xe << 24) | ||
| 151 | |||
| 139 | #define FLEXCAN_MB_CNT_SRR BIT(22) | 152 | #define FLEXCAN_MB_CNT_SRR BIT(22) |
| 140 | #define FLEXCAN_MB_CNT_IDE BIT(21) | 153 | #define FLEXCAN_MB_CNT_IDE BIT(21) |
| 141 | #define FLEXCAN_MB_CNT_RTR BIT(20) | 154 | #define FLEXCAN_MB_CNT_RTR BIT(20) |
| @@ -298,7 +311,7 @@ static int flexcan_chip_enable(struct flexcan_priv *priv) | |||
| 298 | flexcan_write(reg, ®s->mcr); | 311 | flexcan_write(reg, ®s->mcr); |
| 299 | 312 | ||
| 300 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) | 313 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) |
| 301 | usleep_range(10, 20); | 314 | udelay(10); |
| 302 | 315 | ||
| 303 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK) | 316 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK) |
| 304 | return -ETIMEDOUT; | 317 | return -ETIMEDOUT; |
| @@ -317,7 +330,7 @@ static int flexcan_chip_disable(struct flexcan_priv *priv) | |||
| 317 | flexcan_write(reg, ®s->mcr); | 330 | flexcan_write(reg, ®s->mcr); |
| 318 | 331 | ||
| 319 | while (timeout-- && !(flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) | 332 | while (timeout-- && !(flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) |
| 320 | usleep_range(10, 20); | 333 | udelay(10); |
| 321 | 334 | ||
| 322 | if (!(flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) | 335 | if (!(flexcan_read(®s->mcr) & FLEXCAN_MCR_LPM_ACK)) |
| 323 | return -ETIMEDOUT; | 336 | return -ETIMEDOUT; |
| @@ -336,7 +349,7 @@ static int flexcan_chip_freeze(struct flexcan_priv *priv) | |||
| 336 | flexcan_write(reg, ®s->mcr); | 349 | flexcan_write(reg, ®s->mcr); |
| 337 | 350 | ||
| 338 | while (timeout-- && !(flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) | 351 | while (timeout-- && !(flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) |
| 339 | usleep_range(100, 200); | 352 | udelay(100); |
| 340 | 353 | ||
| 341 | if (!(flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) | 354 | if (!(flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) |
| 342 | return -ETIMEDOUT; | 355 | return -ETIMEDOUT; |
| @@ -355,7 +368,7 @@ static int flexcan_chip_unfreeze(struct flexcan_priv *priv) | |||
| 355 | flexcan_write(reg, ®s->mcr); | 368 | flexcan_write(reg, ®s->mcr); |
| 356 | 369 | ||
| 357 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) | 370 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK)) |
| 358 | usleep_range(10, 20); | 371 | udelay(10); |
| 359 | 372 | ||
| 360 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK) | 373 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_FRZ_ACK) |
| 361 | return -ETIMEDOUT; | 374 | return -ETIMEDOUT; |
| @@ -370,7 +383,7 @@ static int flexcan_chip_softreset(struct flexcan_priv *priv) | |||
| 370 | 383 | ||
| 371 | flexcan_write(FLEXCAN_MCR_SOFTRST, ®s->mcr); | 384 | flexcan_write(FLEXCAN_MCR_SOFTRST, ®s->mcr); |
| 372 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_SOFTRST)) | 385 | while (timeout-- && (flexcan_read(®s->mcr) & FLEXCAN_MCR_SOFTRST)) |
| 373 | usleep_range(10, 20); | 386 | udelay(10); |
| 374 | 387 | ||
| 375 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_SOFTRST) | 388 | if (flexcan_read(®s->mcr) & FLEXCAN_MCR_SOFTRST) |
| 376 | return -ETIMEDOUT; | 389 | return -ETIMEDOUT; |
| @@ -428,6 +441,14 @@ static int flexcan_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 428 | flexcan_write(can_id, ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_id); | 441 | flexcan_write(can_id, ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_id); |
| 429 | flexcan_write(ctrl, ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_ctrl); | 442 | flexcan_write(ctrl, ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_ctrl); |
| 430 | 443 | ||
| 444 | /* Errata ERR005829 step8: | ||
| 445 | * Write twice INACTIVE(0x8) code to first MB. | ||
| 446 | */ | ||
| 447 | flexcan_write(FLEXCAN_MB_CODE_TX_INACTIVE, | ||
| 448 | ®s->cantxfg[FLEXCAN_TX_BUF_RESERVED].can_ctrl); | ||
| 449 | flexcan_write(FLEXCAN_MB_CODE_TX_INACTIVE, | ||
| 450 | ®s->cantxfg[FLEXCAN_TX_BUF_RESERVED].can_ctrl); | ||
| 451 | |||
| 431 | return NETDEV_TX_OK; | 452 | return NETDEV_TX_OK; |
| 432 | } | 453 | } |
| 433 | 454 | ||
| @@ -744,6 +765,9 @@ static irqreturn_t flexcan_irq(int irq, void *dev_id) | |||
| 744 | stats->tx_bytes += can_get_echo_skb(dev, 0); | 765 | stats->tx_bytes += can_get_echo_skb(dev, 0); |
| 745 | stats->tx_packets++; | 766 | stats->tx_packets++; |
| 746 | can_led_event(dev, CAN_LED_EVENT_TX); | 767 | can_led_event(dev, CAN_LED_EVENT_TX); |
| 768 | /* after sending a RTR frame mailbox is in RX mode */ | ||
| 769 | flexcan_write(FLEXCAN_MB_CODE_TX_INACTIVE, | ||
| 770 | ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_ctrl); | ||
| 747 | flexcan_write((1 << FLEXCAN_TX_BUF_ID), ®s->iflag1); | 771 | flexcan_write((1 << FLEXCAN_TX_BUF_ID), ®s->iflag1); |
| 748 | netif_wake_queue(dev); | 772 | netif_wake_queue(dev); |
| 749 | } | 773 | } |
| @@ -801,6 +825,7 @@ static int flexcan_chip_start(struct net_device *dev) | |||
| 801 | struct flexcan_regs __iomem *regs = priv->base; | 825 | struct flexcan_regs __iomem *regs = priv->base; |
| 802 | int err; | 826 | int err; |
| 803 | u32 reg_mcr, reg_ctrl; | 827 | u32 reg_mcr, reg_ctrl; |
| 828 | int i; | ||
| 804 | 829 | ||
| 805 | /* enable module */ | 830 | /* enable module */ |
| 806 | err = flexcan_chip_enable(priv); | 831 | err = flexcan_chip_enable(priv); |
| @@ -867,8 +892,18 @@ static int flexcan_chip_start(struct net_device *dev) | |||
| 867 | netdev_dbg(dev, "%s: writing ctrl=0x%08x", __func__, reg_ctrl); | 892 | netdev_dbg(dev, "%s: writing ctrl=0x%08x", __func__, reg_ctrl); |
| 868 | flexcan_write(reg_ctrl, ®s->ctrl); | 893 | flexcan_write(reg_ctrl, ®s->ctrl); |
| 869 | 894 | ||
| 870 | /* Abort any pending TX, mark Mailbox as INACTIVE */ | 895 | /* clear and invalidate all mailboxes first */ |
| 871 | flexcan_write(FLEXCAN_MB_CNT_CODE(0x4), | 896 | for (i = FLEXCAN_TX_BUF_ID; i < ARRAY_SIZE(regs->cantxfg); i++) { |
| 897 | flexcan_write(FLEXCAN_MB_CODE_RX_INACTIVE, | ||
| 898 | ®s->cantxfg[i].can_ctrl); | ||
| 899 | } | ||
| 900 | |||
| 901 | /* Errata ERR005829: mark first TX mailbox as INACTIVE */ | ||
| 902 | flexcan_write(FLEXCAN_MB_CODE_TX_INACTIVE, | ||
| 903 | ®s->cantxfg[FLEXCAN_TX_BUF_RESERVED].can_ctrl); | ||
| 904 | |||
| 905 | /* mark TX mailbox as INACTIVE */ | ||
| 906 | flexcan_write(FLEXCAN_MB_CODE_TX_INACTIVE, | ||
| 872 | ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_ctrl); | 907 | ®s->cantxfg[FLEXCAN_TX_BUF_ID].can_ctrl); |
| 873 | 908 | ||
| 874 | /* acceptance mask/acceptance code (accept everything) */ | 909 | /* acceptance mask/acceptance code (accept everything) */ |
diff --git a/drivers/net/can/sja1000/peak_pci.c b/drivers/net/can/sja1000/peak_pci.c index 7a85590fefb9..e5fac368068a 100644 --- a/drivers/net/can/sja1000/peak_pci.c +++ b/drivers/net/can/sja1000/peak_pci.c | |||
| @@ -70,6 +70,8 @@ struct peak_pci_chan { | |||
| 70 | #define PEAK_PC_104P_DEVICE_ID 0x0006 /* PCAN-PC/104+ cards */ | 70 | #define PEAK_PC_104P_DEVICE_ID 0x0006 /* PCAN-PC/104+ cards */ |
| 71 | #define PEAK_PCI_104E_DEVICE_ID 0x0007 /* PCAN-PCI/104 Express cards */ | 71 | #define PEAK_PCI_104E_DEVICE_ID 0x0007 /* PCAN-PCI/104 Express cards */ |
| 72 | #define PEAK_MPCIE_DEVICE_ID 0x0008 /* The miniPCIe slot cards */ | 72 | #define PEAK_MPCIE_DEVICE_ID 0x0008 /* The miniPCIe slot cards */ |
| 73 | #define PEAK_PCIE_OEM_ID 0x0009 /* PCAN-PCI Express OEM */ | ||
| 74 | #define PEAK_PCIEC34_DEVICE_ID 0x000A /* PCAN-PCI Express 34 (one channel) */ | ||
| 73 | 75 | ||
| 74 | #define PEAK_PCI_CHAN_MAX 4 | 76 | #define PEAK_PCI_CHAN_MAX 4 |
| 75 | 77 | ||
| @@ -87,6 +89,7 @@ static const struct pci_device_id peak_pci_tbl[] = { | |||
| 87 | {PEAK_PCI_VENDOR_ID, PEAK_CPCI_DEVICE_ID, PCI_ANY_ID, PCI_ANY_ID,}, | 89 | {PEAK_PCI_VENDOR_ID, PEAK_CPCI_DEVICE_ID, PCI_ANY_ID, PCI_ANY_ID,}, |
| 88 | #ifdef CONFIG_CAN_PEAK_PCIEC | 90 | #ifdef CONFIG_CAN_PEAK_PCIEC |
| 89 | {PEAK_PCI_VENDOR_ID, PEAK_PCIEC_DEVICE_ID, PCI_ANY_ID, PCI_ANY_ID,}, | 91 | {PEAK_PCI_VENDOR_ID, PEAK_PCIEC_DEVICE_ID, PCI_ANY_ID, PCI_ANY_ID,}, |
| 92 | {PEAK_PCI_VENDOR_ID, PEAK_PCIEC34_DEVICE_ID, PCI_ANY_ID, PCI_ANY_ID,}, | ||
| 90 | #endif | 93 | #endif |
| 91 | {0,} | 94 | {0,} |
| 92 | }; | 95 | }; |
| @@ -653,7 +656,8 @@ static int peak_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 653 | * This must be done *before* register_sja1000dev() but | 656 | * This must be done *before* register_sja1000dev() but |
| 654 | * *after* devices linkage | 657 | * *after* devices linkage |
| 655 | */ | 658 | */ |
| 656 | if (pdev->device == PEAK_PCIEC_DEVICE_ID) { | 659 | if (pdev->device == PEAK_PCIEC_DEVICE_ID || |
| 660 | pdev->device == PEAK_PCIEC34_DEVICE_ID) { | ||
| 657 | err = peak_pciec_probe(pdev, dev); | 661 | err = peak_pciec_probe(pdev, dev); |
| 658 | if (err) { | 662 | if (err) { |
| 659 | dev_err(&pdev->dev, | 663 | dev_err(&pdev->dev, |
diff --git a/drivers/net/ethernet/3com/3c59x.c b/drivers/net/ethernet/3com/3c59x.c index 3fe45c705933..8ca49f04acec 100644 --- a/drivers/net/ethernet/3com/3c59x.c +++ b/drivers/net/ethernet/3com/3c59x.c | |||
| @@ -2129,6 +2129,7 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 2129 | int entry = vp->cur_tx % TX_RING_SIZE; | 2129 | int entry = vp->cur_tx % TX_RING_SIZE; |
| 2130 | struct boom_tx_desc *prev_entry = &vp->tx_ring[(vp->cur_tx-1) % TX_RING_SIZE]; | 2130 | struct boom_tx_desc *prev_entry = &vp->tx_ring[(vp->cur_tx-1) % TX_RING_SIZE]; |
| 2131 | unsigned long flags; | 2131 | unsigned long flags; |
| 2132 | dma_addr_t dma_addr; | ||
| 2132 | 2133 | ||
| 2133 | if (vortex_debug > 6) { | 2134 | if (vortex_debug > 6) { |
| 2134 | pr_debug("boomerang_start_xmit()\n"); | 2135 | pr_debug("boomerang_start_xmit()\n"); |
| @@ -2163,24 +2164,48 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 2163 | vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded | AddTCPChksum | AddUDPChksum); | 2164 | vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded | AddTCPChksum | AddUDPChksum); |
| 2164 | 2165 | ||
| 2165 | if (!skb_shinfo(skb)->nr_frags) { | 2166 | if (!skb_shinfo(skb)->nr_frags) { |
| 2166 | vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data, | 2167 | dma_addr = pci_map_single(VORTEX_PCI(vp), skb->data, skb->len, |
| 2167 | skb->len, PCI_DMA_TODEVICE)); | 2168 | PCI_DMA_TODEVICE); |
| 2169 | if (dma_mapping_error(&VORTEX_PCI(vp)->dev, dma_addr)) | ||
| 2170 | goto out_dma_err; | ||
| 2171 | |||
| 2172 | vp->tx_ring[entry].frag[0].addr = cpu_to_le32(dma_addr); | ||
| 2168 | vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len | LAST_FRAG); | 2173 | vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb->len | LAST_FRAG); |
| 2169 | } else { | 2174 | } else { |
| 2170 | int i; | 2175 | int i; |
| 2171 | 2176 | ||
| 2172 | vp->tx_ring[entry].frag[0].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data, | 2177 | dma_addr = pci_map_single(VORTEX_PCI(vp), skb->data, |
| 2173 | skb_headlen(skb), PCI_DMA_TODEVICE)); | 2178 | skb_headlen(skb), PCI_DMA_TODEVICE); |
| 2179 | if (dma_mapping_error(&VORTEX_PCI(vp)->dev, dma_addr)) | ||
| 2180 | goto out_dma_err; | ||
| 2181 | |||
| 2182 | vp->tx_ring[entry].frag[0].addr = cpu_to_le32(dma_addr); | ||
| 2174 | vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb_headlen(skb)); | 2183 | vp->tx_ring[entry].frag[0].length = cpu_to_le32(skb_headlen(skb)); |
| 2175 | 2184 | ||
| 2176 | for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) { | 2185 | for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) { |
| 2177 | skb_frag_t *frag = &skb_shinfo(skb)->frags[i]; | 2186 | skb_frag_t *frag = &skb_shinfo(skb)->frags[i]; |
| 2178 | 2187 | ||
| 2188 | dma_addr = skb_frag_dma_map(&VORTEX_PCI(vp)->dev, frag, | ||
| 2189 | 0, | ||
| 2190 | frag->size, | ||
| 2191 | DMA_TO_DEVICE); | ||
| 2192 | if (dma_mapping_error(&VORTEX_PCI(vp)->dev, dma_addr)) { | ||
| 2193 | for(i = i-1; i >= 0; i--) | ||
| 2194 | dma_unmap_page(&VORTEX_PCI(vp)->dev, | ||
| 2195 | le32_to_cpu(vp->tx_ring[entry].frag[i+1].addr), | ||
| 2196 | le32_to_cpu(vp->tx_ring[entry].frag[i+1].length), | ||
| 2197 | DMA_TO_DEVICE); | ||
| 2198 | |||
| 2199 | pci_unmap_single(VORTEX_PCI(vp), | ||
| 2200 | le32_to_cpu(vp->tx_ring[entry].frag[0].addr), | ||
| 2201 | le32_to_cpu(vp->tx_ring[entry].frag[0].length), | ||
| 2202 | PCI_DMA_TODEVICE); | ||
| 2203 | |||
| 2204 | goto out_dma_err; | ||
| 2205 | } | ||
| 2206 | |||
| 2179 | vp->tx_ring[entry].frag[i+1].addr = | 2207 | vp->tx_ring[entry].frag[i+1].addr = |
| 2180 | cpu_to_le32(skb_frag_dma_map( | 2208 | cpu_to_le32(dma_addr); |
| 2181 | &VORTEX_PCI(vp)->dev, | ||
| 2182 | frag, | ||
| 2183 | frag->page_offset, frag->size, DMA_TO_DEVICE)); | ||
| 2184 | 2209 | ||
| 2185 | if (i == skb_shinfo(skb)->nr_frags-1) | 2210 | if (i == skb_shinfo(skb)->nr_frags-1) |
| 2186 | vp->tx_ring[entry].frag[i+1].length = cpu_to_le32(skb_frag_size(frag)|LAST_FRAG); | 2211 | vp->tx_ring[entry].frag[i+1].length = cpu_to_le32(skb_frag_size(frag)|LAST_FRAG); |
| @@ -2189,7 +2214,10 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 2189 | } | 2214 | } |
| 2190 | } | 2215 | } |
| 2191 | #else | 2216 | #else |
| 2192 | vp->tx_ring[entry].addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data, skb->len, PCI_DMA_TODEVICE)); | 2217 | dma_addr = cpu_to_le32(pci_map_single(VORTEX_PCI(vp), skb->data, skb->len, PCI_DMA_TODEVICE)); |
| 2218 | if (dma_mapping_error(&VORTEX_PCI(vp)->dev, dma_addr)) | ||
| 2219 | goto out_dma_err; | ||
| 2220 | vp->tx_ring[entry].addr = cpu_to_le32(dma_addr); | ||
| 2193 | vp->tx_ring[entry].length = cpu_to_le32(skb->len | LAST_FRAG); | 2221 | vp->tx_ring[entry].length = cpu_to_le32(skb->len | LAST_FRAG); |
| 2194 | vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded); | 2222 | vp->tx_ring[entry].status = cpu_to_le32(skb->len | TxIntrUploaded); |
| 2195 | #endif | 2223 | #endif |
| @@ -2217,7 +2245,11 @@ boomerang_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 2217 | skb_tx_timestamp(skb); | 2245 | skb_tx_timestamp(skb); |
| 2218 | iowrite16(DownUnstall, ioaddr + EL3_CMD); | 2246 | iowrite16(DownUnstall, ioaddr + EL3_CMD); |
| 2219 | spin_unlock_irqrestore(&vp->lock, flags); | 2247 | spin_unlock_irqrestore(&vp->lock, flags); |
| 2248 | out: | ||
| 2220 | return NETDEV_TX_OK; | 2249 | return NETDEV_TX_OK; |
| 2250 | out_dma_err: | ||
| 2251 | dev_err(&VORTEX_PCI(vp)->dev, "Error mapping dma buffer\n"); | ||
| 2252 | goto out; | ||
| 2221 | } | 2253 | } |
| 2222 | 2254 | ||
| 2223 | /* The interrupt handler does all of the Rx thread work and cleans up | 2255 | /* The interrupt handler does all of the Rx thread work and cleans up |
diff --git a/drivers/net/ethernet/arc/emac_main.c b/drivers/net/ethernet/arc/emac_main.c index fe5cfeace6e3..5919394d9f58 100644 --- a/drivers/net/ethernet/arc/emac_main.c +++ b/drivers/net/ethernet/arc/emac_main.c | |||
| @@ -30,6 +30,17 @@ | |||
| 30 | #define DRV_VERSION "1.0" | 30 | #define DRV_VERSION "1.0" |
| 31 | 31 | ||
| 32 | /** | 32 | /** |
| 33 | * arc_emac_tx_avail - Return the number of available slots in the tx ring. | ||
| 34 | * @priv: Pointer to ARC EMAC private data structure. | ||
| 35 | * | ||
| 36 | * returns: the number of slots available for transmission in tx the ring. | ||
| 37 | */ | ||
| 38 | static inline int arc_emac_tx_avail(struct arc_emac_priv *priv) | ||
| 39 | { | ||
| 40 | return (priv->txbd_dirty + TX_BD_NUM - priv->txbd_curr - 1) % TX_BD_NUM; | ||
| 41 | } | ||
| 42 | |||
| 43 | /** | ||
| 33 | * arc_emac_adjust_link - Adjust the PHY link duplex. | 44 | * arc_emac_adjust_link - Adjust the PHY link duplex. |
| 34 | * @ndev: Pointer to the net_device structure. | 45 | * @ndev: Pointer to the net_device structure. |
| 35 | * | 46 | * |
| @@ -180,10 +191,15 @@ static void arc_emac_tx_clean(struct net_device *ndev) | |||
| 180 | txbd->info = 0; | 191 | txbd->info = 0; |
| 181 | 192 | ||
| 182 | *txbd_dirty = (*txbd_dirty + 1) % TX_BD_NUM; | 193 | *txbd_dirty = (*txbd_dirty + 1) % TX_BD_NUM; |
| 183 | |||
| 184 | if (netif_queue_stopped(ndev)) | ||
| 185 | netif_wake_queue(ndev); | ||
| 186 | } | 194 | } |
| 195 | |||
| 196 | /* Ensure that txbd_dirty is visible to tx() before checking | ||
| 197 | * for queue stopped. | ||
| 198 | */ | ||
| 199 | smp_mb(); | ||
| 200 | |||
| 201 | if (netif_queue_stopped(ndev) && arc_emac_tx_avail(priv)) | ||
| 202 | netif_wake_queue(ndev); | ||
| 187 | } | 203 | } |
| 188 | 204 | ||
| 189 | /** | 205 | /** |
| @@ -298,7 +314,7 @@ static int arc_emac_poll(struct napi_struct *napi, int budget) | |||
| 298 | work_done = arc_emac_rx(ndev, budget); | 314 | work_done = arc_emac_rx(ndev, budget); |
| 299 | if (work_done < budget) { | 315 | if (work_done < budget) { |
| 300 | napi_complete(napi); | 316 | napi_complete(napi); |
| 301 | arc_reg_or(priv, R_ENABLE, RXINT_MASK); | 317 | arc_reg_or(priv, R_ENABLE, RXINT_MASK | TXINT_MASK); |
| 302 | } | 318 | } |
| 303 | 319 | ||
| 304 | return work_done; | 320 | return work_done; |
| @@ -327,9 +343,9 @@ static irqreturn_t arc_emac_intr(int irq, void *dev_instance) | |||
| 327 | /* Reset all flags except "MDIO complete" */ | 343 | /* Reset all flags except "MDIO complete" */ |
| 328 | arc_reg_set(priv, R_STATUS, status); | 344 | arc_reg_set(priv, R_STATUS, status); |
| 329 | 345 | ||
| 330 | if (status & RXINT_MASK) { | 346 | if (status & (RXINT_MASK | TXINT_MASK)) { |
| 331 | if (likely(napi_schedule_prep(&priv->napi))) { | 347 | if (likely(napi_schedule_prep(&priv->napi))) { |
| 332 | arc_reg_clr(priv, R_ENABLE, RXINT_MASK); | 348 | arc_reg_clr(priv, R_ENABLE, RXINT_MASK | TXINT_MASK); |
| 333 | __napi_schedule(&priv->napi); | 349 | __napi_schedule(&priv->napi); |
| 334 | } | 350 | } |
| 335 | } | 351 | } |
| @@ -440,7 +456,7 @@ static int arc_emac_open(struct net_device *ndev) | |||
| 440 | arc_reg_set(priv, R_TX_RING, (unsigned int)priv->txbd_dma); | 456 | arc_reg_set(priv, R_TX_RING, (unsigned int)priv->txbd_dma); |
| 441 | 457 | ||
| 442 | /* Enable interrupts */ | 458 | /* Enable interrupts */ |
| 443 | arc_reg_set(priv, R_ENABLE, RXINT_MASK | ERR_MASK); | 459 | arc_reg_set(priv, R_ENABLE, RXINT_MASK | TXINT_MASK | ERR_MASK); |
| 444 | 460 | ||
| 445 | /* Set CONTROL */ | 461 | /* Set CONTROL */ |
| 446 | arc_reg_set(priv, R_CTRL, | 462 | arc_reg_set(priv, R_CTRL, |
| @@ -511,7 +527,7 @@ static int arc_emac_stop(struct net_device *ndev) | |||
| 511 | netif_stop_queue(ndev); | 527 | netif_stop_queue(ndev); |
| 512 | 528 | ||
| 513 | /* Disable interrupts */ | 529 | /* Disable interrupts */ |
| 514 | arc_reg_clr(priv, R_ENABLE, RXINT_MASK | ERR_MASK); | 530 | arc_reg_clr(priv, R_ENABLE, RXINT_MASK | TXINT_MASK | ERR_MASK); |
| 515 | 531 | ||
| 516 | /* Disable EMAC */ | 532 | /* Disable EMAC */ |
| 517 | arc_reg_clr(priv, R_CTRL, EN_MASK); | 533 | arc_reg_clr(priv, R_CTRL, EN_MASK); |
| @@ -574,11 +590,9 @@ static int arc_emac_tx(struct sk_buff *skb, struct net_device *ndev) | |||
| 574 | 590 | ||
| 575 | len = max_t(unsigned int, ETH_ZLEN, skb->len); | 591 | len = max_t(unsigned int, ETH_ZLEN, skb->len); |
| 576 | 592 | ||
| 577 | /* EMAC still holds this buffer in its possession. | 593 | if (unlikely(!arc_emac_tx_avail(priv))) { |
| 578 | * CPU must not modify this buffer descriptor | ||
| 579 | */ | ||
| 580 | if (unlikely((le32_to_cpu(*info) & OWN_MASK) == FOR_EMAC)) { | ||
| 581 | netif_stop_queue(ndev); | 594 | netif_stop_queue(ndev); |
| 595 | netdev_err(ndev, "BUG! Tx Ring full when queue awake!\n"); | ||
| 582 | return NETDEV_TX_BUSY; | 596 | return NETDEV_TX_BUSY; |
| 583 | } | 597 | } |
| 584 | 598 | ||
| @@ -607,12 +621,19 @@ static int arc_emac_tx(struct sk_buff *skb, struct net_device *ndev) | |||
| 607 | /* Increment index to point to the next BD */ | 621 | /* Increment index to point to the next BD */ |
| 608 | *txbd_curr = (*txbd_curr + 1) % TX_BD_NUM; | 622 | *txbd_curr = (*txbd_curr + 1) % TX_BD_NUM; |
| 609 | 623 | ||
| 610 | /* Get "info" of the next BD */ | 624 | /* Ensure that tx_clean() sees the new txbd_curr before |
| 611 | info = &priv->txbd[*txbd_curr].info; | 625 | * checking the queue status. This prevents an unneeded wake |
| 626 | * of the queue in tx_clean(). | ||
| 627 | */ | ||
| 628 | smp_mb(); | ||
| 612 | 629 | ||
| 613 | /* Check if if Tx BD ring is full - next BD is still owned by EMAC */ | 630 | if (!arc_emac_tx_avail(priv)) { |
| 614 | if (unlikely((le32_to_cpu(*info) & OWN_MASK) == FOR_EMAC)) | ||
| 615 | netif_stop_queue(ndev); | 631 | netif_stop_queue(ndev); |
| 632 | /* Refresh tx_dirty */ | ||
| 633 | smp_mb(); | ||
| 634 | if (arc_emac_tx_avail(priv)) | ||
| 635 | netif_start_queue(ndev); | ||
| 636 | } | ||
| 616 | 637 | ||
| 617 | arc_reg_set(priv, R_STATUS, TXPL_MASK); | 638 | arc_reg_set(priv, R_STATUS, TXPL_MASK); |
| 618 | 639 | ||
diff --git a/drivers/net/ethernet/broadcom/b44.c b/drivers/net/ethernet/broadcom/b44.c index 4a7028d65912..d588136b23b9 100644 --- a/drivers/net/ethernet/broadcom/b44.c +++ b/drivers/net/ethernet/broadcom/b44.c | |||
| @@ -1697,7 +1697,7 @@ static struct rtnl_link_stats64 *b44_get_stats64(struct net_device *dev, | |||
| 1697 | hwstat->tx_underruns + | 1697 | hwstat->tx_underruns + |
| 1698 | hwstat->tx_excessive_cols + | 1698 | hwstat->tx_excessive_cols + |
| 1699 | hwstat->tx_late_cols); | 1699 | hwstat->tx_late_cols); |
| 1700 | nstat->multicast = hwstat->tx_multicast_pkts; | 1700 | nstat->multicast = hwstat->rx_multicast_pkts; |
| 1701 | nstat->collisions = hwstat->tx_total_cols; | 1701 | nstat->collisions = hwstat->tx_total_cols; |
| 1702 | 1702 | ||
| 1703 | nstat->rx_length_errors = (hwstat->rx_oversize_pkts + | 1703 | nstat->rx_length_errors = (hwstat->rx_oversize_pkts + |
diff --git a/drivers/net/ethernet/broadcom/bcmsysport.c b/drivers/net/ethernet/broadcom/bcmsysport.c index 6f4e18644bd4..d9b9170ed2fc 100644 --- a/drivers/net/ethernet/broadcom/bcmsysport.c +++ b/drivers/net/ethernet/broadcom/bcmsysport.c | |||
| @@ -534,6 +534,25 @@ static unsigned int bcm_sysport_desc_rx(struct bcm_sysport_priv *priv, | |||
| 534 | while ((processed < to_process) && (processed < budget)) { | 534 | while ((processed < to_process) && (processed < budget)) { |
| 535 | cb = &priv->rx_cbs[priv->rx_read_ptr]; | 535 | cb = &priv->rx_cbs[priv->rx_read_ptr]; |
| 536 | skb = cb->skb; | 536 | skb = cb->skb; |
| 537 | |||
| 538 | processed++; | ||
| 539 | priv->rx_read_ptr++; | ||
| 540 | |||
| 541 | if (priv->rx_read_ptr == priv->num_rx_bds) | ||
| 542 | priv->rx_read_ptr = 0; | ||
| 543 | |||
| 544 | /* We do not have a backing SKB, so we do not a corresponding | ||
| 545 | * DMA mapping for this incoming packet since | ||
| 546 | * bcm_sysport_rx_refill always either has both skb and mapping | ||
| 547 | * or none. | ||
| 548 | */ | ||
| 549 | if (unlikely(!skb)) { | ||
| 550 | netif_err(priv, rx_err, ndev, "out of memory!\n"); | ||
| 551 | ndev->stats.rx_dropped++; | ||
| 552 | ndev->stats.rx_errors++; | ||
| 553 | goto refill; | ||
| 554 | } | ||
| 555 | |||
| 537 | dma_unmap_single(kdev, dma_unmap_addr(cb, dma_addr), | 556 | dma_unmap_single(kdev, dma_unmap_addr(cb, dma_addr), |
| 538 | RX_BUF_LENGTH, DMA_FROM_DEVICE); | 557 | RX_BUF_LENGTH, DMA_FROM_DEVICE); |
| 539 | 558 | ||
| @@ -543,23 +562,11 @@ static unsigned int bcm_sysport_desc_rx(struct bcm_sysport_priv *priv, | |||
| 543 | status = (rsb->rx_status_len >> DESC_STATUS_SHIFT) & | 562 | status = (rsb->rx_status_len >> DESC_STATUS_SHIFT) & |
| 544 | DESC_STATUS_MASK; | 563 | DESC_STATUS_MASK; |
| 545 | 564 | ||
| 546 | processed++; | ||
| 547 | priv->rx_read_ptr++; | ||
| 548 | if (priv->rx_read_ptr == priv->num_rx_bds) | ||
| 549 | priv->rx_read_ptr = 0; | ||
| 550 | |||
| 551 | netif_dbg(priv, rx_status, ndev, | 565 | netif_dbg(priv, rx_status, ndev, |
| 552 | "p=%d, c=%d, rd_ptr=%d, len=%d, flag=0x%04x\n", | 566 | "p=%d, c=%d, rd_ptr=%d, len=%d, flag=0x%04x\n", |
| 553 | p_index, priv->rx_c_index, priv->rx_read_ptr, | 567 | p_index, priv->rx_c_index, priv->rx_read_ptr, |
| 554 | len, status); | 568 | len, status); |
| 555 | 569 | ||
| 556 | if (unlikely(!skb)) { | ||
| 557 | netif_err(priv, rx_err, ndev, "out of memory!\n"); | ||
| 558 | ndev->stats.rx_dropped++; | ||
| 559 | ndev->stats.rx_errors++; | ||
| 560 | goto refill; | ||
| 561 | } | ||
| 562 | |||
| 563 | if (unlikely(!(status & DESC_EOP) || !(status & DESC_SOP))) { | 570 | if (unlikely(!(status & DESC_EOP) || !(status & DESC_SOP))) { |
| 564 | netif_err(priv, rx_status, ndev, "fragmented packet!\n"); | 571 | netif_err(priv, rx_status, ndev, "fragmented packet!\n"); |
| 565 | ndev->stats.rx_dropped++; | 572 | ndev->stats.rx_dropped++; |
diff --git a/drivers/net/ethernet/broadcom/genet/bcmgenet.c b/drivers/net/ethernet/broadcom/genet/bcmgenet.c index 3f9d4de8173c..5cc9cae21ed5 100644 --- a/drivers/net/ethernet/broadcom/genet/bcmgenet.c +++ b/drivers/net/ethernet/broadcom/genet/bcmgenet.c | |||
| @@ -875,6 +875,7 @@ static void __bcmgenet_tx_reclaim(struct net_device *dev, | |||
| 875 | int last_tx_cn, last_c_index, num_tx_bds; | 875 | int last_tx_cn, last_c_index, num_tx_bds; |
| 876 | struct enet_cb *tx_cb_ptr; | 876 | struct enet_cb *tx_cb_ptr; |
| 877 | struct netdev_queue *txq; | 877 | struct netdev_queue *txq; |
| 878 | unsigned int bds_compl; | ||
| 878 | unsigned int c_index; | 879 | unsigned int c_index; |
| 879 | 880 | ||
| 880 | /* Compute how many buffers are transmitted since last xmit call */ | 881 | /* Compute how many buffers are transmitted since last xmit call */ |
| @@ -899,7 +900,9 @@ static void __bcmgenet_tx_reclaim(struct net_device *dev, | |||
| 899 | /* Reclaim transmitted buffers */ | 900 | /* Reclaim transmitted buffers */ |
| 900 | while (last_tx_cn-- > 0) { | 901 | while (last_tx_cn-- > 0) { |
| 901 | tx_cb_ptr = ring->cbs + last_c_index; | 902 | tx_cb_ptr = ring->cbs + last_c_index; |
| 903 | bds_compl = 0; | ||
| 902 | if (tx_cb_ptr->skb) { | 904 | if (tx_cb_ptr->skb) { |
| 905 | bds_compl = skb_shinfo(tx_cb_ptr->skb)->nr_frags + 1; | ||
| 903 | dev->stats.tx_bytes += tx_cb_ptr->skb->len; | 906 | dev->stats.tx_bytes += tx_cb_ptr->skb->len; |
| 904 | dma_unmap_single(&dev->dev, | 907 | dma_unmap_single(&dev->dev, |
| 905 | dma_unmap_addr(tx_cb_ptr, dma_addr), | 908 | dma_unmap_addr(tx_cb_ptr, dma_addr), |
| @@ -916,7 +919,7 @@ static void __bcmgenet_tx_reclaim(struct net_device *dev, | |||
| 916 | dma_unmap_addr_set(tx_cb_ptr, dma_addr, 0); | 919 | dma_unmap_addr_set(tx_cb_ptr, dma_addr, 0); |
| 917 | } | 920 | } |
| 918 | dev->stats.tx_packets++; | 921 | dev->stats.tx_packets++; |
| 919 | ring->free_bds += 1; | 922 | ring->free_bds += bds_compl; |
| 920 | 923 | ||
| 921 | last_c_index++; | 924 | last_c_index++; |
| 922 | last_c_index &= (num_tx_bds - 1); | 925 | last_c_index &= (num_tx_bds - 1); |
| @@ -1274,12 +1277,29 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_priv *priv, | |||
| 1274 | 1277 | ||
| 1275 | while ((rxpktprocessed < rxpkttoprocess) && | 1278 | while ((rxpktprocessed < rxpkttoprocess) && |
| 1276 | (rxpktprocessed < budget)) { | 1279 | (rxpktprocessed < budget)) { |
| 1280 | cb = &priv->rx_cbs[priv->rx_read_ptr]; | ||
| 1281 | skb = cb->skb; | ||
| 1282 | |||
| 1283 | rxpktprocessed++; | ||
| 1284 | |||
| 1285 | priv->rx_read_ptr++; | ||
| 1286 | priv->rx_read_ptr &= (priv->num_rx_bds - 1); | ||
| 1287 | |||
| 1288 | /* We do not have a backing SKB, so we do not have a | ||
| 1289 | * corresponding DMA mapping for this incoming packet since | ||
| 1290 | * bcmgenet_rx_refill always either has both skb and mapping or | ||
| 1291 | * none. | ||
| 1292 | */ | ||
| 1293 | if (unlikely(!skb)) { | ||
| 1294 | dev->stats.rx_dropped++; | ||
| 1295 | dev->stats.rx_errors++; | ||
| 1296 | goto refill; | ||
| 1297 | } | ||
| 1298 | |||
| 1277 | /* Unmap the packet contents such that we can use the | 1299 | /* Unmap the packet contents such that we can use the |
| 1278 | * RSV from the 64 bytes descriptor when enabled and save | 1300 | * RSV from the 64 bytes descriptor when enabled and save |
| 1279 | * a 32-bits register read | 1301 | * a 32-bits register read |
| 1280 | */ | 1302 | */ |
| 1281 | cb = &priv->rx_cbs[priv->rx_read_ptr]; | ||
| 1282 | skb = cb->skb; | ||
| 1283 | dma_unmap_single(&dev->dev, dma_unmap_addr(cb, dma_addr), | 1303 | dma_unmap_single(&dev->dev, dma_unmap_addr(cb, dma_addr), |
| 1284 | priv->rx_buf_len, DMA_FROM_DEVICE); | 1304 | priv->rx_buf_len, DMA_FROM_DEVICE); |
| 1285 | 1305 | ||
| @@ -1307,18 +1327,6 @@ static unsigned int bcmgenet_desc_rx(struct bcmgenet_priv *priv, | |||
| 1307 | __func__, p_index, priv->rx_c_index, | 1327 | __func__, p_index, priv->rx_c_index, |
| 1308 | priv->rx_read_ptr, dma_length_status); | 1328 | priv->rx_read_ptr, dma_length_status); |
| 1309 | 1329 | ||
| 1310 | rxpktprocessed++; | ||
| 1311 | |||
| 1312 | priv->rx_read_ptr++; | ||
| 1313 | priv->rx_read_ptr &= (priv->num_rx_bds - 1); | ||
| 1314 | |||
| 1315 | /* out of memory, just drop packets at the hardware level */ | ||
| 1316 | if (unlikely(!skb)) { | ||
| 1317 | dev->stats.rx_dropped++; | ||
| 1318 | dev->stats.rx_errors++; | ||
| 1319 | goto refill; | ||
| 1320 | } | ||
| 1321 | |||
| 1322 | if (unlikely(!(dma_flag & DMA_EOP) || !(dma_flag & DMA_SOP))) { | 1330 | if (unlikely(!(dma_flag & DMA_EOP) || !(dma_flag & DMA_SOP))) { |
| 1323 | netif_err(priv, rx_status, dev, | 1331 | netif_err(priv, rx_status, dev, |
| 1324 | "dropping fragmented packet!\n"); | 1332 | "dropping fragmented packet!\n"); |
| @@ -1736,13 +1744,63 @@ static void bcmgenet_init_multiq(struct net_device *dev) | |||
| 1736 | bcmgenet_tdma_writel(priv, reg, DMA_CTRL); | 1744 | bcmgenet_tdma_writel(priv, reg, DMA_CTRL); |
| 1737 | } | 1745 | } |
| 1738 | 1746 | ||
| 1747 | static int bcmgenet_dma_teardown(struct bcmgenet_priv *priv) | ||
| 1748 | { | ||
| 1749 | int ret = 0; | ||
| 1750 | int timeout = 0; | ||
| 1751 | u32 reg; | ||
| 1752 | |||
| 1753 | /* Disable TDMA to stop add more frames in TX DMA */ | ||
| 1754 | reg = bcmgenet_tdma_readl(priv, DMA_CTRL); | ||
| 1755 | reg &= ~DMA_EN; | ||
| 1756 | bcmgenet_tdma_writel(priv, reg, DMA_CTRL); | ||
| 1757 | |||
| 1758 | /* Check TDMA status register to confirm TDMA is disabled */ | ||
| 1759 | while (timeout++ < DMA_TIMEOUT_VAL) { | ||
| 1760 | reg = bcmgenet_tdma_readl(priv, DMA_STATUS); | ||
| 1761 | if (reg & DMA_DISABLED) | ||
| 1762 | break; | ||
| 1763 | |||
| 1764 | udelay(1); | ||
| 1765 | } | ||
| 1766 | |||
| 1767 | if (timeout == DMA_TIMEOUT_VAL) { | ||
| 1768 | netdev_warn(priv->dev, "Timed out while disabling TX DMA\n"); | ||
| 1769 | ret = -ETIMEDOUT; | ||
| 1770 | } | ||
| 1771 | |||
| 1772 | /* Wait 10ms for packet drain in both tx and rx dma */ | ||
| 1773 | usleep_range(10000, 20000); | ||
| 1774 | |||
| 1775 | /* Disable RDMA */ | ||
| 1776 | reg = bcmgenet_rdma_readl(priv, DMA_CTRL); | ||
| 1777 | reg &= ~DMA_EN; | ||
| 1778 | bcmgenet_rdma_writel(priv, reg, DMA_CTRL); | ||
| 1779 | |||
| 1780 | timeout = 0; | ||
| 1781 | /* Check RDMA status register to confirm RDMA is disabled */ | ||
| 1782 | while (timeout++ < DMA_TIMEOUT_VAL) { | ||
| 1783 | reg = bcmgenet_rdma_readl(priv, DMA_STATUS); | ||
| 1784 | if (reg & DMA_DISABLED) | ||
| 1785 | break; | ||
| 1786 | |||
| 1787 | udelay(1); | ||
| 1788 | } | ||
| 1789 | |||
| 1790 | if (timeout == DMA_TIMEOUT_VAL) { | ||
| 1791 | netdev_warn(priv->dev, "Timed out while disabling RX DMA\n"); | ||
| 1792 | ret = -ETIMEDOUT; | ||
| 1793 | } | ||
| 1794 | |||
| 1795 | return ret; | ||
| 1796 | } | ||
| 1797 | |||
| 1739 | static void bcmgenet_fini_dma(struct bcmgenet_priv *priv) | 1798 | static void bcmgenet_fini_dma(struct bcmgenet_priv *priv) |
| 1740 | { | 1799 | { |
| 1741 | int i; | 1800 | int i; |
| 1742 | 1801 | ||
| 1743 | /* disable DMA */ | 1802 | /* disable DMA */ |
| 1744 | bcmgenet_rdma_writel(priv, 0, DMA_CTRL); | 1803 | bcmgenet_dma_teardown(priv); |
| 1745 | bcmgenet_tdma_writel(priv, 0, DMA_CTRL); | ||
| 1746 | 1804 | ||
| 1747 | for (i = 0; i < priv->num_tx_bds; i++) { | 1805 | for (i = 0; i < priv->num_tx_bds; i++) { |
| 1748 | if (priv->tx_cbs[i].skb != NULL) { | 1806 | if (priv->tx_cbs[i].skb != NULL) { |
| @@ -2101,57 +2159,6 @@ err_clk_disable: | |||
| 2101 | return ret; | 2159 | return ret; |
| 2102 | } | 2160 | } |
| 2103 | 2161 | ||
| 2104 | static int bcmgenet_dma_teardown(struct bcmgenet_priv *priv) | ||
| 2105 | { | ||
| 2106 | int ret = 0; | ||
| 2107 | int timeout = 0; | ||
| 2108 | u32 reg; | ||
| 2109 | |||
| 2110 | /* Disable TDMA to stop add more frames in TX DMA */ | ||
| 2111 | reg = bcmgenet_tdma_readl(priv, DMA_CTRL); | ||
| 2112 | reg &= ~DMA_EN; | ||
| 2113 | bcmgenet_tdma_writel(priv, reg, DMA_CTRL); | ||
| 2114 | |||
| 2115 | /* Check TDMA status register to confirm TDMA is disabled */ | ||
| 2116 | while (timeout++ < DMA_TIMEOUT_VAL) { | ||
| 2117 | reg = bcmgenet_tdma_readl(priv, DMA_STATUS); | ||
| 2118 | if (reg & DMA_DISABLED) | ||
| 2119 | break; | ||
| 2120 | |||
| 2121 | udelay(1); | ||
| 2122 | } | ||
| 2123 | |||
| 2124 | if (timeout == DMA_TIMEOUT_VAL) { | ||
| 2125 | netdev_warn(priv->dev, "Timed out while disabling TX DMA\n"); | ||
| 2126 | ret = -ETIMEDOUT; | ||
| 2127 | } | ||
| 2128 | |||
| 2129 | /* Wait 10ms for packet drain in both tx and rx dma */ | ||
| 2130 | usleep_range(10000, 20000); | ||
| 2131 | |||
| 2132 | /* Disable RDMA */ | ||
| 2133 | reg = bcmgenet_rdma_readl(priv, DMA_CTRL); | ||
| 2134 | reg &= ~DMA_EN; | ||
| 2135 | bcmgenet_rdma_writel(priv, reg, DMA_CTRL); | ||
| 2136 | |||
| 2137 | timeout = 0; | ||
| 2138 | /* Check RDMA status register to confirm RDMA is disabled */ | ||
| 2139 | while (timeout++ < DMA_TIMEOUT_VAL) { | ||
| 2140 | reg = bcmgenet_rdma_readl(priv, DMA_STATUS); | ||
| 2141 | if (reg & DMA_DISABLED) | ||
| 2142 | break; | ||
| 2143 | |||
| 2144 | udelay(1); | ||
| 2145 | } | ||
| 2146 | |||
| 2147 | if (timeout == DMA_TIMEOUT_VAL) { | ||
| 2148 | netdev_warn(priv->dev, "Timed out while disabling RX DMA\n"); | ||
| 2149 | ret = -ETIMEDOUT; | ||
| 2150 | } | ||
| 2151 | |||
| 2152 | return ret; | ||
| 2153 | } | ||
| 2154 | |||
| 2155 | static void bcmgenet_netif_stop(struct net_device *dev) | 2162 | static void bcmgenet_netif_stop(struct net_device *dev) |
| 2156 | { | 2163 | { |
| 2157 | struct bcmgenet_priv *priv = netdev_priv(dev); | 2164 | struct bcmgenet_priv *priv = netdev_priv(dev); |
diff --git a/drivers/net/ethernet/broadcom/tg3.c b/drivers/net/ethernet/broadcom/tg3.c index cb77ae93d89a..e7d3a620d96a 100644 --- a/drivers/net/ethernet/broadcom/tg3.c +++ b/drivers/net/ethernet/broadcom/tg3.c | |||
| @@ -7914,8 +7914,6 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 7914 | 7914 | ||
| 7915 | entry = tnapi->tx_prod; | 7915 | entry = tnapi->tx_prod; |
| 7916 | base_flags = 0; | 7916 | base_flags = 0; |
| 7917 | if (skb->ip_summed == CHECKSUM_PARTIAL) | ||
| 7918 | base_flags |= TXD_FLAG_TCPUDP_CSUM; | ||
| 7919 | 7917 | ||
| 7920 | mss = skb_shinfo(skb)->gso_size; | 7918 | mss = skb_shinfo(skb)->gso_size; |
| 7921 | if (mss) { | 7919 | if (mss) { |
| @@ -7929,6 +7927,13 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 7929 | 7927 | ||
| 7930 | hdr_len = skb_transport_offset(skb) + tcp_hdrlen(skb) - ETH_HLEN; | 7928 | hdr_len = skb_transport_offset(skb) + tcp_hdrlen(skb) - ETH_HLEN; |
| 7931 | 7929 | ||
| 7930 | /* HW/FW can not correctly segment packets that have been | ||
| 7931 | * vlan encapsulated. | ||
| 7932 | */ | ||
| 7933 | if (skb->protocol == htons(ETH_P_8021Q) || | ||
| 7934 | skb->protocol == htons(ETH_P_8021AD)) | ||
| 7935 | return tg3_tso_bug(tp, tnapi, txq, skb); | ||
| 7936 | |||
| 7932 | if (!skb_is_gso_v6(skb)) { | 7937 | if (!skb_is_gso_v6(skb)) { |
| 7933 | if (unlikely((ETH_HLEN + hdr_len) > 80) && | 7938 | if (unlikely((ETH_HLEN + hdr_len) > 80) && |
| 7934 | tg3_flag(tp, TSO_BUG)) | 7939 | tg3_flag(tp, TSO_BUG)) |
| @@ -7979,6 +7984,17 @@ static netdev_tx_t tg3_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
| 7979 | base_flags |= tsflags << 12; | 7984 | base_flags |= tsflags << 12; |
| 7980 | } | 7985 | } |
| 7981 | } | 7986 | } |
| 7987 | } else if (skb->ip_summed == CHECKSUM_PARTIAL) { | ||
| 7988 | /* HW/FW can not correctly checksum packets that have been | ||
| 7989 | * vlan encapsulated. | ||
| 7990 | */ | ||
| 7991 | if (skb->protocol == htons(ETH_P_8021Q) || | ||
| 7992 | skb->protocol == htons(ETH_P_8021AD)) { | ||
| 7993 | if (skb_checksum_help(skb)) | ||
| 7994 | goto drop; | ||
| 7995 | } else { | ||
| 7996 | base_flags |= TXD_FLAG_TCPUDP_CSUM; | ||
| 7997 | } | ||
| 7982 | } | 7998 | } |
| 7983 | 7999 | ||
| 7984 | if (tg3_flag(tp, USE_JUMBO_BDFLAG) && | 8000 | if (tg3_flag(tp, USE_JUMBO_BDFLAG) && |
diff --git a/drivers/net/ethernet/chelsio/cxgb4/cxgb4_main.c b/drivers/net/ethernet/chelsio/cxgb4/cxgb4_main.c index 8c34811a1128..e5be511a3c38 100644 --- a/drivers/net/ethernet/chelsio/cxgb4/cxgb4_main.c +++ b/drivers/net/ethernet/chelsio/cxgb4/cxgb4_main.c | |||
| @@ -6478,6 +6478,7 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6478 | struct port_info *pi; | 6478 | struct port_info *pi; |
| 6479 | bool highdma = false; | 6479 | bool highdma = false; |
| 6480 | struct adapter *adapter = NULL; | 6480 | struct adapter *adapter = NULL; |
| 6481 | void __iomem *regs; | ||
| 6481 | 6482 | ||
| 6482 | printk_once(KERN_INFO "%s - version %s\n", DRV_DESC, DRV_VERSION); | 6483 | printk_once(KERN_INFO "%s - version %s\n", DRV_DESC, DRV_VERSION); |
| 6483 | 6484 | ||
| @@ -6494,19 +6495,35 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6494 | goto out_release_regions; | 6495 | goto out_release_regions; |
| 6495 | } | 6496 | } |
| 6496 | 6497 | ||
| 6498 | regs = pci_ioremap_bar(pdev, 0); | ||
| 6499 | if (!regs) { | ||
| 6500 | dev_err(&pdev->dev, "cannot map device registers\n"); | ||
| 6501 | err = -ENOMEM; | ||
| 6502 | goto out_disable_device; | ||
| 6503 | } | ||
| 6504 | |||
| 6505 | /* We control everything through one PF */ | ||
| 6506 | func = SOURCEPF_GET(readl(regs + PL_WHOAMI)); | ||
| 6507 | if (func != ent->driver_data) { | ||
| 6508 | iounmap(regs); | ||
| 6509 | pci_disable_device(pdev); | ||
| 6510 | pci_save_state(pdev); /* to restore SR-IOV later */ | ||
| 6511 | goto sriov; | ||
| 6512 | } | ||
| 6513 | |||
| 6497 | if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) { | 6514 | if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) { |
| 6498 | highdma = true; | 6515 | highdma = true; |
| 6499 | err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64)); | 6516 | err = pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64)); |
| 6500 | if (err) { | 6517 | if (err) { |
| 6501 | dev_err(&pdev->dev, "unable to obtain 64-bit DMA for " | 6518 | dev_err(&pdev->dev, "unable to obtain 64-bit DMA for " |
| 6502 | "coherent allocations\n"); | 6519 | "coherent allocations\n"); |
| 6503 | goto out_disable_device; | 6520 | goto out_unmap_bar0; |
| 6504 | } | 6521 | } |
| 6505 | } else { | 6522 | } else { |
| 6506 | err = pci_set_dma_mask(pdev, DMA_BIT_MASK(32)); | 6523 | err = pci_set_dma_mask(pdev, DMA_BIT_MASK(32)); |
| 6507 | if (err) { | 6524 | if (err) { |
| 6508 | dev_err(&pdev->dev, "no usable DMA configuration\n"); | 6525 | dev_err(&pdev->dev, "no usable DMA configuration\n"); |
| 6509 | goto out_disable_device; | 6526 | goto out_unmap_bar0; |
| 6510 | } | 6527 | } |
| 6511 | } | 6528 | } |
| 6512 | 6529 | ||
| @@ -6518,7 +6535,7 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6518 | adapter = kzalloc(sizeof(*adapter), GFP_KERNEL); | 6535 | adapter = kzalloc(sizeof(*adapter), GFP_KERNEL); |
| 6519 | if (!adapter) { | 6536 | if (!adapter) { |
| 6520 | err = -ENOMEM; | 6537 | err = -ENOMEM; |
| 6521 | goto out_disable_device; | 6538 | goto out_unmap_bar0; |
| 6522 | } | 6539 | } |
| 6523 | 6540 | ||
| 6524 | adapter->workq = create_singlethread_workqueue("cxgb4"); | 6541 | adapter->workq = create_singlethread_workqueue("cxgb4"); |
| @@ -6530,20 +6547,7 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6530 | /* PCI device has been enabled */ | 6547 | /* PCI device has been enabled */ |
| 6531 | adapter->flags |= DEV_ENABLED; | 6548 | adapter->flags |= DEV_ENABLED; |
| 6532 | 6549 | ||
| 6533 | adapter->regs = pci_ioremap_bar(pdev, 0); | 6550 | adapter->regs = regs; |
| 6534 | if (!adapter->regs) { | ||
| 6535 | dev_err(&pdev->dev, "cannot map device registers\n"); | ||
| 6536 | err = -ENOMEM; | ||
| 6537 | goto out_free_adapter; | ||
| 6538 | } | ||
| 6539 | |||
| 6540 | /* We control everything through one PF */ | ||
| 6541 | func = SOURCEPF_GET(readl(adapter->regs + PL_WHOAMI)); | ||
| 6542 | if (func != ent->driver_data) { | ||
| 6543 | pci_save_state(pdev); /* to restore SR-IOV later */ | ||
| 6544 | goto sriov; | ||
| 6545 | } | ||
| 6546 | |||
| 6547 | adapter->pdev = pdev; | 6551 | adapter->pdev = pdev; |
| 6548 | adapter->pdev_dev = &pdev->dev; | 6552 | adapter->pdev_dev = &pdev->dev; |
| 6549 | adapter->mbox = func; | 6553 | adapter->mbox = func; |
| @@ -6560,7 +6564,8 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6560 | 6564 | ||
| 6561 | err = t4_prep_adapter(adapter); | 6565 | err = t4_prep_adapter(adapter); |
| 6562 | if (err) | 6566 | if (err) |
| 6563 | goto out_unmap_bar0; | 6567 | goto out_free_adapter; |
| 6568 | |||
| 6564 | 6569 | ||
| 6565 | if (!is_t4(adapter->params.chip)) { | 6570 | if (!is_t4(adapter->params.chip)) { |
| 6566 | s_qpp = QUEUESPERPAGEPF1 * adapter->fn; | 6571 | s_qpp = QUEUESPERPAGEPF1 * adapter->fn; |
| @@ -6577,14 +6582,14 @@ static int init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 6577 | dev_err(&pdev->dev, | 6582 | dev_err(&pdev->dev, |
| 6578 | "Incorrect number of egress queues per page\n"); | 6583 | "Incorrect number of egress queues per page\n"); |
| 6579 | err = -EINVAL; | 6584 | err = -EINVAL; |
| 6580 | goto out_unmap_bar0; | 6585 | goto out_free_adapter; |
| 6581 | } | 6586 | } |
| 6582 | adapter->bar2 = ioremap_wc(pci_resource_start(pdev, 2), | 6587 | adapter->bar2 = ioremap_wc(pci_resource_start(pdev, 2), |
| 6583 | pci_resource_len(pdev, 2)); | 6588 | pci_resource_len(pdev, 2)); |
| 6584 | if (!adapter->bar2) { | 6589 | if (!adapter->bar2) { |
| 6585 | dev_err(&pdev->dev, "cannot map device bar2 region\n"); | 6590 | dev_err(&pdev->dev, "cannot map device bar2 region\n"); |
| 6586 | err = -ENOMEM; | 6591 | err = -ENOMEM; |
| 6587 | goto out_unmap_bar0; | 6592 | goto out_free_adapter; |
| 6588 | } | 6593 | } |
| 6589 | } | 6594 | } |
| 6590 | 6595 | ||
| @@ -6722,13 +6727,13 @@ sriov: | |||
| 6722 | out_unmap_bar: | 6727 | out_unmap_bar: |
| 6723 | if (!is_t4(adapter->params.chip)) | 6728 | if (!is_t4(adapter->params.chip)) |
| 6724 | iounmap(adapter->bar2); | 6729 | iounmap(adapter->bar2); |
| 6725 | out_unmap_bar0: | ||
| 6726 | iounmap(adapter->regs); | ||
| 6727 | out_free_adapter: | 6730 | out_free_adapter: |
| 6728 | if (adapter->workq) | 6731 | if (adapter->workq) |
| 6729 | destroy_workqueue(adapter->workq); | 6732 | destroy_workqueue(adapter->workq); |
| 6730 | 6733 | ||
| 6731 | kfree(adapter); | 6734 | kfree(adapter); |
| 6735 | out_unmap_bar0: | ||
| 6736 | iounmap(regs); | ||
| 6732 | out_disable_device: | 6737 | out_disable_device: |
| 6733 | pci_disable_pcie_error_reporting(pdev); | 6738 | pci_disable_pcie_error_reporting(pdev); |
| 6734 | pci_disable_device(pdev); | 6739 | pci_disable_device(pdev); |
diff --git a/drivers/net/ethernet/davicom/dm9000.c b/drivers/net/ethernet/davicom/dm9000.c index 9b33057a9477..70089c29d307 100644 --- a/drivers/net/ethernet/davicom/dm9000.c +++ b/drivers/net/ethernet/davicom/dm9000.c | |||
| @@ -1399,7 +1399,7 @@ static struct dm9000_plat_data *dm9000_parse_dt(struct device *dev) | |||
| 1399 | const void *mac_addr; | 1399 | const void *mac_addr; |
| 1400 | 1400 | ||
| 1401 | if (!IS_ENABLED(CONFIG_OF) || !np) | 1401 | if (!IS_ENABLED(CONFIG_OF) || !np) |
| 1402 | return NULL; | 1402 | return ERR_PTR(-ENXIO); |
| 1403 | 1403 | ||
| 1404 | pdata = devm_kzalloc(dev, sizeof(*pdata), GFP_KERNEL); | 1404 | pdata = devm_kzalloc(dev, sizeof(*pdata), GFP_KERNEL); |
| 1405 | if (!pdata) | 1405 | if (!pdata) |
diff --git a/drivers/net/ethernet/mellanox/mlx4/cmd.c b/drivers/net/ethernet/mellanox/mlx4/cmd.c index 65a4a0f88ea0..02a2e90d581a 100644 --- a/drivers/net/ethernet/mellanox/mlx4/cmd.c +++ b/drivers/net/ethernet/mellanox/mlx4/cmd.c | |||
| @@ -2389,6 +2389,22 @@ struct mlx4_slaves_pport mlx4_phys_to_slaves_pport_actv( | |||
| 2389 | } | 2389 | } |
| 2390 | EXPORT_SYMBOL_GPL(mlx4_phys_to_slaves_pport_actv); | 2390 | EXPORT_SYMBOL_GPL(mlx4_phys_to_slaves_pport_actv); |
| 2391 | 2391 | ||
| 2392 | static int mlx4_slaves_closest_port(struct mlx4_dev *dev, int slave, int port) | ||
| 2393 | { | ||
| 2394 | struct mlx4_active_ports actv_ports = mlx4_get_active_ports(dev, slave); | ||
| 2395 | int min_port = find_first_bit(actv_ports.ports, dev->caps.num_ports) | ||
| 2396 | + 1; | ||
| 2397 | int max_port = min_port + | ||
| 2398 | bitmap_weight(actv_ports.ports, dev->caps.num_ports); | ||
| 2399 | |||
| 2400 | if (port < min_port) | ||
| 2401 | port = min_port; | ||
| 2402 | else if (port >= max_port) | ||
| 2403 | port = max_port - 1; | ||
| 2404 | |||
| 2405 | return port; | ||
| 2406 | } | ||
| 2407 | |||
| 2392 | int mlx4_set_vf_mac(struct mlx4_dev *dev, int port, int vf, u64 mac) | 2408 | int mlx4_set_vf_mac(struct mlx4_dev *dev, int port, int vf, u64 mac) |
| 2393 | { | 2409 | { |
| 2394 | struct mlx4_priv *priv = mlx4_priv(dev); | 2410 | struct mlx4_priv *priv = mlx4_priv(dev); |
| @@ -2402,6 +2418,7 @@ int mlx4_set_vf_mac(struct mlx4_dev *dev, int port, int vf, u64 mac) | |||
| 2402 | if (slave < 0) | 2418 | if (slave < 0) |
| 2403 | return -EINVAL; | 2419 | return -EINVAL; |
| 2404 | 2420 | ||
| 2421 | port = mlx4_slaves_closest_port(dev, slave, port); | ||
| 2405 | s_info = &priv->mfunc.master.vf_admin[slave].vport[port]; | 2422 | s_info = &priv->mfunc.master.vf_admin[slave].vport[port]; |
| 2406 | s_info->mac = mac; | 2423 | s_info->mac = mac; |
| 2407 | mlx4_info(dev, "default mac on vf %d port %d to %llX will take afect only after vf restart\n", | 2424 | mlx4_info(dev, "default mac on vf %d port %d to %llX will take afect only after vf restart\n", |
| @@ -2428,6 +2445,7 @@ int mlx4_set_vf_vlan(struct mlx4_dev *dev, int port, int vf, u16 vlan, u8 qos) | |||
| 2428 | if (slave < 0) | 2445 | if (slave < 0) |
| 2429 | return -EINVAL; | 2446 | return -EINVAL; |
| 2430 | 2447 | ||
| 2448 | port = mlx4_slaves_closest_port(dev, slave, port); | ||
| 2431 | vf_admin = &priv->mfunc.master.vf_admin[slave].vport[port]; | 2449 | vf_admin = &priv->mfunc.master.vf_admin[slave].vport[port]; |
| 2432 | 2450 | ||
| 2433 | if ((0 == vlan) && (0 == qos)) | 2451 | if ((0 == vlan) && (0 == qos)) |
| @@ -2455,6 +2473,7 @@ bool mlx4_get_slave_default_vlan(struct mlx4_dev *dev, int port, int slave, | |||
| 2455 | struct mlx4_priv *priv; | 2473 | struct mlx4_priv *priv; |
| 2456 | 2474 | ||
| 2457 | priv = mlx4_priv(dev); | 2475 | priv = mlx4_priv(dev); |
| 2476 | port = mlx4_slaves_closest_port(dev, slave, port); | ||
| 2458 | vp_oper = &priv->mfunc.master.vf_oper[slave].vport[port]; | 2477 | vp_oper = &priv->mfunc.master.vf_oper[slave].vport[port]; |
| 2459 | 2478 | ||
| 2460 | if (MLX4_VGT != vp_oper->state.default_vlan) { | 2479 | if (MLX4_VGT != vp_oper->state.default_vlan) { |
| @@ -2482,6 +2501,7 @@ int mlx4_set_vf_spoofchk(struct mlx4_dev *dev, int port, int vf, bool setting) | |||
| 2482 | if (slave < 0) | 2501 | if (slave < 0) |
| 2483 | return -EINVAL; | 2502 | return -EINVAL; |
| 2484 | 2503 | ||
| 2504 | port = mlx4_slaves_closest_port(dev, slave, port); | ||
| 2485 | s_info = &priv->mfunc.master.vf_admin[slave].vport[port]; | 2505 | s_info = &priv->mfunc.master.vf_admin[slave].vport[port]; |
| 2486 | s_info->spoofchk = setting; | 2506 | s_info->spoofchk = setting; |
| 2487 | 2507 | ||
| @@ -2535,6 +2555,7 @@ int mlx4_set_vf_link_state(struct mlx4_dev *dev, int port, int vf, int link_stat | |||
| 2535 | if (slave < 0) | 2555 | if (slave < 0) |
| 2536 | return -EINVAL; | 2556 | return -EINVAL; |
| 2537 | 2557 | ||
| 2558 | port = mlx4_slaves_closest_port(dev, slave, port); | ||
| 2538 | switch (link_state) { | 2559 | switch (link_state) { |
| 2539 | case IFLA_VF_LINK_STATE_AUTO: | 2560 | case IFLA_VF_LINK_STATE_AUTO: |
| 2540 | /* get current link state */ | 2561 | /* get current link state */ |
diff --git a/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c b/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c index e22f24f784fc..35ff2925110a 100644 --- a/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c +++ b/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c | |||
| @@ -487,6 +487,9 @@ static int mlx4_en_set_pauseparam(struct net_device *dev, | |||
| 487 | struct mlx4_en_dev *mdev = priv->mdev; | 487 | struct mlx4_en_dev *mdev = priv->mdev; |
| 488 | int err; | 488 | int err; |
| 489 | 489 | ||
| 490 | if (pause->autoneg) | ||
| 491 | return -EINVAL; | ||
| 492 | |||
| 490 | priv->prof->tx_pause = pause->tx_pause != 0; | 493 | priv->prof->tx_pause = pause->tx_pause != 0; |
| 491 | priv->prof->rx_pause = pause->rx_pause != 0; | 494 | priv->prof->rx_pause = pause->rx_pause != 0; |
| 492 | err = mlx4_SET_PORT_general(mdev->dev, priv->port, | 495 | err = mlx4_SET_PORT_general(mdev->dev, priv->port, |
diff --git a/drivers/net/ethernet/mellanox/mlx4/qp.c b/drivers/net/ethernet/mellanox/mlx4/qp.c index 0dc31d85fc3b..2301365c79c7 100644 --- a/drivers/net/ethernet/mellanox/mlx4/qp.c +++ b/drivers/net/ethernet/mellanox/mlx4/qp.c | |||
| @@ -390,13 +390,14 @@ err_icm: | |||
| 390 | EXPORT_SYMBOL_GPL(mlx4_qp_alloc); | 390 | EXPORT_SYMBOL_GPL(mlx4_qp_alloc); |
| 391 | 391 | ||
| 392 | #define MLX4_UPDATE_QP_SUPPORTED_ATTRS MLX4_UPDATE_QP_SMAC | 392 | #define MLX4_UPDATE_QP_SUPPORTED_ATTRS MLX4_UPDATE_QP_SMAC |
| 393 | int mlx4_update_qp(struct mlx4_dev *dev, struct mlx4_qp *qp, | 393 | int mlx4_update_qp(struct mlx4_dev *dev, u32 qpn, |
| 394 | enum mlx4_update_qp_attr attr, | 394 | enum mlx4_update_qp_attr attr, |
| 395 | struct mlx4_update_qp_params *params) | 395 | struct mlx4_update_qp_params *params) |
| 396 | { | 396 | { |
| 397 | struct mlx4_cmd_mailbox *mailbox; | 397 | struct mlx4_cmd_mailbox *mailbox; |
| 398 | struct mlx4_update_qp_context *cmd; | 398 | struct mlx4_update_qp_context *cmd; |
| 399 | u64 pri_addr_path_mask = 0; | 399 | u64 pri_addr_path_mask = 0; |
| 400 | u64 qp_mask = 0; | ||
| 400 | int err = 0; | 401 | int err = 0; |
| 401 | 402 | ||
| 402 | mailbox = mlx4_alloc_cmd_mailbox(dev); | 403 | mailbox = mlx4_alloc_cmd_mailbox(dev); |
| @@ -413,9 +414,16 @@ int mlx4_update_qp(struct mlx4_dev *dev, struct mlx4_qp *qp, | |||
| 413 | cmd->qp_context.pri_path.grh_mylmc = params->smac_index; | 414 | cmd->qp_context.pri_path.grh_mylmc = params->smac_index; |
| 414 | } | 415 | } |
| 415 | 416 | ||
| 417 | if (attr & MLX4_UPDATE_QP_VSD) { | ||
| 418 | qp_mask |= 1ULL << MLX4_UPD_QP_MASK_VSD; | ||
| 419 | if (params->flags & MLX4_UPDATE_QP_PARAMS_FLAGS_VSD_ENABLE) | ||
| 420 | cmd->qp_context.param3 |= cpu_to_be32(MLX4_STRIP_VLAN); | ||
| 421 | } | ||
| 422 | |||
| 416 | cmd->primary_addr_path_mask = cpu_to_be64(pri_addr_path_mask); | 423 | cmd->primary_addr_path_mask = cpu_to_be64(pri_addr_path_mask); |
| 424 | cmd->qp_mask = cpu_to_be64(qp_mask); | ||
| 417 | 425 | ||
| 418 | err = mlx4_cmd(dev, mailbox->dma, qp->qpn & 0xffffff, 0, | 426 | err = mlx4_cmd(dev, mailbox->dma, qpn & 0xffffff, 0, |
| 419 | MLX4_CMD_UPDATE_QP, MLX4_CMD_TIME_CLASS_A, | 427 | MLX4_CMD_UPDATE_QP, MLX4_CMD_TIME_CLASS_A, |
| 420 | MLX4_CMD_NATIVE); | 428 | MLX4_CMD_NATIVE); |
| 421 | 429 | ||
diff --git a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c index 1089367fed22..5d2498dcf536 100644 --- a/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c +++ b/drivers/net/ethernet/mellanox/mlx4/resource_tracker.c | |||
| @@ -702,11 +702,13 @@ static int update_vport_qp_param(struct mlx4_dev *dev, | |||
| 702 | struct mlx4_qp_context *qpc = inbox->buf + 8; | 702 | struct mlx4_qp_context *qpc = inbox->buf + 8; |
| 703 | struct mlx4_vport_oper_state *vp_oper; | 703 | struct mlx4_vport_oper_state *vp_oper; |
| 704 | struct mlx4_priv *priv; | 704 | struct mlx4_priv *priv; |
| 705 | u32 qp_type; | ||
| 705 | int port; | 706 | int port; |
| 706 | 707 | ||
| 707 | port = (qpc->pri_path.sched_queue & 0x40) ? 2 : 1; | 708 | port = (qpc->pri_path.sched_queue & 0x40) ? 2 : 1; |
| 708 | priv = mlx4_priv(dev); | 709 | priv = mlx4_priv(dev); |
| 709 | vp_oper = &priv->mfunc.master.vf_oper[slave].vport[port]; | 710 | vp_oper = &priv->mfunc.master.vf_oper[slave].vport[port]; |
| 711 | qp_type = (be32_to_cpu(qpc->flags) >> 16) & 0xff; | ||
| 710 | 712 | ||
| 711 | if (MLX4_VGT != vp_oper->state.default_vlan) { | 713 | if (MLX4_VGT != vp_oper->state.default_vlan) { |
| 712 | /* the reserved QPs (special, proxy, tunnel) | 714 | /* the reserved QPs (special, proxy, tunnel) |
| @@ -715,8 +717,20 @@ static int update_vport_qp_param(struct mlx4_dev *dev, | |||
| 715 | if (mlx4_is_qp_reserved(dev, qpn)) | 717 | if (mlx4_is_qp_reserved(dev, qpn)) |
| 716 | return 0; | 718 | return 0; |
| 717 | 719 | ||
| 718 | /* force strip vlan by clear vsd */ | 720 | /* force strip vlan by clear vsd, MLX QP refers to Raw Ethernet */ |
| 719 | qpc->param3 &= ~cpu_to_be32(MLX4_STRIP_VLAN); | 721 | if (qp_type == MLX4_QP_ST_UD || |
| 722 | (qp_type == MLX4_QP_ST_MLX && mlx4_is_eth(dev, port))) { | ||
| 723 | if (dev->caps.bmme_flags & MLX4_BMME_FLAG_VSD_INIT2RTR) { | ||
| 724 | *(__be32 *)inbox->buf = | ||
| 725 | cpu_to_be32(be32_to_cpu(*(__be32 *)inbox->buf) | | ||
| 726 | MLX4_QP_OPTPAR_VLAN_STRIPPING); | ||
| 727 | qpc->param3 &= ~cpu_to_be32(MLX4_STRIP_VLAN); | ||
| 728 | } else { | ||
| 729 | struct mlx4_update_qp_params params = {.flags = 0}; | ||
| 730 | |||
| 731 | mlx4_update_qp(dev, qpn, MLX4_UPDATE_QP_VSD, ¶ms); | ||
| 732 | } | ||
| 733 | } | ||
| 720 | 734 | ||
| 721 | if (vp_oper->state.link_state == IFLA_VF_LINK_STATE_DISABLE && | 735 | if (vp_oper->state.link_state == IFLA_VF_LINK_STATE_DISABLE && |
| 722 | dev->caps.flags2 & MLX4_DEV_CAP_FLAG2_UPDATE_QP) { | 736 | dev->caps.flags2 & MLX4_DEV_CAP_FLAG2_UPDATE_QP) { |
| @@ -3998,13 +4012,17 @@ int mlx4_UPDATE_QP_wrapper(struct mlx4_dev *dev, int slave, | |||
| 3998 | } | 4012 | } |
| 3999 | 4013 | ||
| 4000 | port = (rqp->sched_queue >> 6 & 1) + 1; | 4014 | port = (rqp->sched_queue >> 6 & 1) + 1; |
| 4001 | smac_index = cmd->qp_context.pri_path.grh_mylmc; | 4015 | |
| 4002 | err = mac_find_smac_ix_in_slave(dev, slave, port, | 4016 | if (pri_addr_path_mask & (1ULL << MLX4_UPD_QP_PATH_MASK_MAC_INDEX)) { |
| 4003 | smac_index, &mac); | 4017 | smac_index = cmd->qp_context.pri_path.grh_mylmc; |
| 4004 | if (err) { | 4018 | err = mac_find_smac_ix_in_slave(dev, slave, port, |
| 4005 | mlx4_err(dev, "Failed to update qpn 0x%x, MAC is invalid. smac_ix: %d\n", | 4019 | smac_index, &mac); |
| 4006 | qpn, smac_index); | 4020 | |
| 4007 | goto err_mac; | 4021 | if (err) { |
| 4022 | mlx4_err(dev, "Failed to update qpn 0x%x, MAC is invalid. smac_ix: %d\n", | ||
| 4023 | qpn, smac_index); | ||
| 4024 | goto err_mac; | ||
| 4025 | } | ||
| 4008 | } | 4026 | } |
| 4009 | 4027 | ||
| 4010 | err = mlx4_cmd(dev, inbox->dma, | 4028 | err = mlx4_cmd(dev, inbox->dma, |
| @@ -4818,7 +4836,7 @@ void mlx4_vf_immed_vlan_work_handler(struct work_struct *_work) | |||
| 4818 | MLX4_VLAN_CTRL_ETH_RX_BLOCK_UNTAGGED; | 4836 | MLX4_VLAN_CTRL_ETH_RX_BLOCK_UNTAGGED; |
| 4819 | 4837 | ||
| 4820 | upd_context = mailbox->buf; | 4838 | upd_context = mailbox->buf; |
| 4821 | upd_context->qp_mask = cpu_to_be64(MLX4_UPD_QP_MASK_VSD); | 4839 | upd_context->qp_mask = cpu_to_be64(1ULL << MLX4_UPD_QP_MASK_VSD); |
| 4822 | 4840 | ||
| 4823 | spin_lock_irq(mlx4_tlock(dev)); | 4841 | spin_lock_irq(mlx4_tlock(dev)); |
| 4824 | list_for_each_entry_safe(qp, tmp, qp_list, com.list) { | 4842 | list_for_each_entry_safe(qp, tmp, qp_list, com.list) { |
diff --git a/drivers/net/ethernet/octeon/octeon_mgmt.c b/drivers/net/ethernet/octeon/octeon_mgmt.c index 979c6980639f..a42293092ea4 100644 --- a/drivers/net/ethernet/octeon/octeon_mgmt.c +++ b/drivers/net/ethernet/octeon/octeon_mgmt.c | |||
| @@ -290,9 +290,11 @@ static void octeon_mgmt_clean_tx_buffers(struct octeon_mgmt *p) | |||
| 290 | /* Read the hardware TX timestamp if one was recorded */ | 290 | /* Read the hardware TX timestamp if one was recorded */ |
| 291 | if (unlikely(re.s.tstamp)) { | 291 | if (unlikely(re.s.tstamp)) { |
| 292 | struct skb_shared_hwtstamps ts; | 292 | struct skb_shared_hwtstamps ts; |
| 293 | u64 ns; | ||
| 294 | |||
| 293 | memset(&ts, 0, sizeof(ts)); | 295 | memset(&ts, 0, sizeof(ts)); |
| 294 | /* Read the timestamp */ | 296 | /* Read the timestamp */ |
| 295 | u64 ns = cvmx_read_csr(CVMX_MIXX_TSTAMP(p->port)); | 297 | ns = cvmx_read_csr(CVMX_MIXX_TSTAMP(p->port)); |
| 296 | /* Remove the timestamp from the FIFO */ | 298 | /* Remove the timestamp from the FIFO */ |
| 297 | cvmx_write_csr(CVMX_MIXX_TSCTL(p->port), 0); | 299 | cvmx_write_csr(CVMX_MIXX_TSCTL(p->port), 0); |
| 298 | /* Tell the kernel about the timestamp */ | 300 | /* Tell the kernel about the timestamp */ |
diff --git a/drivers/net/ethernet/oki-semi/pch_gbe/Kconfig b/drivers/net/ethernet/oki-semi/pch_gbe/Kconfig index 44c8be1c6805..5f7a35212796 100644 --- a/drivers/net/ethernet/oki-semi/pch_gbe/Kconfig +++ b/drivers/net/ethernet/oki-semi/pch_gbe/Kconfig | |||
| @@ -7,6 +7,7 @@ config PCH_GBE | |||
| 7 | depends on PCI && (X86_32 || COMPILE_TEST) | 7 | depends on PCI && (X86_32 || COMPILE_TEST) |
| 8 | select MII | 8 | select MII |
| 9 | select PTP_1588_CLOCK_PCH | 9 | select PTP_1588_CLOCK_PCH |
| 10 | select NET_PTP_CLASSIFY | ||
| 10 | ---help--- | 11 | ---help--- |
| 11 | This is a gigabit ethernet driver for EG20T PCH. | 12 | This is a gigabit ethernet driver for EG20T PCH. |
| 12 | EG20T PCH is the platform controller hub that is used in Intel's | 13 | EG20T PCH is the platform controller hub that is used in Intel's |
diff --git a/drivers/net/ethernet/realtek/r8169.c b/drivers/net/ethernet/realtek/r8169.c index 91652e7235e4..0921302553c6 100644 --- a/drivers/net/ethernet/realtek/r8169.c +++ b/drivers/net/ethernet/realtek/r8169.c | |||
| @@ -1783,33 +1783,31 @@ static void __rtl8169_set_features(struct net_device *dev, | |||
| 1783 | netdev_features_t features) | 1783 | netdev_features_t features) |
| 1784 | { | 1784 | { |
| 1785 | struct rtl8169_private *tp = netdev_priv(dev); | 1785 | struct rtl8169_private *tp = netdev_priv(dev); |
| 1786 | netdev_features_t changed = features ^ dev->features; | ||
| 1787 | void __iomem *ioaddr = tp->mmio_addr; | 1786 | void __iomem *ioaddr = tp->mmio_addr; |
| 1787 | u32 rx_config; | ||
| 1788 | 1788 | ||
| 1789 | if (!(changed & (NETIF_F_RXALL | NETIF_F_RXCSUM | | 1789 | rx_config = RTL_R32(RxConfig); |
| 1790 | NETIF_F_HW_VLAN_CTAG_RX))) | 1790 | if (features & NETIF_F_RXALL) |
| 1791 | return; | 1791 | rx_config |= (AcceptErr | AcceptRunt); |
| 1792 | else | ||
| 1793 | rx_config &= ~(AcceptErr | AcceptRunt); | ||
| 1792 | 1794 | ||
| 1793 | if (changed & (NETIF_F_RXCSUM | NETIF_F_HW_VLAN_CTAG_RX)) { | 1795 | RTL_W32(RxConfig, rx_config); |
| 1794 | if (features & NETIF_F_RXCSUM) | ||
| 1795 | tp->cp_cmd |= RxChkSum; | ||
| 1796 | else | ||
| 1797 | tp->cp_cmd &= ~RxChkSum; | ||
| 1798 | 1796 | ||
| 1799 | if (dev->features & NETIF_F_HW_VLAN_CTAG_RX) | 1797 | if (features & NETIF_F_RXCSUM) |
| 1800 | tp->cp_cmd |= RxVlan; | 1798 | tp->cp_cmd |= RxChkSum; |
| 1801 | else | 1799 | else |
| 1802 | tp->cp_cmd &= ~RxVlan; | 1800 | tp->cp_cmd &= ~RxChkSum; |
| 1803 | 1801 | ||
| 1804 | RTL_W16(CPlusCmd, tp->cp_cmd); | 1802 | if (features & NETIF_F_HW_VLAN_CTAG_RX) |
| 1805 | RTL_R16(CPlusCmd); | 1803 | tp->cp_cmd |= RxVlan; |
| 1806 | } | 1804 | else |
| 1807 | if (changed & NETIF_F_RXALL) { | 1805 | tp->cp_cmd &= ~RxVlan; |
| 1808 | int tmp = (RTL_R32(RxConfig) & ~(AcceptErr | AcceptRunt)); | 1806 | |
| 1809 | if (features & NETIF_F_RXALL) | 1807 | tp->cp_cmd |= RTL_R16(CPlusCmd) & ~(RxVlan | RxChkSum); |
| 1810 | tmp |= (AcceptErr | AcceptRunt); | 1808 | |
| 1811 | RTL_W32(RxConfig, tmp); | 1809 | RTL_W16(CPlusCmd, tp->cp_cmd); |
| 1812 | } | 1810 | RTL_R16(CPlusCmd); |
| 1813 | } | 1811 | } |
| 1814 | 1812 | ||
| 1815 | static int rtl8169_set_features(struct net_device *dev, | 1813 | static int rtl8169_set_features(struct net_device *dev, |
| @@ -1817,8 +1815,11 @@ static int rtl8169_set_features(struct net_device *dev, | |||
| 1817 | { | 1815 | { |
| 1818 | struct rtl8169_private *tp = netdev_priv(dev); | 1816 | struct rtl8169_private *tp = netdev_priv(dev); |
| 1819 | 1817 | ||
| 1818 | features &= NETIF_F_RXALL | NETIF_F_RXCSUM | NETIF_F_HW_VLAN_CTAG_RX; | ||
| 1819 | |||
| 1820 | rtl_lock_work(tp); | 1820 | rtl_lock_work(tp); |
| 1821 | __rtl8169_set_features(dev, features); | 1821 | if (features ^ dev->features) |
| 1822 | __rtl8169_set_features(dev, features); | ||
| 1822 | rtl_unlock_work(tp); | 1823 | rtl_unlock_work(tp); |
| 1823 | 1824 | ||
| 1824 | return 0; | 1825 | return 0; |
| @@ -7118,8 +7119,7 @@ static void rtl_hw_initialize(struct rtl8169_private *tp) | |||
| 7118 | } | 7119 | } |
| 7119 | } | 7120 | } |
| 7120 | 7121 | ||
| 7121 | static int | 7122 | static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) |
| 7122 | rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | ||
| 7123 | { | 7123 | { |
| 7124 | const struct rtl_cfg_info *cfg = rtl_cfg_infos + ent->driver_data; | 7124 | const struct rtl_cfg_info *cfg = rtl_cfg_infos + ent->driver_data; |
| 7125 | const unsigned int region = cfg->region; | 7125 | const unsigned int region = cfg->region; |
| @@ -7194,7 +7194,7 @@ rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 7194 | goto err_out_mwi_2; | 7194 | goto err_out_mwi_2; |
| 7195 | } | 7195 | } |
| 7196 | 7196 | ||
| 7197 | tp->cp_cmd = RxChkSum; | 7197 | tp->cp_cmd = 0; |
| 7198 | 7198 | ||
| 7199 | if ((sizeof(dma_addr_t) > 4) && | 7199 | if ((sizeof(dma_addr_t) > 4) && |
| 7200 | !pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) && use_dac) { | 7200 | !pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) && use_dac) { |
| @@ -7235,13 +7235,6 @@ rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 7235 | 7235 | ||
| 7236 | pci_set_master(pdev); | 7236 | pci_set_master(pdev); |
| 7237 | 7237 | ||
| 7238 | /* | ||
| 7239 | * Pretend we are using VLANs; This bypasses a nasty bug where | ||
| 7240 | * Interrupts stop flowing on high load on 8110SCd controllers. | ||
| 7241 | */ | ||
| 7242 | if (tp->mac_version == RTL_GIGA_MAC_VER_05) | ||
| 7243 | tp->cp_cmd |= RxVlan; | ||
| 7244 | |||
| 7245 | rtl_init_mdio_ops(tp); | 7238 | rtl_init_mdio_ops(tp); |
| 7246 | rtl_init_pll_power_ops(tp); | 7239 | rtl_init_pll_power_ops(tp); |
| 7247 | rtl_init_jumbo_ops(tp); | 7240 | rtl_init_jumbo_ops(tp); |
| @@ -7302,8 +7295,14 @@ rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
| 7302 | dev->vlan_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO | | 7295 | dev->vlan_features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO | |
| 7303 | NETIF_F_HIGHDMA; | 7296 | NETIF_F_HIGHDMA; |
| 7304 | 7297 | ||
| 7298 | tp->cp_cmd |= RxChkSum | RxVlan; | ||
| 7299 | |||
| 7300 | /* | ||
| 7301 | * Pretend we are using VLANs; This bypasses a nasty bug where | ||
| 7302 | * Interrupts stop flowing on high load on 8110SCd controllers. | ||
| 7303 | */ | ||
| 7305 | if (tp->mac_version == RTL_GIGA_MAC_VER_05) | 7304 | if (tp->mac_version == RTL_GIGA_MAC_VER_05) |
| 7306 | /* 8110SCd requires hardware Rx VLAN - disallow toggling */ | 7305 | /* Disallow toggling */ |
| 7307 | dev->hw_features &= ~NETIF_F_HW_VLAN_CTAG_RX; | 7306 | dev->hw_features &= ~NETIF_F_HW_VLAN_CTAG_RX; |
| 7308 | 7307 | ||
| 7309 | if (tp->txd_version == RTL_TD_0) | 7308 | if (tp->txd_version == RTL_TD_0) |
diff --git a/drivers/net/ethernet/sfc/farch.c b/drivers/net/ethernet/sfc/farch.c index 0537381cd2f6..6859437b59fb 100644 --- a/drivers/net/ethernet/sfc/farch.c +++ b/drivers/net/ethernet/sfc/farch.c | |||
| @@ -2933,6 +2933,9 @@ void efx_farch_filter_sync_rx_mode(struct efx_nic *efx) | |||
| 2933 | u32 crc; | 2933 | u32 crc; |
| 2934 | int bit; | 2934 | int bit; |
| 2935 | 2935 | ||
| 2936 | if (!efx_dev_registered(efx)) | ||
| 2937 | return; | ||
| 2938 | |||
| 2936 | netif_addr_lock_bh(net_dev); | 2939 | netif_addr_lock_bh(net_dev); |
| 2937 | 2940 | ||
| 2938 | efx->unicast_filter = !(net_dev->flags & IFF_PROMISC); | 2941 | efx->unicast_filter = !(net_dev->flags & IFF_PROMISC); |
diff --git a/drivers/net/ethernet/sun/sunvnet.c b/drivers/net/ethernet/sun/sunvnet.c index 23c89ab5a6ad..f67539650c38 100644 --- a/drivers/net/ethernet/sun/sunvnet.c +++ b/drivers/net/ethernet/sun/sunvnet.c | |||
| @@ -350,14 +350,17 @@ static int vnet_walk_rx_one(struct vnet_port *port, | |||
| 350 | if (IS_ERR(desc)) | 350 | if (IS_ERR(desc)) |
| 351 | return PTR_ERR(desc); | 351 | return PTR_ERR(desc); |
| 352 | 352 | ||
| 353 | if (desc->hdr.state != VIO_DESC_READY) | ||
| 354 | return 1; | ||
| 355 | |||
| 356 | rmb(); | ||
| 357 | |||
| 353 | viodbg(DATA, "vio_walk_rx_one desc[%02x:%02x:%08x:%08x:%llx:%llx]\n", | 358 | viodbg(DATA, "vio_walk_rx_one desc[%02x:%02x:%08x:%08x:%llx:%llx]\n", |
| 354 | desc->hdr.state, desc->hdr.ack, | 359 | desc->hdr.state, desc->hdr.ack, |
| 355 | desc->size, desc->ncookies, | 360 | desc->size, desc->ncookies, |
| 356 | desc->cookies[0].cookie_addr, | 361 | desc->cookies[0].cookie_addr, |
| 357 | desc->cookies[0].cookie_size); | 362 | desc->cookies[0].cookie_size); |
| 358 | 363 | ||
| 359 | if (desc->hdr.state != VIO_DESC_READY) | ||
| 360 | return 1; | ||
| 361 | err = vnet_rx_one(port, desc->size, desc->cookies, desc->ncookies); | 364 | err = vnet_rx_one(port, desc->size, desc->cookies, desc->ncookies); |
| 362 | if (err == -ECONNRESET) | 365 | if (err == -ECONNRESET) |
| 363 | return err; | 366 | return err; |
diff --git a/drivers/net/ethernet/ti/cpsw.c b/drivers/net/ethernet/ti/cpsw.c index 999fb72688d2..e2a00287f8eb 100644 --- a/drivers/net/ethernet/ti/cpsw.c +++ b/drivers/net/ethernet/ti/cpsw.c | |||
| @@ -699,6 +699,28 @@ static void cpsw_rx_handler(void *token, int len, int status) | |||
| 699 | cpsw_dual_emac_src_port_detect(status, priv, ndev, skb); | 699 | cpsw_dual_emac_src_port_detect(status, priv, ndev, skb); |
| 700 | 700 | ||
| 701 | if (unlikely(status < 0) || unlikely(!netif_running(ndev))) { | 701 | if (unlikely(status < 0) || unlikely(!netif_running(ndev))) { |
| 702 | bool ndev_status = false; | ||
| 703 | struct cpsw_slave *slave = priv->slaves; | ||
| 704 | int n; | ||
| 705 | |||
| 706 | if (priv->data.dual_emac) { | ||
| 707 | /* In dual emac mode check for all interfaces */ | ||
| 708 | for (n = priv->data.slaves; n; n--, slave++) | ||
| 709 | if (netif_running(slave->ndev)) | ||
| 710 | ndev_status = true; | ||
| 711 | } | ||
| 712 | |||
| 713 | if (ndev_status && (status >= 0)) { | ||
| 714 | /* The packet received is for the interface which | ||
| 715 | * is already down and the other interface is up | ||
| 716 | * and running, intead of freeing which results | ||
| 717 | * in reducing of the number of rx descriptor in | ||
| 718 | * DMA engine, requeue skb back to cpdma. | ||
| 719 | */ | ||
| 720 | new_skb = skb; | ||
| 721 | goto requeue; | ||
| 722 | } | ||
| 723 | |||
| 702 | /* the interface is going down, skbs are purged */ | 724 | /* the interface is going down, skbs are purged */ |
| 703 | dev_kfree_skb_any(skb); | 725 | dev_kfree_skb_any(skb); |
| 704 | return; | 726 | return; |
| @@ -717,6 +739,7 @@ static void cpsw_rx_handler(void *token, int len, int status) | |||
| 717 | new_skb = skb; | 739 | new_skb = skb; |
| 718 | } | 740 | } |
| 719 | 741 | ||
| 742 | requeue: | ||
| 720 | ret = cpdma_chan_submit(priv->rxch, new_skb, new_skb->data, | 743 | ret = cpdma_chan_submit(priv->rxch, new_skb, new_skb->data, |
| 721 | skb_tailroom(new_skb), 0); | 744 | skb_tailroom(new_skb), 0); |
| 722 | if (WARN_ON(ret < 0)) | 745 | if (WARN_ON(ret < 0)) |
| @@ -2311,10 +2334,19 @@ static int cpsw_suspend(struct device *dev) | |||
| 2311 | struct net_device *ndev = platform_get_drvdata(pdev); | 2334 | struct net_device *ndev = platform_get_drvdata(pdev); |
| 2312 | struct cpsw_priv *priv = netdev_priv(ndev); | 2335 | struct cpsw_priv *priv = netdev_priv(ndev); |
| 2313 | 2336 | ||
| 2314 | if (netif_running(ndev)) | 2337 | if (priv->data.dual_emac) { |
| 2315 | cpsw_ndo_stop(ndev); | 2338 | int i; |
| 2316 | 2339 | ||
| 2317 | for_each_slave(priv, soft_reset_slave); | 2340 | for (i = 0; i < priv->data.slaves; i++) { |
| 2341 | if (netif_running(priv->slaves[i].ndev)) | ||
| 2342 | cpsw_ndo_stop(priv->slaves[i].ndev); | ||
| 2343 | soft_reset_slave(priv->slaves + i); | ||
| 2344 | } | ||
| 2345 | } else { | ||
| 2346 | if (netif_running(ndev)) | ||
| 2347 | cpsw_ndo_stop(ndev); | ||
| 2348 | for_each_slave(priv, soft_reset_slave); | ||
| 2349 | } | ||
| 2318 | 2350 | ||
| 2319 | pm_runtime_put_sync(&pdev->dev); | 2351 | pm_runtime_put_sync(&pdev->dev); |
| 2320 | 2352 | ||
| @@ -2328,14 +2360,24 @@ static int cpsw_resume(struct device *dev) | |||
| 2328 | { | 2360 | { |
| 2329 | struct platform_device *pdev = to_platform_device(dev); | 2361 | struct platform_device *pdev = to_platform_device(dev); |
| 2330 | struct net_device *ndev = platform_get_drvdata(pdev); | 2362 | struct net_device *ndev = platform_get_drvdata(pdev); |
| 2363 | struct cpsw_priv *priv = netdev_priv(ndev); | ||
| 2331 | 2364 | ||
| 2332 | pm_runtime_get_sync(&pdev->dev); | 2365 | pm_runtime_get_sync(&pdev->dev); |
| 2333 | 2366 | ||
| 2334 | /* Select default pin state */ | 2367 | /* Select default pin state */ |
| 2335 | pinctrl_pm_select_default_state(&pdev->dev); | 2368 | pinctrl_pm_select_default_state(&pdev->dev); |
| 2336 | 2369 | ||
| 2337 | if (netif_running(ndev)) | 2370 | if (priv->data.dual_emac) { |
| 2338 | cpsw_ndo_open(ndev); | 2371 | int i; |
| 2372 | |||
| 2373 | for (i = 0; i < priv->data.slaves; i++) { | ||
| 2374 | if (netif_running(priv->slaves[i].ndev)) | ||
| 2375 | cpsw_ndo_open(priv->slaves[i].ndev); | ||
| 2376 | } | ||
| 2377 | } else { | ||
| 2378 | if (netif_running(ndev)) | ||
| 2379 | cpsw_ndo_open(ndev); | ||
| 2380 | } | ||
| 2339 | return 0; | 2381 | return 0; |
| 2340 | } | 2382 | } |
| 2341 | 2383 | ||
diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c index a96955597755..726edabff26b 100644 --- a/drivers/net/macvlan.c +++ b/drivers/net/macvlan.c | |||
| @@ -36,6 +36,7 @@ | |||
| 36 | #include <linux/netpoll.h> | 36 | #include <linux/netpoll.h> |
| 37 | 37 | ||
| 38 | #define MACVLAN_HASH_SIZE (1 << BITS_PER_BYTE) | 38 | #define MACVLAN_HASH_SIZE (1 << BITS_PER_BYTE) |
| 39 | #define MACVLAN_BC_QUEUE_LEN 1000 | ||
| 39 | 40 | ||
| 40 | struct macvlan_port { | 41 | struct macvlan_port { |
| 41 | struct net_device *dev; | 42 | struct net_device *dev; |
| @@ -248,7 +249,7 @@ static void macvlan_broadcast_enqueue(struct macvlan_port *port, | |||
| 248 | goto err; | 249 | goto err; |
| 249 | 250 | ||
| 250 | spin_lock(&port->bc_queue.lock); | 251 | spin_lock(&port->bc_queue.lock); |
| 251 | if (skb_queue_len(&port->bc_queue) < skb->dev->tx_queue_len) { | 252 | if (skb_queue_len(&port->bc_queue) < MACVLAN_BC_QUEUE_LEN) { |
| 252 | __skb_queue_tail(&port->bc_queue, nskb); | 253 | __skb_queue_tail(&port->bc_queue, nskb); |
| 253 | err = 0; | 254 | err = 0; |
| 254 | } | 255 | } |
| @@ -806,6 +807,7 @@ static netdev_features_t macvlan_fix_features(struct net_device *dev, | |||
| 806 | features, | 807 | features, |
| 807 | mask); | 808 | mask); |
| 808 | features |= ALWAYS_ON_FEATURES; | 809 | features |= ALWAYS_ON_FEATURES; |
| 810 | features &= ~NETIF_F_NETNS_LOCAL; | ||
| 809 | 811 | ||
| 810 | return features; | 812 | return features; |
| 811 | } | 813 | } |
diff --git a/drivers/net/phy/micrel.c b/drivers/net/phy/micrel.c index fd0ea7c50ee6..011dbda2b2f1 100644 --- a/drivers/net/phy/micrel.c +++ b/drivers/net/phy/micrel.c | |||
| @@ -592,8 +592,7 @@ static struct phy_driver ksphy_driver[] = { | |||
| 592 | .phy_id = PHY_ID_KSZ9031, | 592 | .phy_id = PHY_ID_KSZ9031, |
| 593 | .phy_id_mask = 0x00fffff0, | 593 | .phy_id_mask = 0x00fffff0, |
| 594 | .name = "Micrel KSZ9031 Gigabit PHY", | 594 | .name = "Micrel KSZ9031 Gigabit PHY", |
| 595 | .features = (PHY_GBIT_FEATURES | SUPPORTED_Pause | 595 | .features = (PHY_GBIT_FEATURES | SUPPORTED_Pause), |
| 596 | | SUPPORTED_Asym_Pause), | ||
| 597 | .flags = PHY_HAS_MAGICANEG | PHY_HAS_INTERRUPT, | 596 | .flags = PHY_HAS_MAGICANEG | PHY_HAS_INTERRUPT, |
| 598 | .config_init = ksz9031_config_init, | 597 | .config_init = ksz9031_config_init, |
| 599 | .config_aneg = genphy_config_aneg, | 598 | .config_aneg = genphy_config_aneg, |
diff --git a/drivers/net/usb/r8152.c b/drivers/net/usb/r8152.c index 87f710476217..74760e8143e3 100644 --- a/drivers/net/usb/r8152.c +++ b/drivers/net/usb/r8152.c | |||
| @@ -2019,7 +2019,7 @@ static int rtl8153_enable(struct r8152 *tp) | |||
| 2019 | return rtl_enable(tp); | 2019 | return rtl_enable(tp); |
| 2020 | } | 2020 | } |
| 2021 | 2021 | ||
| 2022 | static void rtl8152_disable(struct r8152 *tp) | 2022 | static void rtl_disable(struct r8152 *tp) |
| 2023 | { | 2023 | { |
| 2024 | u32 ocp_data; | 2024 | u32 ocp_data; |
| 2025 | int i; | 2025 | int i; |
| @@ -2232,6 +2232,13 @@ static inline void r8152b_enable_aldps(struct r8152 *tp) | |||
| 2232 | LINKENA | DIS_SDSAVE); | 2232 | LINKENA | DIS_SDSAVE); |
| 2233 | } | 2233 | } |
| 2234 | 2234 | ||
| 2235 | static void rtl8152_disable(struct r8152 *tp) | ||
| 2236 | { | ||
| 2237 | r8152b_disable_aldps(tp); | ||
| 2238 | rtl_disable(tp); | ||
| 2239 | r8152b_enable_aldps(tp); | ||
| 2240 | } | ||
| 2241 | |||
| 2235 | static void r8152b_hw_phy_cfg(struct r8152 *tp) | 2242 | static void r8152b_hw_phy_cfg(struct r8152 *tp) |
| 2236 | { | 2243 | { |
| 2237 | u16 data; | 2244 | u16 data; |
| @@ -2242,11 +2249,8 @@ static void r8152b_hw_phy_cfg(struct r8152 *tp) | |||
| 2242 | r8152_mdio_write(tp, MII_BMCR, data); | 2249 | r8152_mdio_write(tp, MII_BMCR, data); |
| 2243 | } | 2250 | } |
| 2244 | 2251 | ||
| 2245 | r8152b_disable_aldps(tp); | ||
| 2246 | |||
| 2247 | rtl_clear_bp(tp); | 2252 | rtl_clear_bp(tp); |
| 2248 | 2253 | ||
| 2249 | r8152b_enable_aldps(tp); | ||
| 2250 | set_bit(PHY_RESET, &tp->flags); | 2254 | set_bit(PHY_RESET, &tp->flags); |
| 2251 | } | 2255 | } |
| 2252 | 2256 | ||
| @@ -2255,9 +2259,6 @@ static void r8152b_exit_oob(struct r8152 *tp) | |||
| 2255 | u32 ocp_data; | 2259 | u32 ocp_data; |
| 2256 | int i; | 2260 | int i; |
| 2257 | 2261 | ||
| 2258 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | ||
| 2259 | return; | ||
| 2260 | |||
| 2261 | ocp_data = ocp_read_dword(tp, MCU_TYPE_PLA, PLA_RCR); | 2262 | ocp_data = ocp_read_dword(tp, MCU_TYPE_PLA, PLA_RCR); |
| 2262 | ocp_data &= ~RCR_ACPT_ALL; | 2263 | ocp_data &= ~RCR_ACPT_ALL; |
| 2263 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RCR, ocp_data); | 2264 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RCR, ocp_data); |
| @@ -2347,7 +2348,7 @@ static void r8152b_enter_oob(struct r8152 *tp) | |||
| 2347 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RXFIFO_CTRL1, RXFIFO_THR2_OOB); | 2348 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RXFIFO_CTRL1, RXFIFO_THR2_OOB); |
| 2348 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RXFIFO_CTRL2, RXFIFO_THR3_OOB); | 2349 | ocp_write_dword(tp, MCU_TYPE_PLA, PLA_RXFIFO_CTRL2, RXFIFO_THR3_OOB); |
| 2349 | 2350 | ||
| 2350 | rtl8152_disable(tp); | 2351 | rtl_disable(tp); |
| 2351 | 2352 | ||
| 2352 | for (i = 0; i < 1000; i++) { | 2353 | for (i = 0; i < 1000; i++) { |
| 2353 | ocp_data = ocp_read_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL); | 2354 | ocp_data = ocp_read_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL); |
| @@ -2485,9 +2486,6 @@ static void r8153_first_init(struct r8152 *tp) | |||
| 2485 | u32 ocp_data; | 2486 | u32 ocp_data; |
| 2486 | int i; | 2487 | int i; |
| 2487 | 2488 | ||
| 2488 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | ||
| 2489 | return; | ||
| 2490 | |||
| 2491 | rxdy_gated_en(tp, true); | 2489 | rxdy_gated_en(tp, true); |
| 2492 | r8153_teredo_off(tp); | 2490 | r8153_teredo_off(tp); |
| 2493 | 2491 | ||
| @@ -2560,7 +2558,7 @@ static void r8153_enter_oob(struct r8152 *tp) | |||
| 2560 | ocp_data &= ~NOW_IS_OOB; | 2558 | ocp_data &= ~NOW_IS_OOB; |
| 2561 | ocp_write_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL, ocp_data); | 2559 | ocp_write_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL, ocp_data); |
| 2562 | 2560 | ||
| 2563 | rtl8152_disable(tp); | 2561 | rtl_disable(tp); |
| 2564 | 2562 | ||
| 2565 | for (i = 0; i < 1000; i++) { | 2563 | for (i = 0; i < 1000; i++) { |
| 2566 | ocp_data = ocp_read_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL); | 2564 | ocp_data = ocp_read_byte(tp, MCU_TYPE_PLA, PLA_OOB_CTRL); |
| @@ -2624,6 +2622,13 @@ static void r8153_enable_aldps(struct r8152 *tp) | |||
| 2624 | ocp_reg_write(tp, OCP_POWER_CFG, data); | 2622 | ocp_reg_write(tp, OCP_POWER_CFG, data); |
| 2625 | } | 2623 | } |
| 2626 | 2624 | ||
| 2625 | static void rtl8153_disable(struct r8152 *tp) | ||
| 2626 | { | ||
| 2627 | r8153_disable_aldps(tp); | ||
| 2628 | rtl_disable(tp); | ||
| 2629 | r8153_enable_aldps(tp); | ||
| 2630 | } | ||
| 2631 | |||
| 2627 | static int rtl8152_set_speed(struct r8152 *tp, u8 autoneg, u16 speed, u8 duplex) | 2632 | static int rtl8152_set_speed(struct r8152 *tp, u8 autoneg, u16 speed, u8 duplex) |
| 2628 | { | 2633 | { |
| 2629 | u16 bmcr, anar, gbcr; | 2634 | u16 bmcr, anar, gbcr; |
| @@ -2714,6 +2719,16 @@ out: | |||
| 2714 | return ret; | 2719 | return ret; |
| 2715 | } | 2720 | } |
| 2716 | 2721 | ||
| 2722 | static void rtl8152_up(struct r8152 *tp) | ||
| 2723 | { | ||
| 2724 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | ||
| 2725 | return; | ||
| 2726 | |||
| 2727 | r8152b_disable_aldps(tp); | ||
| 2728 | r8152b_exit_oob(tp); | ||
| 2729 | r8152b_enable_aldps(tp); | ||
| 2730 | } | ||
| 2731 | |||
| 2717 | static void rtl8152_down(struct r8152 *tp) | 2732 | static void rtl8152_down(struct r8152 *tp) |
| 2718 | { | 2733 | { |
| 2719 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) { | 2734 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) { |
| @@ -2727,6 +2742,16 @@ static void rtl8152_down(struct r8152 *tp) | |||
| 2727 | r8152b_enable_aldps(tp); | 2742 | r8152b_enable_aldps(tp); |
| 2728 | } | 2743 | } |
| 2729 | 2744 | ||
| 2745 | static void rtl8153_up(struct r8152 *tp) | ||
| 2746 | { | ||
| 2747 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | ||
| 2748 | return; | ||
| 2749 | |||
| 2750 | r8153_disable_aldps(tp); | ||
| 2751 | r8153_first_init(tp); | ||
| 2752 | r8153_enable_aldps(tp); | ||
| 2753 | } | ||
| 2754 | |||
| 2730 | static void rtl8153_down(struct r8152 *tp) | 2755 | static void rtl8153_down(struct r8152 *tp) |
| 2731 | { | 2756 | { |
| 2732 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) { | 2757 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) { |
| @@ -2946,6 +2971,8 @@ static void r8152b_init(struct r8152 *tp) | |||
| 2946 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | 2971 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) |
| 2947 | return; | 2972 | return; |
| 2948 | 2973 | ||
| 2974 | r8152b_disable_aldps(tp); | ||
| 2975 | |||
| 2949 | if (tp->version == RTL_VER_01) { | 2976 | if (tp->version == RTL_VER_01) { |
| 2950 | ocp_data = ocp_read_word(tp, MCU_TYPE_PLA, PLA_LED_FEATURE); | 2977 | ocp_data = ocp_read_word(tp, MCU_TYPE_PLA, PLA_LED_FEATURE); |
| 2951 | ocp_data &= ~LED_MODE_MASK; | 2978 | ocp_data &= ~LED_MODE_MASK; |
| @@ -2984,6 +3011,7 @@ static void r8153_init(struct r8152 *tp) | |||
| 2984 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) | 3011 | if (test_bit(RTL8152_UNPLUG, &tp->flags)) |
| 2985 | return; | 3012 | return; |
| 2986 | 3013 | ||
| 3014 | r8153_disable_aldps(tp); | ||
| 2987 | r8153_u1u2en(tp, false); | 3015 | r8153_u1u2en(tp, false); |
| 2988 | 3016 | ||
| 2989 | for (i = 0; i < 500; i++) { | 3017 | for (i = 0; i < 500; i++) { |
| @@ -3392,7 +3420,7 @@ static int rtl_ops_init(struct r8152 *tp, const struct usb_device_id *id) | |||
| 3392 | ops->init = r8152b_init; | 3420 | ops->init = r8152b_init; |
| 3393 | ops->enable = rtl8152_enable; | 3421 | ops->enable = rtl8152_enable; |
| 3394 | ops->disable = rtl8152_disable; | 3422 | ops->disable = rtl8152_disable; |
| 3395 | ops->up = r8152b_exit_oob; | 3423 | ops->up = rtl8152_up; |
| 3396 | ops->down = rtl8152_down; | 3424 | ops->down = rtl8152_down; |
| 3397 | ops->unload = rtl8152_unload; | 3425 | ops->unload = rtl8152_unload; |
| 3398 | ret = 0; | 3426 | ret = 0; |
| @@ -3400,8 +3428,8 @@ static int rtl_ops_init(struct r8152 *tp, const struct usb_device_id *id) | |||
| 3400 | case PRODUCT_ID_RTL8153: | 3428 | case PRODUCT_ID_RTL8153: |
| 3401 | ops->init = r8153_init; | 3429 | ops->init = r8153_init; |
| 3402 | ops->enable = rtl8153_enable; | 3430 | ops->enable = rtl8153_enable; |
| 3403 | ops->disable = rtl8152_disable; | 3431 | ops->disable = rtl8153_disable; |
| 3404 | ops->up = r8153_first_init; | 3432 | ops->up = rtl8153_up; |
| 3405 | ops->down = rtl8153_down; | 3433 | ops->down = rtl8153_down; |
| 3406 | ops->unload = rtl8153_unload; | 3434 | ops->unload = rtl8153_unload; |
| 3407 | ret = 0; | 3435 | ret = 0; |
| @@ -3416,8 +3444,8 @@ static int rtl_ops_init(struct r8152 *tp, const struct usb_device_id *id) | |||
| 3416 | case PRODUCT_ID_SAMSUNG: | 3444 | case PRODUCT_ID_SAMSUNG: |
| 3417 | ops->init = r8153_init; | 3445 | ops->init = r8153_init; |
| 3418 | ops->enable = rtl8153_enable; | 3446 | ops->enable = rtl8153_enable; |
| 3419 | ops->disable = rtl8152_disable; | 3447 | ops->disable = rtl8153_disable; |
| 3420 | ops->up = r8153_first_init; | 3448 | ops->up = rtl8153_up; |
| 3421 | ops->down = rtl8153_down; | 3449 | ops->down = rtl8153_down; |
| 3422 | ops->unload = rtl8153_unload; | 3450 | ops->unload = rtl8153_unload; |
| 3423 | ret = 0; | 3451 | ret = 0; |
diff --git a/drivers/net/wireless/ath/ath9k/common-beacon.c b/drivers/net/wireless/ath/ath9k/common-beacon.c index 733be5178481..6ad44470d0f2 100644 --- a/drivers/net/wireless/ath/ath9k/common-beacon.c +++ b/drivers/net/wireless/ath/ath9k/common-beacon.c | |||
| @@ -57,7 +57,7 @@ int ath9k_cmn_beacon_config_sta(struct ath_hw *ah, | |||
| 57 | struct ath9k_beacon_state *bs) | 57 | struct ath9k_beacon_state *bs) |
| 58 | { | 58 | { |
| 59 | struct ath_common *common = ath9k_hw_common(ah); | 59 | struct ath_common *common = ath9k_hw_common(ah); |
| 60 | int dtim_intval, sleepduration; | 60 | int dtim_intval; |
| 61 | u64 tsf; | 61 | u64 tsf; |
| 62 | 62 | ||
| 63 | /* No need to configure beacon if we are not associated */ | 63 | /* No need to configure beacon if we are not associated */ |
| @@ -75,7 +75,6 @@ int ath9k_cmn_beacon_config_sta(struct ath_hw *ah, | |||
| 75 | * last beacon we received (which may be none). | 75 | * last beacon we received (which may be none). |
| 76 | */ | 76 | */ |
| 77 | dtim_intval = conf->intval * conf->dtim_period; | 77 | dtim_intval = conf->intval * conf->dtim_period; |
| 78 | sleepduration = ah->hw->conf.listen_interval * conf->intval; | ||
| 79 | 78 | ||
| 80 | /* | 79 | /* |
| 81 | * Pull nexttbtt forward to reflect the current | 80 | * Pull nexttbtt forward to reflect the current |
| @@ -113,7 +112,7 @@ int ath9k_cmn_beacon_config_sta(struct ath_hw *ah, | |||
| 113 | */ | 112 | */ |
| 114 | 113 | ||
| 115 | bs->bs_sleepduration = TU_TO_USEC(roundup(IEEE80211_MS_TO_TU(100), | 114 | bs->bs_sleepduration = TU_TO_USEC(roundup(IEEE80211_MS_TO_TU(100), |
| 116 | sleepduration)); | 115 | conf->intval)); |
| 117 | if (bs->bs_sleepduration > bs->bs_dtimperiod) | 116 | if (bs->bs_sleepduration > bs->bs_dtimperiod) |
| 118 | bs->bs_sleepduration = bs->bs_dtimperiod; | 117 | bs->bs_sleepduration = bs->bs_dtimperiod; |
| 119 | 118 | ||
diff --git a/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c b/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c index bb86eb2ffc95..f0484b1b617e 100644 --- a/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c +++ b/drivers/net/wireless/ath/ath9k/htc_drv_txrx.c | |||
| @@ -978,7 +978,7 @@ static bool ath9k_rx_prepare(struct ath9k_htc_priv *priv, | |||
| 978 | struct ath_hw *ah = common->ah; | 978 | struct ath_hw *ah = common->ah; |
| 979 | struct ath_htc_rx_status *rxstatus; | 979 | struct ath_htc_rx_status *rxstatus; |
| 980 | struct ath_rx_status rx_stats; | 980 | struct ath_rx_status rx_stats; |
| 981 | bool decrypt_error; | 981 | bool decrypt_error = false; |
| 982 | 982 | ||
| 983 | if (skb->len < HTC_RX_FRAME_HEADER_SIZE) { | 983 | if (skb->len < HTC_RX_FRAME_HEADER_SIZE) { |
| 984 | ath_err(common, "Corrupted RX frame, dropping (len: %d)\n", | 984 | ath_err(common, "Corrupted RX frame, dropping (len: %d)\n", |
diff --git a/drivers/net/wireless/brcm80211/Kconfig b/drivers/net/wireless/brcm80211/Kconfig index b8e2561ea645..fe3dc126b149 100644 --- a/drivers/net/wireless/brcm80211/Kconfig +++ b/drivers/net/wireless/brcm80211/Kconfig | |||
| @@ -27,10 +27,17 @@ config BRCMFMAC | |||
| 27 | one of the bus interface support. If you choose to build a module, | 27 | one of the bus interface support. If you choose to build a module, |
| 28 | it'll be called brcmfmac.ko. | 28 | it'll be called brcmfmac.ko. |
| 29 | 29 | ||
| 30 | config BRCMFMAC_PROTO_BCDC | ||
| 31 | bool | ||
| 32 | |||
| 33 | config BRCMFMAC_PROTO_MSGBUF | ||
| 34 | bool | ||
| 35 | |||
| 30 | config BRCMFMAC_SDIO | 36 | config BRCMFMAC_SDIO |
| 31 | bool "SDIO bus interface support for FullMAC driver" | 37 | bool "SDIO bus interface support for FullMAC driver" |
| 32 | depends on (MMC = y || MMC = BRCMFMAC) | 38 | depends on (MMC = y || MMC = BRCMFMAC) |
| 33 | depends on BRCMFMAC | 39 | depends on BRCMFMAC |
| 40 | select BRCMFMAC_PROTO_BCDC | ||
| 34 | select FW_LOADER | 41 | select FW_LOADER |
| 35 | default y | 42 | default y |
| 36 | ---help--- | 43 | ---help--- |
| @@ -42,6 +49,7 @@ config BRCMFMAC_USB | |||
| 42 | bool "USB bus interface support for FullMAC driver" | 49 | bool "USB bus interface support for FullMAC driver" |
| 43 | depends on (USB = y || USB = BRCMFMAC) | 50 | depends on (USB = y || USB = BRCMFMAC) |
| 44 | depends on BRCMFMAC | 51 | depends on BRCMFMAC |
| 52 | select BRCMFMAC_PROTO_BCDC | ||
| 45 | select FW_LOADER | 53 | select FW_LOADER |
| 46 | ---help--- | 54 | ---help--- |
| 47 | This option enables the USB bus interface support for Broadcom | 55 | This option enables the USB bus interface support for Broadcom |
| @@ -52,6 +60,8 @@ config BRCMFMAC_PCIE | |||
| 52 | bool "PCIE bus interface support for FullMAC driver" | 60 | bool "PCIE bus interface support for FullMAC driver" |
| 53 | depends on BRCMFMAC | 61 | depends on BRCMFMAC |
| 54 | depends on PCI | 62 | depends on PCI |
| 63 | depends on HAS_DMA | ||
| 64 | select BRCMFMAC_PROTO_MSGBUF | ||
| 55 | select FW_LOADER | 65 | select FW_LOADER |
| 56 | ---help--- | 66 | ---help--- |
| 57 | This option enables the PCIE bus interface support for Broadcom | 67 | This option enables the PCIE bus interface support for Broadcom |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/Makefile b/drivers/net/wireless/brcm80211/brcmfmac/Makefile index c35adf4bc70b..90a977fe9a64 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/Makefile +++ b/drivers/net/wireless/brcm80211/brcmfmac/Makefile | |||
| @@ -30,16 +30,18 @@ brcmfmac-objs += \ | |||
| 30 | fwsignal.o \ | 30 | fwsignal.o \ |
| 31 | p2p.o \ | 31 | p2p.o \ |
| 32 | proto.o \ | 32 | proto.o \ |
| 33 | bcdc.o \ | ||
| 34 | commonring.o \ | ||
| 35 | flowring.o \ | ||
| 36 | msgbuf.o \ | ||
| 37 | dhd_common.o \ | 33 | dhd_common.o \ |
| 38 | dhd_linux.o \ | 34 | dhd_linux.o \ |
| 39 | firmware.o \ | 35 | firmware.o \ |
| 40 | feature.o \ | 36 | feature.o \ |
| 41 | btcoex.o \ | 37 | btcoex.o \ |
| 42 | vendor.o | 38 | vendor.o |
| 39 | brcmfmac-$(CONFIG_BRCMFMAC_PROTO_BCDC) += \ | ||
| 40 | bcdc.o | ||
| 41 | brcmfmac-$(CONFIG_BRCMFMAC_PROTO_MSGBUF) += \ | ||
| 42 | commonring.o \ | ||
| 43 | flowring.o \ | ||
| 44 | msgbuf.o | ||
| 43 | brcmfmac-$(CONFIG_BRCMFMAC_SDIO) += \ | 45 | brcmfmac-$(CONFIG_BRCMFMAC_SDIO) += \ |
| 44 | dhd_sdio.o \ | 46 | dhd_sdio.o \ |
| 45 | bcmsdh.o | 47 | bcmsdh.o |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/bcdc.h b/drivers/net/wireless/brcm80211/brcmfmac/bcdc.h index 17e8c039ff32..6003179c0ceb 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/bcdc.h +++ b/drivers/net/wireless/brcm80211/brcmfmac/bcdc.h | |||
| @@ -16,9 +16,12 @@ | |||
| 16 | #ifndef BRCMFMAC_BCDC_H | 16 | #ifndef BRCMFMAC_BCDC_H |
| 17 | #define BRCMFMAC_BCDC_H | 17 | #define BRCMFMAC_BCDC_H |
| 18 | 18 | ||
| 19 | 19 | #ifdef CONFIG_BRCMFMAC_PROTO_BCDC | |
| 20 | int brcmf_proto_bcdc_attach(struct brcmf_pub *drvr); | 20 | int brcmf_proto_bcdc_attach(struct brcmf_pub *drvr); |
| 21 | void brcmf_proto_bcdc_detach(struct brcmf_pub *drvr); | 21 | void brcmf_proto_bcdc_detach(struct brcmf_pub *drvr); |
| 22 | 22 | #else | |
| 23 | static inline int brcmf_proto_bcdc_attach(struct brcmf_pub *drvr) { return 0; } | ||
| 24 | static inline void brcmf_proto_bcdc_detach(struct brcmf_pub *drvr) {} | ||
| 25 | #endif | ||
| 23 | 26 | ||
| 24 | #endif /* BRCMFMAC_BCDC_H */ | 27 | #endif /* BRCMFMAC_BCDC_H */ |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/fweh.c b/drivers/net/wireless/brcm80211/brcmfmac/fweh.c index 4f1daabc551b..44fc85f68f7a 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/fweh.c +++ b/drivers/net/wireless/brcm80211/brcmfmac/fweh.c | |||
| @@ -185,7 +185,13 @@ static void brcmf_fweh_handle_if_event(struct brcmf_pub *drvr, | |||
| 185 | ifevent->action, ifevent->ifidx, ifevent->bssidx, | 185 | ifevent->action, ifevent->ifidx, ifevent->bssidx, |
| 186 | ifevent->flags, ifevent->role); | 186 | ifevent->flags, ifevent->role); |
| 187 | 187 | ||
| 188 | if (ifevent->flags & BRCMF_E_IF_FLAG_NOIF) { | 188 | /* The P2P Device interface event must not be ignored |
| 189 | * contrary to what firmware tells us. The only way to | ||
| 190 | * distinguish the P2P Device is by looking at the ifidx | ||
| 191 | * and bssidx received. | ||
| 192 | */ | ||
| 193 | if (!(ifevent->ifidx == 0 && ifevent->bssidx == 1) && | ||
| 194 | (ifevent->flags & BRCMF_E_IF_FLAG_NOIF)) { | ||
| 189 | brcmf_dbg(EVENT, "event can be ignored\n"); | 195 | brcmf_dbg(EVENT, "event can be ignored\n"); |
| 190 | return; | 196 | return; |
| 191 | } | 197 | } |
| @@ -210,12 +216,12 @@ static void brcmf_fweh_handle_if_event(struct brcmf_pub *drvr, | |||
| 210 | return; | 216 | return; |
| 211 | } | 217 | } |
| 212 | 218 | ||
| 213 | if (ifevent->action == BRCMF_E_IF_CHANGE) | 219 | if (ifp && ifevent->action == BRCMF_E_IF_CHANGE) |
| 214 | brcmf_fws_reset_interface(ifp); | 220 | brcmf_fws_reset_interface(ifp); |
| 215 | 221 | ||
| 216 | err = brcmf_fweh_call_event_handler(ifp, emsg->event_code, emsg, data); | 222 | err = brcmf_fweh_call_event_handler(ifp, emsg->event_code, emsg, data); |
| 217 | 223 | ||
| 218 | if (ifevent->action == BRCMF_E_IF_DEL) { | 224 | if (ifp && ifevent->action == BRCMF_E_IF_DEL) { |
| 219 | brcmf_fws_del_interface(ifp); | 225 | brcmf_fws_del_interface(ifp); |
| 220 | brcmf_del_if(drvr, ifevent->bssidx); | 226 | brcmf_del_if(drvr, ifevent->bssidx); |
| 221 | } | 227 | } |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/fweh.h b/drivers/net/wireless/brcm80211/brcmfmac/fweh.h index dd20b1862d44..cbf033f59109 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/fweh.h +++ b/drivers/net/wireless/brcm80211/brcmfmac/fweh.h | |||
| @@ -172,6 +172,8 @@ enum brcmf_fweh_event_code { | |||
| 172 | #define BRCMF_E_IF_ROLE_STA 0 | 172 | #define BRCMF_E_IF_ROLE_STA 0 |
| 173 | #define BRCMF_E_IF_ROLE_AP 1 | 173 | #define BRCMF_E_IF_ROLE_AP 1 |
| 174 | #define BRCMF_E_IF_ROLE_WDS 2 | 174 | #define BRCMF_E_IF_ROLE_WDS 2 |
| 175 | #define BRCMF_E_IF_ROLE_P2P_GO 3 | ||
| 176 | #define BRCMF_E_IF_ROLE_P2P_CLIENT 4 | ||
| 175 | 177 | ||
| 176 | /** | 178 | /** |
| 177 | * definitions for event packet validation. | 179 | * definitions for event packet validation. |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/msgbuf.h b/drivers/net/wireless/brcm80211/brcmfmac/msgbuf.h index f901ae52bf2b..77a51b8c1e12 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/msgbuf.h +++ b/drivers/net/wireless/brcm80211/brcmfmac/msgbuf.h | |||
| @@ -15,6 +15,7 @@ | |||
| 15 | #ifndef BRCMFMAC_MSGBUF_H | 15 | #ifndef BRCMFMAC_MSGBUF_H |
| 16 | #define BRCMFMAC_MSGBUF_H | 16 | #define BRCMFMAC_MSGBUF_H |
| 17 | 17 | ||
| 18 | #ifdef CONFIG_BRCMFMAC_PROTO_MSGBUF | ||
| 18 | 19 | ||
| 19 | #define BRCMF_H2D_MSGRING_CONTROL_SUBMIT_MAX_ITEM 20 | 20 | #define BRCMF_H2D_MSGRING_CONTROL_SUBMIT_MAX_ITEM 20 |
| 20 | #define BRCMF_H2D_MSGRING_RXPOST_SUBMIT_MAX_ITEM 256 | 21 | #define BRCMF_H2D_MSGRING_RXPOST_SUBMIT_MAX_ITEM 256 |
| @@ -32,9 +33,15 @@ | |||
| 32 | 33 | ||
| 33 | 34 | ||
| 34 | int brcmf_proto_msgbuf_rx_trigger(struct device *dev); | 35 | int brcmf_proto_msgbuf_rx_trigger(struct device *dev); |
| 36 | void brcmf_msgbuf_delete_flowring(struct brcmf_pub *drvr, u8 flowid); | ||
| 35 | int brcmf_proto_msgbuf_attach(struct brcmf_pub *drvr); | 37 | int brcmf_proto_msgbuf_attach(struct brcmf_pub *drvr); |
| 36 | void brcmf_proto_msgbuf_detach(struct brcmf_pub *drvr); | 38 | void brcmf_proto_msgbuf_detach(struct brcmf_pub *drvr); |
| 37 | void brcmf_msgbuf_delete_flowring(struct brcmf_pub *drvr, u8 flowid); | 39 | #else |
| 38 | 40 | static inline int brcmf_proto_msgbuf_attach(struct brcmf_pub *drvr) | |
| 41 | { | ||
| 42 | return 0; | ||
| 43 | } | ||
| 44 | static inline void brcmf_proto_msgbuf_detach(struct brcmf_pub *drvr) {} | ||
| 45 | #endif | ||
| 39 | 46 | ||
| 40 | #endif /* BRCMFMAC_MSGBUF_H */ | 47 | #endif /* BRCMFMAC_MSGBUF_H */ |
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c b/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c index 02fe706fc9ec..f3a9804988a6 100644 --- a/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c +++ b/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c | |||
| @@ -497,8 +497,11 @@ brcmf_configure_arp_offload(struct brcmf_if *ifp, bool enable) | |||
| 497 | static void | 497 | static void |
| 498 | brcmf_cfg80211_update_proto_addr_mode(struct wireless_dev *wdev) | 498 | brcmf_cfg80211_update_proto_addr_mode(struct wireless_dev *wdev) |
| 499 | { | 499 | { |
| 500 | struct net_device *ndev = wdev->netdev; | 500 | struct brcmf_cfg80211_vif *vif; |
| 501 | struct brcmf_if *ifp = netdev_priv(ndev); | 501 | struct brcmf_if *ifp; |
| 502 | |||
| 503 | vif = container_of(wdev, struct brcmf_cfg80211_vif, wdev); | ||
| 504 | ifp = vif->ifp; | ||
| 502 | 505 | ||
| 503 | if ((wdev->iftype == NL80211_IFTYPE_ADHOC) || | 506 | if ((wdev->iftype == NL80211_IFTYPE_ADHOC) || |
| 504 | (wdev->iftype == NL80211_IFTYPE_AP) || | 507 | (wdev->iftype == NL80211_IFTYPE_AP) || |
| @@ -5143,6 +5146,7 @@ static int brcmf_enable_bw40_2g(struct brcmf_cfg80211_info *cfg) | |||
| 5143 | 5146 | ||
| 5144 | ch.band = BRCMU_CHAN_BAND_2G; | 5147 | ch.band = BRCMU_CHAN_BAND_2G; |
| 5145 | ch.bw = BRCMU_CHAN_BW_40; | 5148 | ch.bw = BRCMU_CHAN_BW_40; |
| 5149 | ch.sb = BRCMU_CHAN_SB_NONE; | ||
| 5146 | ch.chnum = 0; | 5150 | ch.chnum = 0; |
| 5147 | cfg->d11inf.encchspec(&ch); | 5151 | cfg->d11inf.encchspec(&ch); |
| 5148 | 5152 | ||
| @@ -5176,6 +5180,7 @@ static int brcmf_enable_bw40_2g(struct brcmf_cfg80211_info *cfg) | |||
| 5176 | 5180 | ||
| 5177 | brcmf_update_bw40_channel_flag(&band->channels[j], &ch); | 5181 | brcmf_update_bw40_channel_flag(&band->channels[j], &ch); |
| 5178 | } | 5182 | } |
| 5183 | kfree(pbuf); | ||
| 5179 | } | 5184 | } |
| 5180 | return err; | 5185 | return err; |
| 5181 | } | 5186 | } |
diff --git a/drivers/net/wireless/iwlwifi/dvm/power.c b/drivers/net/wireless/iwlwifi/dvm/power.c index 760c45c34ef3..1513dbc79c14 100644 --- a/drivers/net/wireless/iwlwifi/dvm/power.c +++ b/drivers/net/wireless/iwlwifi/dvm/power.c | |||
| @@ -40,7 +40,7 @@ | |||
| 40 | #include "commands.h" | 40 | #include "commands.h" |
| 41 | #include "power.h" | 41 | #include "power.h" |
| 42 | 42 | ||
| 43 | static bool force_cam; | 43 | static bool force_cam = true; |
| 44 | module_param(force_cam, bool, 0644); | 44 | module_param(force_cam, bool, 0644); |
| 45 | MODULE_PARM_DESC(force_cam, "force continuously aware mode (no power saving at all)"); | 45 | MODULE_PARM_DESC(force_cam, "force continuously aware mode (no power saving at all)"); |
| 46 | 46 | ||
diff --git a/drivers/net/wireless/iwlwifi/iwl-7000.c b/drivers/net/wireless/iwlwifi/iwl-7000.c index d67a37a786aa..d53adc245497 100644 --- a/drivers/net/wireless/iwlwifi/iwl-7000.c +++ b/drivers/net/wireless/iwlwifi/iwl-7000.c | |||
| @@ -83,6 +83,8 @@ | |||
| 83 | #define IWL7260_TX_POWER_VERSION 0xffff /* meaningless */ | 83 | #define IWL7260_TX_POWER_VERSION 0xffff /* meaningless */ |
| 84 | #define IWL3160_NVM_VERSION 0x709 | 84 | #define IWL3160_NVM_VERSION 0x709 |
| 85 | #define IWL3160_TX_POWER_VERSION 0xffff /* meaningless */ | 85 | #define IWL3160_TX_POWER_VERSION 0xffff /* meaningless */ |
| 86 | #define IWL3165_NVM_VERSION 0x709 | ||
| 87 | #define IWL3165_TX_POWER_VERSION 0xffff /* meaningless */ | ||
| 86 | #define IWL7265_NVM_VERSION 0x0a1d | 88 | #define IWL7265_NVM_VERSION 0x0a1d |
| 87 | #define IWL7265_TX_POWER_VERSION 0xffff /* meaningless */ | 89 | #define IWL7265_TX_POWER_VERSION 0xffff /* meaningless */ |
| 88 | 90 | ||
| @@ -92,6 +94,9 @@ | |||
| 92 | #define IWL3160_FW_PRE "iwlwifi-3160-" | 94 | #define IWL3160_FW_PRE "iwlwifi-3160-" |
| 93 | #define IWL3160_MODULE_FIRMWARE(api) IWL3160_FW_PRE __stringify(api) ".ucode" | 95 | #define IWL3160_MODULE_FIRMWARE(api) IWL3160_FW_PRE __stringify(api) ".ucode" |
| 94 | 96 | ||
| 97 | #define IWL3165_FW_PRE "iwlwifi-3165-" | ||
| 98 | #define IWL3165_MODULE_FIRMWARE(api) IWL3165_FW_PRE __stringify(api) ".ucode" | ||
| 99 | |||
| 95 | #define IWL7265_FW_PRE "iwlwifi-7265-" | 100 | #define IWL7265_FW_PRE "iwlwifi-7265-" |
| 96 | #define IWL7265_MODULE_FIRMWARE(api) IWL7265_FW_PRE __stringify(api) ".ucode" | 101 | #define IWL7265_MODULE_FIRMWARE(api) IWL7265_FW_PRE __stringify(api) ".ucode" |
| 97 | 102 | ||
| @@ -213,6 +218,16 @@ static const struct iwl_pwr_tx_backoff iwl7265_pwr_tx_backoffs[] = { | |||
| 213 | {0}, | 218 | {0}, |
| 214 | }; | 219 | }; |
| 215 | 220 | ||
| 221 | const struct iwl_cfg iwl3165_2ac_cfg = { | ||
| 222 | .name = "Intel(R) Dual Band Wireless AC 3165", | ||
| 223 | .fw_name_pre = IWL3165_FW_PRE, | ||
| 224 | IWL_DEVICE_7000, | ||
| 225 | .ht_params = &iwl7000_ht_params, | ||
| 226 | .nvm_ver = IWL3165_NVM_VERSION, | ||
| 227 | .nvm_calib_ver = IWL3165_TX_POWER_VERSION, | ||
| 228 | .pwr_tx_backoffs = iwl7265_pwr_tx_backoffs, | ||
| 229 | }; | ||
| 230 | |||
| 216 | const struct iwl_cfg iwl7265_2ac_cfg = { | 231 | const struct iwl_cfg iwl7265_2ac_cfg = { |
| 217 | .name = "Intel(R) Dual Band Wireless AC 7265", | 232 | .name = "Intel(R) Dual Band Wireless AC 7265", |
| 218 | .fw_name_pre = IWL7265_FW_PRE, | 233 | .fw_name_pre = IWL7265_FW_PRE, |
| @@ -245,4 +260,5 @@ const struct iwl_cfg iwl7265_n_cfg = { | |||
| 245 | 260 | ||
| 246 | MODULE_FIRMWARE(IWL7260_MODULE_FIRMWARE(IWL7260_UCODE_API_OK)); | 261 | MODULE_FIRMWARE(IWL7260_MODULE_FIRMWARE(IWL7260_UCODE_API_OK)); |
| 247 | MODULE_FIRMWARE(IWL3160_MODULE_FIRMWARE(IWL3160_UCODE_API_OK)); | 262 | MODULE_FIRMWARE(IWL3160_MODULE_FIRMWARE(IWL3160_UCODE_API_OK)); |
| 263 | MODULE_FIRMWARE(IWL3165_MODULE_FIRMWARE(IWL3160_UCODE_API_OK)); | ||
| 248 | MODULE_FIRMWARE(IWL7265_MODULE_FIRMWARE(IWL7260_UCODE_API_OK)); | 264 | MODULE_FIRMWARE(IWL7265_MODULE_FIRMWARE(IWL7260_UCODE_API_OK)); |
diff --git a/drivers/net/wireless/iwlwifi/iwl-config.h b/drivers/net/wireless/iwlwifi/iwl-config.h index 8da596db9abe..3d7cc37420ae 100644 --- a/drivers/net/wireless/iwlwifi/iwl-config.h +++ b/drivers/net/wireless/iwlwifi/iwl-config.h | |||
| @@ -120,6 +120,8 @@ enum iwl_led_mode { | |||
| 120 | #define IWL_LONG_WD_TIMEOUT 10000 | 120 | #define IWL_LONG_WD_TIMEOUT 10000 |
| 121 | #define IWL_MAX_WD_TIMEOUT 120000 | 121 | #define IWL_MAX_WD_TIMEOUT 120000 |
| 122 | 122 | ||
| 123 | #define IWL_DEFAULT_MAX_TX_POWER 22 | ||
| 124 | |||
| 123 | /* Antenna presence definitions */ | 125 | /* Antenna presence definitions */ |
| 124 | #define ANT_NONE 0x0 | 126 | #define ANT_NONE 0x0 |
| 125 | #define ANT_A BIT(0) | 127 | #define ANT_A BIT(0) |
| @@ -335,6 +337,7 @@ extern const struct iwl_cfg iwl7260_n_cfg; | |||
| 335 | extern const struct iwl_cfg iwl3160_2ac_cfg; | 337 | extern const struct iwl_cfg iwl3160_2ac_cfg; |
| 336 | extern const struct iwl_cfg iwl3160_2n_cfg; | 338 | extern const struct iwl_cfg iwl3160_2n_cfg; |
| 337 | extern const struct iwl_cfg iwl3160_n_cfg; | 339 | extern const struct iwl_cfg iwl3160_n_cfg; |
| 340 | extern const struct iwl_cfg iwl3165_2ac_cfg; | ||
| 338 | extern const struct iwl_cfg iwl7265_2ac_cfg; | 341 | extern const struct iwl_cfg iwl7265_2ac_cfg; |
| 339 | extern const struct iwl_cfg iwl7265_2n_cfg; | 342 | extern const struct iwl_cfg iwl7265_2n_cfg; |
| 340 | extern const struct iwl_cfg iwl7265_n_cfg; | 343 | extern const struct iwl_cfg iwl7265_n_cfg; |
diff --git a/drivers/net/wireless/iwlwifi/iwl-nvm-parse.c b/drivers/net/wireless/iwlwifi/iwl-nvm-parse.c index 018af2957d3b..354255f08754 100644 --- a/drivers/net/wireless/iwlwifi/iwl-nvm-parse.c +++ b/drivers/net/wireless/iwlwifi/iwl-nvm-parse.c | |||
| @@ -146,8 +146,6 @@ static const u8 iwl_nvm_channels_family_8000[] = { | |||
| 146 | #define LAST_2GHZ_HT_PLUS 9 | 146 | #define LAST_2GHZ_HT_PLUS 9 |
| 147 | #define LAST_5GHZ_HT 161 | 147 | #define LAST_5GHZ_HT 161 |
| 148 | 148 | ||
| 149 | #define DEFAULT_MAX_TX_POWER 16 | ||
| 150 | |||
| 151 | /* rate data (static) */ | 149 | /* rate data (static) */ |
| 152 | static struct ieee80211_rate iwl_cfg80211_rates[] = { | 150 | static struct ieee80211_rate iwl_cfg80211_rates[] = { |
| 153 | { .bitrate = 1 * 10, .hw_value = 0, .hw_value_short = 0, }, | 151 | { .bitrate = 1 * 10, .hw_value = 0, .hw_value_short = 0, }, |
| @@ -295,7 +293,7 @@ static int iwl_init_channel_map(struct device *dev, const struct iwl_cfg *cfg, | |||
| 295 | * Default value - highest tx power value. max_power | 293 | * Default value - highest tx power value. max_power |
| 296 | * is not used in mvm, and is used for backwards compatibility | 294 | * is not used in mvm, and is used for backwards compatibility |
| 297 | */ | 295 | */ |
| 298 | channel->max_power = DEFAULT_MAX_TX_POWER; | 296 | channel->max_power = IWL_DEFAULT_MAX_TX_POWER; |
| 299 | is_5ghz = channel->band == IEEE80211_BAND_5GHZ; | 297 | is_5ghz = channel->band == IEEE80211_BAND_5GHZ; |
| 300 | IWL_DEBUG_EEPROM(dev, | 298 | IWL_DEBUG_EEPROM(dev, |
| 301 | "Ch. %d [%sGHz] %s%s%s%s%s%s%s(0x%02x %ddBm): Ad-Hoc %ssupported\n", | 299 | "Ch. %d [%sGHz] %s%s%s%s%s%s%s(0x%02x %ddBm): Ad-Hoc %ssupported\n", |
diff --git a/drivers/net/wireless/iwlwifi/mvm/coex.c b/drivers/net/wireless/iwlwifi/mvm/coex.c index 2291bbcaaeab..ce71625f497f 100644 --- a/drivers/net/wireless/iwlwifi/mvm/coex.c +++ b/drivers/net/wireless/iwlwifi/mvm/coex.c | |||
| @@ -585,8 +585,6 @@ int iwl_send_bt_init_conf(struct iwl_mvm *mvm) | |||
| 585 | lockdep_assert_held(&mvm->mutex); | 585 | lockdep_assert_held(&mvm->mutex); |
| 586 | 586 | ||
| 587 | if (unlikely(mvm->bt_force_ant_mode != BT_FORCE_ANT_DIS)) { | 587 | if (unlikely(mvm->bt_force_ant_mode != BT_FORCE_ANT_DIS)) { |
| 588 | u32 mode; | ||
| 589 | |||
| 590 | switch (mvm->bt_force_ant_mode) { | 588 | switch (mvm->bt_force_ant_mode) { |
| 591 | case BT_FORCE_ANT_BT: | 589 | case BT_FORCE_ANT_BT: |
| 592 | mode = BT_COEX_BT; | 590 | mode = BT_COEX_BT; |
| @@ -756,7 +754,8 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, | |||
| 756 | struct iwl_bt_iterator_data *data = _data; | 754 | struct iwl_bt_iterator_data *data = _data; |
| 757 | struct iwl_mvm *mvm = data->mvm; | 755 | struct iwl_mvm *mvm = data->mvm; |
| 758 | struct ieee80211_chanctx_conf *chanctx_conf; | 756 | struct ieee80211_chanctx_conf *chanctx_conf; |
| 759 | enum ieee80211_smps_mode smps_mode; | 757 | /* default smps_mode is AUTOMATIC - only used for client modes */ |
| 758 | enum ieee80211_smps_mode smps_mode = IEEE80211_SMPS_AUTOMATIC; | ||
| 760 | u32 bt_activity_grading; | 759 | u32 bt_activity_grading; |
| 761 | int ave_rssi; | 760 | int ave_rssi; |
| 762 | 761 | ||
| @@ -764,8 +763,6 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, | |||
| 764 | 763 | ||
| 765 | switch (vif->type) { | 764 | switch (vif->type) { |
| 766 | case NL80211_IFTYPE_STATION: | 765 | case NL80211_IFTYPE_STATION: |
| 767 | /* default smps_mode for BSS / P2P client is AUTOMATIC */ | ||
| 768 | smps_mode = IEEE80211_SMPS_AUTOMATIC; | ||
| 769 | break; | 766 | break; |
| 770 | case NL80211_IFTYPE_AP: | 767 | case NL80211_IFTYPE_AP: |
| 771 | if (!mvmvif->ap_ibss_active) | 768 | if (!mvmvif->ap_ibss_active) |
| @@ -797,7 +794,7 @@ static void iwl_mvm_bt_notif_iterator(void *_data, u8 *mac, | |||
| 797 | else if (bt_activity_grading >= BT_LOW_TRAFFIC) | 794 | else if (bt_activity_grading >= BT_LOW_TRAFFIC) |
| 798 | smps_mode = IEEE80211_SMPS_DYNAMIC; | 795 | smps_mode = IEEE80211_SMPS_DYNAMIC; |
| 799 | 796 | ||
| 800 | /* relax SMPS contraints for next association */ | 797 | /* relax SMPS constraints for next association */ |
| 801 | if (!vif->bss_conf.assoc) | 798 | if (!vif->bss_conf.assoc) |
| 802 | smps_mode = IEEE80211_SMPS_AUTOMATIC; | 799 | smps_mode = IEEE80211_SMPS_AUTOMATIC; |
| 803 | 800 | ||
diff --git a/drivers/net/wireless/iwlwifi/mvm/debugfs-vif.c b/drivers/net/wireless/iwlwifi/mvm/debugfs-vif.c index 2e90ff795c13..87e517bffedc 100644 --- a/drivers/net/wireless/iwlwifi/mvm/debugfs-vif.c +++ b/drivers/net/wireless/iwlwifi/mvm/debugfs-vif.c | |||
| @@ -74,8 +74,7 @@ static void iwl_dbgfs_update_pm(struct iwl_mvm *mvm, | |||
| 74 | 74 | ||
| 75 | switch (param) { | 75 | switch (param) { |
| 76 | case MVM_DEBUGFS_PM_KEEP_ALIVE: { | 76 | case MVM_DEBUGFS_PM_KEEP_ALIVE: { |
| 77 | struct ieee80211_hw *hw = mvm->hw; | 77 | int dtimper = vif->bss_conf.dtim_period ?: 1; |
| 78 | int dtimper = hw->conf.ps_dtim_period ?: 1; | ||
| 79 | int dtimper_msec = dtimper * vif->bss_conf.beacon_int; | 78 | int dtimper_msec = dtimper * vif->bss_conf.beacon_int; |
| 80 | 79 | ||
| 81 | IWL_DEBUG_POWER(mvm, "debugfs: set keep_alive= %d sec\n", val); | 80 | IWL_DEBUG_POWER(mvm, "debugfs: set keep_alive= %d sec\n", val); |
diff --git a/drivers/net/wireless/iwlwifi/mvm/fw-api.h b/drivers/net/wireless/iwlwifi/mvm/fw-api.h index 95f5b3274efb..9a922f3bd16b 100644 --- a/drivers/net/wireless/iwlwifi/mvm/fw-api.h +++ b/drivers/net/wireless/iwlwifi/mvm/fw-api.h | |||
| @@ -1563,14 +1563,14 @@ enum iwl_sf_scenario { | |||
| 1563 | 1563 | ||
| 1564 | /** | 1564 | /** |
| 1565 | * Smart Fifo configuration command. | 1565 | * Smart Fifo configuration command. |
| 1566 | * @state: smart fifo state, types listed in iwl_sf_sate. | 1566 | * @state: smart fifo state, types listed in enum %iwl_sf_sate. |
| 1567 | * @watermark: Minimum allowed availabe free space in RXF for transient state. | 1567 | * @watermark: Minimum allowed availabe free space in RXF for transient state. |
| 1568 | * @long_delay_timeouts: aging and idle timer values for each scenario | 1568 | * @long_delay_timeouts: aging and idle timer values for each scenario |
| 1569 | * in long delay state. | 1569 | * in long delay state. |
| 1570 | * @full_on_timeouts: timer values for each scenario in full on state. | 1570 | * @full_on_timeouts: timer values for each scenario in full on state. |
| 1571 | */ | 1571 | */ |
| 1572 | struct iwl_sf_cfg_cmd { | 1572 | struct iwl_sf_cfg_cmd { |
| 1573 | enum iwl_sf_state state; | 1573 | __le32 state; |
| 1574 | __le32 watermark[SF_TRANSIENT_STATES_NUMBER]; | 1574 | __le32 watermark[SF_TRANSIENT_STATES_NUMBER]; |
| 1575 | __le32 long_delay_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES]; | 1575 | __le32 long_delay_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES]; |
| 1576 | __le32 full_on_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES]; | 1576 | __le32 full_on_timeouts[SF_NUM_SCENARIO][SF_NUM_TIMEOUT_TYPES]; |
diff --git a/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c b/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c index 0e523e28cabf..8242e689ddb1 100644 --- a/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c +++ b/drivers/net/wireless/iwlwifi/mvm/mac-ctxt.c | |||
| @@ -721,11 +721,6 @@ static int iwl_mvm_mac_ctxt_cmd_sta(struct iwl_mvm *mvm, | |||
| 721 | !force_assoc_off) { | 721 | !force_assoc_off) { |
| 722 | u32 dtim_offs; | 722 | u32 dtim_offs; |
| 723 | 723 | ||
| 724 | /* Allow beacons to pass through as long as we are not | ||
| 725 | * associated, or we do not have dtim period information. | ||
| 726 | */ | ||
| 727 | cmd.filter_flags |= cpu_to_le32(MAC_FILTER_IN_BEACON); | ||
| 728 | |||
| 729 | /* | 724 | /* |
| 730 | * The DTIM count counts down, so when it is N that means N | 725 | * The DTIM count counts down, so when it is N that means N |
| 731 | * more beacon intervals happen until the DTIM TBTT. Therefore | 726 | * more beacon intervals happen until the DTIM TBTT. Therefore |
| @@ -759,6 +754,11 @@ static int iwl_mvm_mac_ctxt_cmd_sta(struct iwl_mvm *mvm, | |||
| 759 | ctxt_sta->is_assoc = cpu_to_le32(1); | 754 | ctxt_sta->is_assoc = cpu_to_le32(1); |
| 760 | } else { | 755 | } else { |
| 761 | ctxt_sta->is_assoc = cpu_to_le32(0); | 756 | ctxt_sta->is_assoc = cpu_to_le32(0); |
| 757 | |||
| 758 | /* Allow beacons to pass through as long as we are not | ||
| 759 | * associated, or we do not have dtim period information. | ||
| 760 | */ | ||
| 761 | cmd.filter_flags |= cpu_to_le32(MAC_FILTER_IN_BEACON); | ||
| 762 | } | 762 | } |
| 763 | 763 | ||
| 764 | ctxt_sta->bi = cpu_to_le32(vif->bss_conf.beacon_int); | 764 | ctxt_sta->bi = cpu_to_le32(vif->bss_conf.beacon_int); |
diff --git a/drivers/net/wireless/iwlwifi/mvm/mac80211.c b/drivers/net/wireless/iwlwifi/mvm/mac80211.c index 7c8796584c25..cdc272d776e7 100644 --- a/drivers/net/wireless/iwlwifi/mvm/mac80211.c +++ b/drivers/net/wireless/iwlwifi/mvm/mac80211.c | |||
| @@ -396,12 +396,14 @@ int iwl_mvm_mac_setup_register(struct iwl_mvm *mvm) | |||
| 396 | else | 396 | else |
| 397 | hw->wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT; | 397 | hw->wiphy->flags &= ~WIPHY_FLAG_PS_ON_BY_DEFAULT; |
| 398 | 398 | ||
| 399 | /* TODO: enable that only for firmwares that don't crash */ | 399 | if (IWL_UCODE_API(mvm->fw->ucode_ver) >= 10) { |
| 400 | /* hw->wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN; */ | 400 | hw->wiphy->flags |= WIPHY_FLAG_SUPPORTS_SCHED_SCAN; |
| 401 | hw->wiphy->max_sched_scan_ssids = PROBE_OPTION_MAX; | 401 | hw->wiphy->max_sched_scan_ssids = PROBE_OPTION_MAX; |
| 402 | hw->wiphy->max_match_sets = IWL_SCAN_MAX_PROFILES; | 402 | hw->wiphy->max_match_sets = IWL_SCAN_MAX_PROFILES; |
| 403 | /* we create the 802.11 header and zero length SSID IE. */ | 403 | /* we create the 802.11 header and zero length SSID IE. */ |
| 404 | hw->wiphy->max_sched_scan_ie_len = SCAN_OFFLOAD_PROBE_REQ_SIZE - 24 - 2; | 404 | hw->wiphy->max_sched_scan_ie_len = |
| 405 | SCAN_OFFLOAD_PROBE_REQ_SIZE - 24 - 2; | ||
| 406 | } | ||
| 405 | 407 | ||
| 406 | hw->wiphy->features |= NL80211_FEATURE_P2P_GO_CTWIN | | 408 | hw->wiphy->features |= NL80211_FEATURE_P2P_GO_CTWIN | |
| 407 | NL80211_FEATURE_LOW_PRIORITY_SCAN | | 409 | NL80211_FEATURE_LOW_PRIORITY_SCAN | |
| @@ -1524,11 +1526,6 @@ static void iwl_mvm_bss_info_changed_station(struct iwl_mvm *mvm, | |||
| 1524 | */ | 1526 | */ |
| 1525 | iwl_mvm_remove_time_event(mvm, mvmvif, | 1527 | iwl_mvm_remove_time_event(mvm, mvmvif, |
| 1526 | &mvmvif->time_event_data); | 1528 | &mvmvif->time_event_data); |
| 1527 | } else if (changes & (BSS_CHANGED_PS | BSS_CHANGED_P2P_PS | | ||
| 1528 | BSS_CHANGED_QOS)) { | ||
| 1529 | ret = iwl_mvm_power_update_mac(mvm); | ||
| 1530 | if (ret) | ||
| 1531 | IWL_ERR(mvm, "failed to update power mode\n"); | ||
| 1532 | } | 1529 | } |
| 1533 | 1530 | ||
| 1534 | if (changes & BSS_CHANGED_BEACON_INFO) { | 1531 | if (changes & BSS_CHANGED_BEACON_INFO) { |
| @@ -1536,6 +1533,12 @@ static void iwl_mvm_bss_info_changed_station(struct iwl_mvm *mvm, | |||
| 1536 | WARN_ON(iwl_mvm_enable_beacon_filter(mvm, vif, 0)); | 1533 | WARN_ON(iwl_mvm_enable_beacon_filter(mvm, vif, 0)); |
| 1537 | } | 1534 | } |
| 1538 | 1535 | ||
| 1536 | if (changes & (BSS_CHANGED_PS | BSS_CHANGED_P2P_PS | BSS_CHANGED_QOS)) { | ||
| 1537 | ret = iwl_mvm_power_update_mac(mvm); | ||
| 1538 | if (ret) | ||
| 1539 | IWL_ERR(mvm, "failed to update power mode\n"); | ||
| 1540 | } | ||
| 1541 | |||
| 1539 | if (changes & BSS_CHANGED_TXPOWER) { | 1542 | if (changes & BSS_CHANGED_TXPOWER) { |
| 1540 | IWL_DEBUG_CALIB(mvm, "Changing TX Power to %d\n", | 1543 | IWL_DEBUG_CALIB(mvm, "Changing TX Power to %d\n", |
| 1541 | bss_conf->txpower); | 1544 | bss_conf->txpower); |
diff --git a/drivers/net/wireless/iwlwifi/mvm/power.c b/drivers/net/wireless/iwlwifi/mvm/power.c index 2b2d10800a55..d9769a23c68b 100644 --- a/drivers/net/wireless/iwlwifi/mvm/power.c +++ b/drivers/net/wireless/iwlwifi/mvm/power.c | |||
| @@ -281,7 +281,6 @@ static void iwl_mvm_power_build_cmd(struct iwl_mvm *mvm, | |||
| 281 | struct ieee80211_vif *vif, | 281 | struct ieee80211_vif *vif, |
| 282 | struct iwl_mac_power_cmd *cmd) | 282 | struct iwl_mac_power_cmd *cmd) |
| 283 | { | 283 | { |
| 284 | struct ieee80211_hw *hw = mvm->hw; | ||
| 285 | struct ieee80211_chanctx_conf *chanctx_conf; | 284 | struct ieee80211_chanctx_conf *chanctx_conf; |
| 286 | struct ieee80211_channel *chan; | 285 | struct ieee80211_channel *chan; |
| 287 | int dtimper, dtimper_msec; | 286 | int dtimper, dtimper_msec; |
| @@ -292,7 +291,7 @@ static void iwl_mvm_power_build_cmd(struct iwl_mvm *mvm, | |||
| 292 | 291 | ||
| 293 | cmd->id_and_color = cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, | 292 | cmd->id_and_color = cpu_to_le32(FW_CMD_ID_AND_COLOR(mvmvif->id, |
| 294 | mvmvif->color)); | 293 | mvmvif->color)); |
| 295 | dtimper = hw->conf.ps_dtim_period ?: 1; | 294 | dtimper = vif->bss_conf.dtim_period; |
| 296 | 295 | ||
| 297 | /* | 296 | /* |
| 298 | * Regardless of power management state the driver must set | 297 | * Regardless of power management state the driver must set |
| @@ -885,7 +884,7 @@ int iwl_mvm_update_d0i3_power_mode(struct iwl_mvm *mvm, | |||
| 885 | iwl_mvm_power_build_cmd(mvm, vif, &cmd); | 884 | iwl_mvm_power_build_cmd(mvm, vif, &cmd); |
| 886 | if (enable) { | 885 | if (enable) { |
| 887 | /* configure skip over dtim up to 300 msec */ | 886 | /* configure skip over dtim up to 300 msec */ |
| 888 | int dtimper = mvm->hw->conf.ps_dtim_period ?: 1; | 887 | int dtimper = vif->bss_conf.dtim_period ?: 1; |
| 889 | int dtimper_msec = dtimper * vif->bss_conf.beacon_int; | 888 | int dtimper_msec = dtimper * vif->bss_conf.beacon_int; |
| 890 | 889 | ||
| 891 | if (WARN_ON(!dtimper_msec)) | 890 | if (WARN_ON(!dtimper_msec)) |
diff --git a/drivers/net/wireless/iwlwifi/mvm/rx.c b/drivers/net/wireless/iwlwifi/mvm/rx.c index 4b98987fc413..bf5cd8c8b0f7 100644 --- a/drivers/net/wireless/iwlwifi/mvm/rx.c +++ b/drivers/net/wireless/iwlwifi/mvm/rx.c | |||
| @@ -149,13 +149,13 @@ static void iwl_mvm_get_signal_strength(struct iwl_mvm *mvm, | |||
| 149 | le32_to_cpu(phy_info->non_cfg_phy[IWL_RX_INFO_ENERGY_ANT_ABC_IDX]); | 149 | le32_to_cpu(phy_info->non_cfg_phy[IWL_RX_INFO_ENERGY_ANT_ABC_IDX]); |
| 150 | energy_a = (val & IWL_RX_INFO_ENERGY_ANT_A_MSK) >> | 150 | energy_a = (val & IWL_RX_INFO_ENERGY_ANT_A_MSK) >> |
| 151 | IWL_RX_INFO_ENERGY_ANT_A_POS; | 151 | IWL_RX_INFO_ENERGY_ANT_A_POS; |
| 152 | energy_a = energy_a ? -energy_a : -256; | 152 | energy_a = energy_a ? -energy_a : S8_MIN; |
| 153 | energy_b = (val & IWL_RX_INFO_ENERGY_ANT_B_MSK) >> | 153 | energy_b = (val & IWL_RX_INFO_ENERGY_ANT_B_MSK) >> |
| 154 | IWL_RX_INFO_ENERGY_ANT_B_POS; | 154 | IWL_RX_INFO_ENERGY_ANT_B_POS; |
| 155 | energy_b = energy_b ? -energy_b : -256; | 155 | energy_b = energy_b ? -energy_b : S8_MIN; |
| 156 | energy_c = (val & IWL_RX_INFO_ENERGY_ANT_C_MSK) >> | 156 | energy_c = (val & IWL_RX_INFO_ENERGY_ANT_C_MSK) >> |
| 157 | IWL_RX_INFO_ENERGY_ANT_C_POS; | 157 | IWL_RX_INFO_ENERGY_ANT_C_POS; |
| 158 | energy_c = energy_c ? -energy_c : -256; | 158 | energy_c = energy_c ? -energy_c : S8_MIN; |
| 159 | max_energy = max(energy_a, energy_b); | 159 | max_energy = max(energy_a, energy_b); |
| 160 | max_energy = max(max_energy, energy_c); | 160 | max_energy = max(max_energy, energy_c); |
| 161 | 161 | ||
diff --git a/drivers/net/wireless/iwlwifi/mvm/sf.c b/drivers/net/wireless/iwlwifi/mvm/sf.c index 7edfd15efc9d..e843b67f2201 100644 --- a/drivers/net/wireless/iwlwifi/mvm/sf.c +++ b/drivers/net/wireless/iwlwifi/mvm/sf.c | |||
| @@ -172,7 +172,7 @@ static int iwl_mvm_sf_config(struct iwl_mvm *mvm, u8 sta_id, | |||
| 172 | enum iwl_sf_state new_state) | 172 | enum iwl_sf_state new_state) |
| 173 | { | 173 | { |
| 174 | struct iwl_sf_cfg_cmd sf_cmd = { | 174 | struct iwl_sf_cfg_cmd sf_cmd = { |
| 175 | .state = new_state, | 175 | .state = cpu_to_le32(new_state), |
| 176 | }; | 176 | }; |
| 177 | struct ieee80211_sta *sta; | 177 | struct ieee80211_sta *sta; |
| 178 | int ret = 0; | 178 | int ret = 0; |
diff --git a/drivers/net/wireless/iwlwifi/mvm/tx.c b/drivers/net/wireless/iwlwifi/mvm/tx.c index dbc870713882..9ee410bf6da2 100644 --- a/drivers/net/wireless/iwlwifi/mvm/tx.c +++ b/drivers/net/wireless/iwlwifi/mvm/tx.c | |||
| @@ -168,10 +168,14 @@ static void iwl_mvm_set_tx_cmd_rate(struct iwl_mvm *mvm, | |||
| 168 | 168 | ||
| 169 | /* | 169 | /* |
| 170 | * for data packets, rate info comes from the table inside the fw. This | 170 | * for data packets, rate info comes from the table inside the fw. This |
| 171 | * table is controlled by LINK_QUALITY commands | 171 | * table is controlled by LINK_QUALITY commands. Exclude ctrl port |
| 172 | * frames like EAPOLs which should be treated as mgmt frames. This | ||
| 173 | * avoids them being sent initially in high rates which increases the | ||
| 174 | * chances for completion of the 4-Way handshake. | ||
| 172 | */ | 175 | */ |
| 173 | 176 | ||
| 174 | if (ieee80211_is_data(fc) && sta) { | 177 | if (ieee80211_is_data(fc) && sta && |
| 178 | !(info->control.flags & IEEE80211_TX_CTRL_PORT_CTRL_PROTO)) { | ||
| 175 | tx_cmd->initial_rate_index = 0; | 179 | tx_cmd->initial_rate_index = 0; |
| 176 | tx_cmd->tx_flags |= cpu_to_le32(TX_CMD_FLG_STA_RATE); | 180 | tx_cmd->tx_flags |= cpu_to_le32(TX_CMD_FLG_STA_RATE); |
| 177 | return; | 181 | return; |
diff --git a/drivers/net/wireless/iwlwifi/pcie/drv.c b/drivers/net/wireless/iwlwifi/pcie/drv.c index f0e722ced080..073a68b97a72 100644 --- a/drivers/net/wireless/iwlwifi/pcie/drv.c +++ b/drivers/net/wireless/iwlwifi/pcie/drv.c | |||
| @@ -352,11 +352,17 @@ static const struct pci_device_id iwl_hw_card_ids[] = { | |||
| 352 | {IWL_PCI_DEVICE(0x08B3, 0x8060, iwl3160_2n_cfg)}, | 352 | {IWL_PCI_DEVICE(0x08B3, 0x8060, iwl3160_2n_cfg)}, |
| 353 | {IWL_PCI_DEVICE(0x08B3, 0x8062, iwl3160_n_cfg)}, | 353 | {IWL_PCI_DEVICE(0x08B3, 0x8062, iwl3160_n_cfg)}, |
| 354 | {IWL_PCI_DEVICE(0x08B4, 0x8270, iwl3160_2ac_cfg)}, | 354 | {IWL_PCI_DEVICE(0x08B4, 0x8270, iwl3160_2ac_cfg)}, |
| 355 | {IWL_PCI_DEVICE(0x08B4, 0x8370, iwl3160_2ac_cfg)}, | ||
| 356 | {IWL_PCI_DEVICE(0x08B4, 0x8272, iwl3160_2ac_cfg)}, | ||
| 355 | {IWL_PCI_DEVICE(0x08B3, 0x8470, iwl3160_2ac_cfg)}, | 357 | {IWL_PCI_DEVICE(0x08B3, 0x8470, iwl3160_2ac_cfg)}, |
| 356 | {IWL_PCI_DEVICE(0x08B3, 0x8570, iwl3160_2ac_cfg)}, | 358 | {IWL_PCI_DEVICE(0x08B3, 0x8570, iwl3160_2ac_cfg)}, |
| 357 | {IWL_PCI_DEVICE(0x08B3, 0x1070, iwl3160_2ac_cfg)}, | 359 | {IWL_PCI_DEVICE(0x08B3, 0x1070, iwl3160_2ac_cfg)}, |
| 358 | {IWL_PCI_DEVICE(0x08B3, 0x1170, iwl3160_2ac_cfg)}, | 360 | {IWL_PCI_DEVICE(0x08B3, 0x1170, iwl3160_2ac_cfg)}, |
| 359 | 361 | ||
| 362 | /* 3165 Series */ | ||
| 363 | {IWL_PCI_DEVICE(0x3165, 0x4010, iwl3165_2ac_cfg)}, | ||
| 364 | {IWL_PCI_DEVICE(0x3165, 0x4210, iwl3165_2ac_cfg)}, | ||
| 365 | |||
| 360 | /* 7265 Series */ | 366 | /* 7265 Series */ |
| 361 | {IWL_PCI_DEVICE(0x095A, 0x5010, iwl7265_2ac_cfg)}, | 367 | {IWL_PCI_DEVICE(0x095A, 0x5010, iwl7265_2ac_cfg)}, |
| 362 | {IWL_PCI_DEVICE(0x095A, 0x5110, iwl7265_2ac_cfg)}, | 368 | {IWL_PCI_DEVICE(0x095A, 0x5110, iwl7265_2ac_cfg)}, |
| @@ -378,6 +384,7 @@ static const struct pci_device_id iwl_hw_card_ids[] = { | |||
| 378 | {IWL_PCI_DEVICE(0x095B, 0x5202, iwl7265_n_cfg)}, | 384 | {IWL_PCI_DEVICE(0x095B, 0x5202, iwl7265_n_cfg)}, |
| 379 | {IWL_PCI_DEVICE(0x095A, 0x9010, iwl7265_2ac_cfg)}, | 385 | {IWL_PCI_DEVICE(0x095A, 0x9010, iwl7265_2ac_cfg)}, |
| 380 | {IWL_PCI_DEVICE(0x095A, 0x9012, iwl7265_2ac_cfg)}, | 386 | {IWL_PCI_DEVICE(0x095A, 0x9012, iwl7265_2ac_cfg)}, |
| 387 | {IWL_PCI_DEVICE(0x095A, 0x900A, iwl7265_2ac_cfg)}, | ||
| 381 | {IWL_PCI_DEVICE(0x095A, 0x9110, iwl7265_2ac_cfg)}, | 388 | {IWL_PCI_DEVICE(0x095A, 0x9110, iwl7265_2ac_cfg)}, |
| 382 | {IWL_PCI_DEVICE(0x095A, 0x9112, iwl7265_2ac_cfg)}, | 389 | {IWL_PCI_DEVICE(0x095A, 0x9112, iwl7265_2ac_cfg)}, |
| 383 | {IWL_PCI_DEVICE(0x095A, 0x9210, iwl7265_2ac_cfg)}, | 390 | {IWL_PCI_DEVICE(0x095A, 0x9210, iwl7265_2ac_cfg)}, |
diff --git a/drivers/scsi/Kconfig b/drivers/scsi/Kconfig index 18a3358eb1d4..bd85fb4978e0 100644 --- a/drivers/scsi/Kconfig +++ b/drivers/scsi/Kconfig | |||
| @@ -43,7 +43,7 @@ config SCSI_DMA | |||
| 43 | config SCSI_NETLINK | 43 | config SCSI_NETLINK |
| 44 | bool | 44 | bool |
| 45 | default n | 45 | default n |
| 46 | select NET | 46 | depends on NET |
| 47 | 47 | ||
| 48 | config SCSI_PROC_FS | 48 | config SCSI_PROC_FS |
| 49 | bool "legacy /proc/scsi/ support" | 49 | bool "legacy /proc/scsi/ support" |
| @@ -257,7 +257,7 @@ config SCSI_SPI_ATTRS | |||
| 257 | 257 | ||
| 258 | config SCSI_FC_ATTRS | 258 | config SCSI_FC_ATTRS |
| 259 | tristate "FiberChannel Transport Attributes" | 259 | tristate "FiberChannel Transport Attributes" |
| 260 | depends on SCSI | 260 | depends on SCSI && NET |
| 261 | select SCSI_NETLINK | 261 | select SCSI_NETLINK |
| 262 | help | 262 | help |
| 263 | If you wish to export transport-specific information about | 263 | If you wish to export transport-specific information about |
| @@ -585,28 +585,28 @@ config HYPERV_STORAGE | |||
| 585 | 585 | ||
| 586 | config LIBFC | 586 | config LIBFC |
| 587 | tristate "LibFC module" | 587 | tristate "LibFC module" |
| 588 | select SCSI_FC_ATTRS | 588 | depends on SCSI_FC_ATTRS |
| 589 | select CRC32 | 589 | select CRC32 |
| 590 | ---help--- | 590 | ---help--- |
| 591 | Fibre Channel library module | 591 | Fibre Channel library module |
| 592 | 592 | ||
| 593 | config LIBFCOE | 593 | config LIBFCOE |
| 594 | tristate "LibFCoE module" | 594 | tristate "LibFCoE module" |
| 595 | select LIBFC | 595 | depends on LIBFC |
| 596 | ---help--- | 596 | ---help--- |
| 597 | Library for Fibre Channel over Ethernet module | 597 | Library for Fibre Channel over Ethernet module |
| 598 | 598 | ||
| 599 | config FCOE | 599 | config FCOE |
| 600 | tristate "FCoE module" | 600 | tristate "FCoE module" |
| 601 | depends on PCI | 601 | depends on PCI |
| 602 | select LIBFCOE | 602 | depends on LIBFCOE |
| 603 | ---help--- | 603 | ---help--- |
| 604 | Fibre Channel over Ethernet module | 604 | Fibre Channel over Ethernet module |
| 605 | 605 | ||
| 606 | config FCOE_FNIC | 606 | config FCOE_FNIC |
| 607 | tristate "Cisco FNIC Driver" | 607 | tristate "Cisco FNIC Driver" |
| 608 | depends on PCI && X86 | 608 | depends on PCI && X86 |
| 609 | select LIBFCOE | 609 | depends on LIBFCOE |
| 610 | help | 610 | help |
| 611 | This is support for the Cisco PCI-Express FCoE HBA. | 611 | This is support for the Cisco PCI-Express FCoE HBA. |
| 612 | 612 | ||
| @@ -816,7 +816,7 @@ config SCSI_IBMVSCSI | |||
| 816 | config SCSI_IBMVFC | 816 | config SCSI_IBMVFC |
| 817 | tristate "IBM Virtual FC support" | 817 | tristate "IBM Virtual FC support" |
| 818 | depends on PPC_PSERIES && SCSI | 818 | depends on PPC_PSERIES && SCSI |
| 819 | select SCSI_FC_ATTRS | 819 | depends on SCSI_FC_ATTRS |
| 820 | help | 820 | help |
| 821 | This is the IBM POWER Virtual FC Client | 821 | This is the IBM POWER Virtual FC Client |
| 822 | 822 | ||
| @@ -1266,7 +1266,7 @@ source "drivers/scsi/qla4xxx/Kconfig" | |||
| 1266 | config SCSI_LPFC | 1266 | config SCSI_LPFC |
| 1267 | tristate "Emulex LightPulse Fibre Channel Support" | 1267 | tristate "Emulex LightPulse Fibre Channel Support" |
| 1268 | depends on PCI && SCSI | 1268 | depends on PCI && SCSI |
| 1269 | select SCSI_FC_ATTRS | 1269 | depends on SCSI_FC_ATTRS |
| 1270 | select CRC_T10DIF | 1270 | select CRC_T10DIF |
| 1271 | help | 1271 | help |
| 1272 | This lpfc driver supports the Emulex LightPulse | 1272 | This lpfc driver supports the Emulex LightPulse |
| @@ -1676,7 +1676,7 @@ config SCSI_SUNESP | |||
| 1676 | config ZFCP | 1676 | config ZFCP |
| 1677 | tristate "FCP host bus adapter driver for IBM eServer zSeries" | 1677 | tristate "FCP host bus adapter driver for IBM eServer zSeries" |
| 1678 | depends on S390 && QDIO && SCSI | 1678 | depends on S390 && QDIO && SCSI |
| 1679 | select SCSI_FC_ATTRS | 1679 | depends on SCSI_FC_ATTRS |
| 1680 | help | 1680 | help |
| 1681 | If you want to access SCSI devices attached to your IBM eServer | 1681 | If you want to access SCSI devices attached to your IBM eServer |
| 1682 | zSeries by means of Fibre Channel interfaces say Y. | 1682 | zSeries by means of Fibre Channel interfaces say Y. |
| @@ -1704,7 +1704,7 @@ config SCSI_PM8001 | |||
| 1704 | config SCSI_BFA_FC | 1704 | config SCSI_BFA_FC |
| 1705 | tristate "Brocade BFA Fibre Channel Support" | 1705 | tristate "Brocade BFA Fibre Channel Support" |
| 1706 | depends on PCI && SCSI | 1706 | depends on PCI && SCSI |
| 1707 | select SCSI_FC_ATTRS | 1707 | depends on SCSI_FC_ATTRS |
| 1708 | help | 1708 | help |
| 1709 | This bfa driver supports all Brocade PCIe FC/FCOE host adapters. | 1709 | This bfa driver supports all Brocade PCIe FC/FCOE host adapters. |
| 1710 | 1710 | ||
diff --git a/drivers/scsi/bnx2fc/Kconfig b/drivers/scsi/bnx2fc/Kconfig index f245d543d7b1..097882882649 100644 --- a/drivers/scsi/bnx2fc/Kconfig +++ b/drivers/scsi/bnx2fc/Kconfig | |||
| @@ -1,11 +1,12 @@ | |||
| 1 | config SCSI_BNX2X_FCOE | 1 | config SCSI_BNX2X_FCOE |
| 2 | tristate "QLogic NetXtreme II FCoE support" | 2 | tristate "QLogic NetXtreme II FCoE support" |
| 3 | depends on PCI | 3 | depends on PCI |
| 4 | depends on (IPV6 || IPV6=n) | ||
| 5 | depends on LIBFC | ||
| 6 | depends on LIBFCOE | ||
| 4 | select NETDEVICES | 7 | select NETDEVICES |
| 5 | select ETHERNET | 8 | select ETHERNET |
| 6 | select NET_VENDOR_BROADCOM | 9 | select NET_VENDOR_BROADCOM |
| 7 | select LIBFC | ||
| 8 | select LIBFCOE | ||
| 9 | select CNIC | 10 | select CNIC |
| 10 | ---help--- | 11 | ---help--- |
| 11 | This driver supports FCoE offload for the QLogic NetXtreme II | 12 | This driver supports FCoE offload for the QLogic NetXtreme II |
diff --git a/drivers/scsi/bnx2i/Kconfig b/drivers/scsi/bnx2i/Kconfig index 44ce54e536e5..ba30ff86d581 100644 --- a/drivers/scsi/bnx2i/Kconfig +++ b/drivers/scsi/bnx2i/Kconfig | |||
| @@ -2,6 +2,7 @@ config SCSI_BNX2_ISCSI | |||
| 2 | tristate "QLogic NetXtreme II iSCSI support" | 2 | tristate "QLogic NetXtreme II iSCSI support" |
| 3 | depends on NET | 3 | depends on NET |
| 4 | depends on PCI | 4 | depends on PCI |
| 5 | depends on (IPV6 || IPV6=n) | ||
| 5 | select SCSI_ISCSI_ATTRS | 6 | select SCSI_ISCSI_ATTRS |
| 6 | select NETDEVICES | 7 | select NETDEVICES |
| 7 | select ETHERNET | 8 | select ETHERNET |
diff --git a/drivers/scsi/csiostor/Kconfig b/drivers/scsi/csiostor/Kconfig index 4d03b032aa10..7c7e5085968b 100644 --- a/drivers/scsi/csiostor/Kconfig +++ b/drivers/scsi/csiostor/Kconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | config SCSI_CHELSIO_FCOE | 1 | config SCSI_CHELSIO_FCOE |
| 2 | tristate "Chelsio Communications FCoE support" | 2 | tristate "Chelsio Communications FCoE support" |
| 3 | depends on PCI && SCSI | 3 | depends on PCI && SCSI |
| 4 | select SCSI_FC_ATTRS | 4 | depends on SCSI_FC_ATTRS |
| 5 | select FW_LOADER | 5 | select FW_LOADER |
| 6 | help | 6 | help |
| 7 | This driver supports FCoE Offload functionality over | 7 | This driver supports FCoE Offload functionality over |
diff --git a/drivers/scsi/qla2xxx/Kconfig b/drivers/scsi/qla2xxx/Kconfig index 23d607218ae8..113e6c9826a1 100644 --- a/drivers/scsi/qla2xxx/Kconfig +++ b/drivers/scsi/qla2xxx/Kconfig | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | config SCSI_QLA_FC | 1 | config SCSI_QLA_FC |
| 2 | tristate "QLogic QLA2XXX Fibre Channel Support" | 2 | tristate "QLogic QLA2XXX Fibre Channel Support" |
| 3 | depends on PCI && SCSI | 3 | depends on PCI && SCSI |
| 4 | select SCSI_FC_ATTRS | 4 | depends on SCSI_FC_ATTRS |
| 5 | select FW_LOADER | 5 | select FW_LOADER |
| 6 | ---help--- | 6 | ---help--- |
| 7 | This qla2xxx driver supports all QLogic Fibre Channel | 7 | This qla2xxx driver supports all QLogic Fibre Channel |
| @@ -31,7 +31,7 @@ config SCSI_QLA_FC | |||
| 31 | config TCM_QLA2XXX | 31 | config TCM_QLA2XXX |
| 32 | tristate "TCM_QLA2XXX fabric module for Qlogic 2xxx series target mode HBAs" | 32 | tristate "TCM_QLA2XXX fabric module for Qlogic 2xxx series target mode HBAs" |
| 33 | depends on SCSI_QLA_FC && TARGET_CORE | 33 | depends on SCSI_QLA_FC && TARGET_CORE |
| 34 | select LIBFC | 34 | depends on LIBFC |
| 35 | select BTREE | 35 | select BTREE |
| 36 | default n | 36 | default n |
| 37 | ---help--- | 37 | ---help--- |
diff --git a/include/linux/mlx4/device.h b/include/linux/mlx4/device.h index 511c6e0d21a9..a5b7d7cfcedf 100644 --- a/include/linux/mlx4/device.h +++ b/include/linux/mlx4/device.h | |||
| @@ -209,6 +209,7 @@ enum { | |||
| 209 | MLX4_BMME_FLAG_TYPE_2_WIN = 1 << 9, | 209 | MLX4_BMME_FLAG_TYPE_2_WIN = 1 << 9, |
| 210 | MLX4_BMME_FLAG_RESERVED_LKEY = 1 << 10, | 210 | MLX4_BMME_FLAG_RESERVED_LKEY = 1 << 10, |
| 211 | MLX4_BMME_FLAG_FAST_REG_WR = 1 << 11, | 211 | MLX4_BMME_FLAG_FAST_REG_WR = 1 << 11, |
| 212 | MLX4_BMME_FLAG_VSD_INIT2RTR = 1 << 28, | ||
| 212 | }; | 213 | }; |
| 213 | 214 | ||
| 214 | enum mlx4_event { | 215 | enum mlx4_event { |
diff --git a/include/linux/mlx4/qp.h b/include/linux/mlx4/qp.h index 7040dc98ff8b..5f4e36cf0091 100644 --- a/include/linux/mlx4/qp.h +++ b/include/linux/mlx4/qp.h | |||
| @@ -56,7 +56,8 @@ enum mlx4_qp_optpar { | |||
| 56 | MLX4_QP_OPTPAR_RNR_RETRY = 1 << 13, | 56 | MLX4_QP_OPTPAR_RNR_RETRY = 1 << 13, |
| 57 | MLX4_QP_OPTPAR_ACK_TIMEOUT = 1 << 14, | 57 | MLX4_QP_OPTPAR_ACK_TIMEOUT = 1 << 14, |
| 58 | MLX4_QP_OPTPAR_SCHED_QUEUE = 1 << 16, | 58 | MLX4_QP_OPTPAR_SCHED_QUEUE = 1 << 16, |
| 59 | MLX4_QP_OPTPAR_COUNTER_INDEX = 1 << 20 | 59 | MLX4_QP_OPTPAR_COUNTER_INDEX = 1 << 20, |
| 60 | MLX4_QP_OPTPAR_VLAN_STRIPPING = 1 << 21, | ||
| 60 | }; | 61 | }; |
| 61 | 62 | ||
| 62 | enum mlx4_qp_state { | 63 | enum mlx4_qp_state { |
| @@ -423,13 +424,20 @@ struct mlx4_wqe_inline_seg { | |||
| 423 | 424 | ||
| 424 | enum mlx4_update_qp_attr { | 425 | enum mlx4_update_qp_attr { |
| 425 | MLX4_UPDATE_QP_SMAC = 1 << 0, | 426 | MLX4_UPDATE_QP_SMAC = 1 << 0, |
| 427 | MLX4_UPDATE_QP_VSD = 1 << 2, | ||
| 428 | MLX4_UPDATE_QP_SUPPORTED_ATTRS = (1 << 2) - 1 | ||
| 429 | }; | ||
| 430 | |||
| 431 | enum mlx4_update_qp_params_flags { | ||
| 432 | MLX4_UPDATE_QP_PARAMS_FLAGS_VSD_ENABLE = 1 << 0, | ||
| 426 | }; | 433 | }; |
| 427 | 434 | ||
| 428 | struct mlx4_update_qp_params { | 435 | struct mlx4_update_qp_params { |
| 429 | u8 smac_index; | 436 | u8 smac_index; |
| 437 | u32 flags; | ||
| 430 | }; | 438 | }; |
| 431 | 439 | ||
| 432 | int mlx4_update_qp(struct mlx4_dev *dev, struct mlx4_qp *qp, | 440 | int mlx4_update_qp(struct mlx4_dev *dev, u32 qpn, |
| 433 | enum mlx4_update_qp_attr attr, | 441 | enum mlx4_update_qp_attr attr, |
| 434 | struct mlx4_update_qp_params *params); | 442 | struct mlx4_update_qp_params *params); |
| 435 | int mlx4_qp_modify(struct mlx4_dev *dev, struct mlx4_mtt *mtt, | 443 | int mlx4_qp_modify(struct mlx4_dev *dev, struct mlx4_mtt *mtt, |
diff --git a/include/net/addrconf.h b/include/net/addrconf.h index f679877bb601..ec51e673b4b6 100644 --- a/include/net/addrconf.h +++ b/include/net/addrconf.h | |||
| @@ -204,6 +204,7 @@ void ipv6_sock_ac_close(struct sock *sk); | |||
| 204 | 204 | ||
| 205 | int ipv6_dev_ac_inc(struct net_device *dev, const struct in6_addr *addr); | 205 | int ipv6_dev_ac_inc(struct net_device *dev, const struct in6_addr *addr); |
| 206 | int __ipv6_dev_ac_dec(struct inet6_dev *idev, const struct in6_addr *addr); | 206 | int __ipv6_dev_ac_dec(struct inet6_dev *idev, const struct in6_addr *addr); |
| 207 | void ipv6_ac_destroy_dev(struct inet6_dev *idev); | ||
| 207 | bool ipv6_chk_acast_addr(struct net *net, struct net_device *dev, | 208 | bool ipv6_chk_acast_addr(struct net *net, struct net_device *dev, |
| 208 | const struct in6_addr *addr); | 209 | const struct in6_addr *addr); |
| 209 | bool ipv6_chk_acast_addr_src(struct net *net, struct net_device *dev, | 210 | bool ipv6_chk_acast_addr_src(struct net *net, struct net_device *dev, |
diff --git a/include/net/dst.h b/include/net/dst.h index 71c60f42be48..a8ae4e760778 100644 --- a/include/net/dst.h +++ b/include/net/dst.h | |||
| @@ -480,6 +480,7 @@ void dst_init(void); | |||
| 480 | /* Flags for xfrm_lookup flags argument. */ | 480 | /* Flags for xfrm_lookup flags argument. */ |
| 481 | enum { | 481 | enum { |
| 482 | XFRM_LOOKUP_ICMP = 1 << 0, | 482 | XFRM_LOOKUP_ICMP = 1 << 0, |
| 483 | XFRM_LOOKUP_QUEUE = 1 << 1, | ||
| 483 | }; | 484 | }; |
| 484 | 485 | ||
| 485 | struct flowi; | 486 | struct flowi; |
| @@ -490,7 +491,16 @@ static inline struct dst_entry *xfrm_lookup(struct net *net, | |||
| 490 | int flags) | 491 | int flags) |
| 491 | { | 492 | { |
| 492 | return dst_orig; | 493 | return dst_orig; |
| 493 | } | 494 | } |
| 495 | |||
| 496 | static inline struct dst_entry *xfrm_lookup_route(struct net *net, | ||
| 497 | struct dst_entry *dst_orig, | ||
| 498 | const struct flowi *fl, | ||
| 499 | struct sock *sk, | ||
| 500 | int flags) | ||
| 501 | { | ||
| 502 | return dst_orig; | ||
| 503 | } | ||
| 494 | 504 | ||
| 495 | static inline struct xfrm_state *dst_xfrm(const struct dst_entry *dst) | 505 | static inline struct xfrm_state *dst_xfrm(const struct dst_entry *dst) |
| 496 | { | 506 | { |
| @@ -502,6 +512,10 @@ struct dst_entry *xfrm_lookup(struct net *net, struct dst_entry *dst_orig, | |||
| 502 | const struct flowi *fl, struct sock *sk, | 512 | const struct flowi *fl, struct sock *sk, |
| 503 | int flags); | 513 | int flags); |
| 504 | 514 | ||
| 515 | struct dst_entry *xfrm_lookup_route(struct net *net, struct dst_entry *dst_orig, | ||
| 516 | const struct flowi *fl, struct sock *sk, | ||
| 517 | int flags); | ||
| 518 | |||
| 505 | /* skb attached with this dst needs transformation if dst->xfrm is valid */ | 519 | /* skb attached with this dst needs transformation if dst->xfrm is valid */ |
| 506 | static inline struct xfrm_state *dst_xfrm(const struct dst_entry *dst) | 520 | static inline struct xfrm_state *dst_xfrm(const struct dst_entry *dst) |
| 507 | { | 521 | { |
diff --git a/include/net/genetlink.h b/include/net/genetlink.h index 93695f0e22a5..af10c2cf8a1d 100644 --- a/include/net/genetlink.h +++ b/include/net/genetlink.h | |||
| @@ -394,4 +394,12 @@ static inline int genl_set_err(struct genl_family *family, struct net *net, | |||
| 394 | return netlink_set_err(net->genl_sock, portid, group, code); | 394 | return netlink_set_err(net->genl_sock, portid, group, code); |
| 395 | } | 395 | } |
| 396 | 396 | ||
| 397 | static inline int genl_has_listeners(struct genl_family *family, | ||
| 398 | struct sock *sk, unsigned int group) | ||
| 399 | { | ||
| 400 | if (WARN_ON_ONCE(group >= family->n_mcgrps)) | ||
| 401 | return -EINVAL; | ||
| 402 | group = family->mcgrp_offset + group; | ||
| 403 | return netlink_has_listeners(sk, group); | ||
| 404 | } | ||
| 397 | #endif /* __NET_GENERIC_NETLINK_H */ | 405 | #endif /* __NET_GENERIC_NETLINK_H */ |
diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h index a3cfb8ebeb53..620e086c0cbe 100644 --- a/include/net/sch_generic.h +++ b/include/net/sch_generic.h | |||
| @@ -231,7 +231,8 @@ struct qdisc_skb_cb { | |||
| 231 | unsigned int pkt_len; | 231 | unsigned int pkt_len; |
| 232 | u16 slave_dev_queue_mapping; | 232 | u16 slave_dev_queue_mapping; |
| 233 | u16 _pad; | 233 | u16 _pad; |
| 234 | unsigned char data[24]; | 234 | #define QDISC_CB_PRIV_LEN 20 |
| 235 | unsigned char data[QDISC_CB_PRIV_LEN]; | ||
| 235 | }; | 236 | }; |
| 236 | 237 | ||
| 237 | static inline void qdisc_cb_private_validate(const struct sk_buff *skb, int sz) | 238 | static inline void qdisc_cb_private_validate(const struct sk_buff *skb, int sz) |
diff --git a/lib/rhashtable.c b/lib/rhashtable.c index a2c78810ebc1..7b36e4d40ed7 100644 --- a/lib/rhashtable.c +++ b/lib/rhashtable.c | |||
| @@ -23,7 +23,6 @@ | |||
| 23 | #include <linux/hash.h> | 23 | #include <linux/hash.h> |
| 24 | #include <linux/random.h> | 24 | #include <linux/random.h> |
| 25 | #include <linux/rhashtable.h> | 25 | #include <linux/rhashtable.h> |
| 26 | #include <linux/log2.h> | ||
| 27 | 26 | ||
| 28 | #define HASH_DEFAULT_SIZE 64UL | 27 | #define HASH_DEFAULT_SIZE 64UL |
| 29 | #define HASH_MIN_SIZE 4UL | 28 | #define HASH_MIN_SIZE 4UL |
diff --git a/net/bridge/br_private.h b/net/bridge/br_private.h index 62a7fa2e3569..b6c04cbcfdc5 100644 --- a/net/bridge/br_private.h +++ b/net/bridge/br_private.h | |||
| @@ -309,6 +309,9 @@ struct br_input_skb_cb { | |||
| 309 | int igmp; | 309 | int igmp; |
| 310 | int mrouters_only; | 310 | int mrouters_only; |
| 311 | #endif | 311 | #endif |
| 312 | #ifdef CONFIG_BRIDGE_VLAN_FILTERING | ||
| 313 | bool vlan_filtered; | ||
| 314 | #endif | ||
| 312 | }; | 315 | }; |
| 313 | 316 | ||
| 314 | #define BR_INPUT_SKB_CB(__skb) ((struct br_input_skb_cb *)(__skb)->cb) | 317 | #define BR_INPUT_SKB_CB(__skb) ((struct br_input_skb_cb *)(__skb)->cb) |
diff --git a/net/bridge/br_vlan.c b/net/bridge/br_vlan.c index e1bcd653899b..3ba57fcdcd13 100644 --- a/net/bridge/br_vlan.c +++ b/net/bridge/br_vlan.c | |||
| @@ -27,9 +27,13 @@ static void __vlan_add_flags(struct net_port_vlans *v, u16 vid, u16 flags) | |||
| 27 | { | 27 | { |
| 28 | if (flags & BRIDGE_VLAN_INFO_PVID) | 28 | if (flags & BRIDGE_VLAN_INFO_PVID) |
| 29 | __vlan_add_pvid(v, vid); | 29 | __vlan_add_pvid(v, vid); |
| 30 | else | ||
| 31 | __vlan_delete_pvid(v, vid); | ||
| 30 | 32 | ||
| 31 | if (flags & BRIDGE_VLAN_INFO_UNTAGGED) | 33 | if (flags & BRIDGE_VLAN_INFO_UNTAGGED) |
| 32 | set_bit(vid, v->untagged_bitmap); | 34 | set_bit(vid, v->untagged_bitmap); |
| 35 | else | ||
| 36 | clear_bit(vid, v->untagged_bitmap); | ||
| 33 | } | 37 | } |
| 34 | 38 | ||
| 35 | static int __vlan_add(struct net_port_vlans *v, u16 vid, u16 flags) | 39 | static int __vlan_add(struct net_port_vlans *v, u16 vid, u16 flags) |
| @@ -125,7 +129,8 @@ struct sk_buff *br_handle_vlan(struct net_bridge *br, | |||
| 125 | { | 129 | { |
| 126 | u16 vid; | 130 | u16 vid; |
| 127 | 131 | ||
| 128 | if (!br->vlan_enabled) | 132 | /* If this packet was not filtered at input, let it pass */ |
| 133 | if (!BR_INPUT_SKB_CB(skb)->vlan_filtered) | ||
| 129 | goto out; | 134 | goto out; |
| 130 | 135 | ||
| 131 | /* Vlan filter table must be configured at this point. The | 136 | /* Vlan filter table must be configured at this point. The |
| @@ -164,8 +169,10 @@ bool br_allowed_ingress(struct net_bridge *br, struct net_port_vlans *v, | |||
| 164 | /* If VLAN filtering is disabled on the bridge, all packets are | 169 | /* If VLAN filtering is disabled on the bridge, all packets are |
| 165 | * permitted. | 170 | * permitted. |
| 166 | */ | 171 | */ |
| 167 | if (!br->vlan_enabled) | 172 | if (!br->vlan_enabled) { |
| 173 | BR_INPUT_SKB_CB(skb)->vlan_filtered = false; | ||
| 168 | return true; | 174 | return true; |
| 175 | } | ||
| 169 | 176 | ||
| 170 | /* If there are no vlan in the permitted list, all packets are | 177 | /* If there are no vlan in the permitted list, all packets are |
| 171 | * rejected. | 178 | * rejected. |
| @@ -173,6 +180,7 @@ bool br_allowed_ingress(struct net_bridge *br, struct net_port_vlans *v, | |||
| 173 | if (!v) | 180 | if (!v) |
| 174 | goto drop; | 181 | goto drop; |
| 175 | 182 | ||
| 183 | BR_INPUT_SKB_CB(skb)->vlan_filtered = true; | ||
| 176 | proto = br->vlan_proto; | 184 | proto = br->vlan_proto; |
| 177 | 185 | ||
| 178 | /* If vlan tx offload is disabled on bridge device and frame was | 186 | /* If vlan tx offload is disabled on bridge device and frame was |
| @@ -251,7 +259,8 @@ bool br_allowed_egress(struct net_bridge *br, | |||
| 251 | { | 259 | { |
| 252 | u16 vid; | 260 | u16 vid; |
| 253 | 261 | ||
| 254 | if (!br->vlan_enabled) | 262 | /* If this packet was not filtered at input, let it pass */ |
| 263 | if (!BR_INPUT_SKB_CB(skb)->vlan_filtered) | ||
| 255 | return true; | 264 | return true; |
| 256 | 265 | ||
| 257 | if (!v) | 266 | if (!v) |
| @@ -270,6 +279,7 @@ bool br_should_learn(struct net_bridge_port *p, struct sk_buff *skb, u16 *vid) | |||
| 270 | struct net_bridge *br = p->br; | 279 | struct net_bridge *br = p->br; |
| 271 | struct net_port_vlans *v; | 280 | struct net_port_vlans *v; |
| 272 | 281 | ||
| 282 | /* If filtering was disabled at input, let it pass. */ | ||
| 273 | if (!br->vlan_enabled) | 283 | if (!br->vlan_enabled) |
| 274 | return true; | 284 | return true; |
| 275 | 285 | ||
diff --git a/net/core/dev.c b/net/core/dev.c index ab9a16530c36..cf8a95f48cff 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
| @@ -4809,9 +4809,14 @@ static void netdev_adjacent_sysfs_del(struct net_device *dev, | |||
| 4809 | sysfs_remove_link(&(dev->dev.kobj), linkname); | 4809 | sysfs_remove_link(&(dev->dev.kobj), linkname); |
| 4810 | } | 4810 | } |
| 4811 | 4811 | ||
| 4812 | #define netdev_adjacent_is_neigh_list(dev, dev_list) \ | 4812 | static inline bool netdev_adjacent_is_neigh_list(struct net_device *dev, |
| 4813 | (dev_list == &dev->adj_list.upper || \ | 4813 | struct net_device *adj_dev, |
| 4814 | dev_list == &dev->adj_list.lower) | 4814 | struct list_head *dev_list) |
| 4815 | { | ||
| 4816 | return (dev_list == &dev->adj_list.upper || | ||
| 4817 | dev_list == &dev->adj_list.lower) && | ||
| 4818 | net_eq(dev_net(dev), dev_net(adj_dev)); | ||
| 4819 | } | ||
| 4815 | 4820 | ||
| 4816 | static int __netdev_adjacent_dev_insert(struct net_device *dev, | 4821 | static int __netdev_adjacent_dev_insert(struct net_device *dev, |
| 4817 | struct net_device *adj_dev, | 4822 | struct net_device *adj_dev, |
| @@ -4841,7 +4846,7 @@ static int __netdev_adjacent_dev_insert(struct net_device *dev, | |||
| 4841 | pr_debug("dev_hold for %s, because of link added from %s to %s\n", | 4846 | pr_debug("dev_hold for %s, because of link added from %s to %s\n", |
| 4842 | adj_dev->name, dev->name, adj_dev->name); | 4847 | adj_dev->name, dev->name, adj_dev->name); |
| 4843 | 4848 | ||
| 4844 | if (netdev_adjacent_is_neigh_list(dev, dev_list)) { | 4849 | if (netdev_adjacent_is_neigh_list(dev, adj_dev, dev_list)) { |
| 4845 | ret = netdev_adjacent_sysfs_add(dev, adj_dev, dev_list); | 4850 | ret = netdev_adjacent_sysfs_add(dev, adj_dev, dev_list); |
| 4846 | if (ret) | 4851 | if (ret) |
| 4847 | goto free_adj; | 4852 | goto free_adj; |
| @@ -4862,7 +4867,7 @@ static int __netdev_adjacent_dev_insert(struct net_device *dev, | |||
| 4862 | return 0; | 4867 | return 0; |
| 4863 | 4868 | ||
| 4864 | remove_symlinks: | 4869 | remove_symlinks: |
| 4865 | if (netdev_adjacent_is_neigh_list(dev, dev_list)) | 4870 | if (netdev_adjacent_is_neigh_list(dev, adj_dev, dev_list)) |
| 4866 | netdev_adjacent_sysfs_del(dev, adj_dev->name, dev_list); | 4871 | netdev_adjacent_sysfs_del(dev, adj_dev->name, dev_list); |
| 4867 | free_adj: | 4872 | free_adj: |
| 4868 | kfree(adj); | 4873 | kfree(adj); |
| @@ -4895,8 +4900,7 @@ static void __netdev_adjacent_dev_remove(struct net_device *dev, | |||
| 4895 | if (adj->master) | 4900 | if (adj->master) |
| 4896 | sysfs_remove_link(&(dev->dev.kobj), "master"); | 4901 | sysfs_remove_link(&(dev->dev.kobj), "master"); |
| 4897 | 4902 | ||
| 4898 | if (netdev_adjacent_is_neigh_list(dev, dev_list) && | 4903 | if (netdev_adjacent_is_neigh_list(dev, adj_dev, dev_list)) |
| 4899 | net_eq(dev_net(dev),dev_net(adj_dev))) | ||
| 4900 | netdev_adjacent_sysfs_del(dev, adj_dev->name, dev_list); | 4904 | netdev_adjacent_sysfs_del(dev, adj_dev->name, dev_list); |
| 4901 | 4905 | ||
| 4902 | list_del_rcu(&adj->list); | 4906 | list_del_rcu(&adj->list); |
diff --git a/net/core/sock.c b/net/core/sock.c index d372b4bd3f99..9c3f823e76a9 100644 --- a/net/core/sock.c +++ b/net/core/sock.c | |||
| @@ -1866,7 +1866,7 @@ EXPORT_SYMBOL(sock_alloc_send_skb); | |||
| 1866 | * skb_page_frag_refill - check that a page_frag contains enough room | 1866 | * skb_page_frag_refill - check that a page_frag contains enough room |
| 1867 | * @sz: minimum size of the fragment we want to get | 1867 | * @sz: minimum size of the fragment we want to get |
| 1868 | * @pfrag: pointer to page_frag | 1868 | * @pfrag: pointer to page_frag |
| 1869 | * @prio: priority for memory allocation | 1869 | * @gfp: priority for memory allocation |
| 1870 | * | 1870 | * |
| 1871 | * Note: While this allocator tries to use high order pages, there is | 1871 | * Note: While this allocator tries to use high order pages, there is |
| 1872 | * no guarantee that allocations succeed. Therefore, @sz MUST be | 1872 | * no guarantee that allocations succeed. Therefore, @sz MUST be |
diff --git a/net/ipv4/ip_tunnel.c b/net/ipv4/ip_tunnel.c index afed1aac2638..bd41dd1948b6 100644 --- a/net/ipv4/ip_tunnel.c +++ b/net/ipv4/ip_tunnel.c | |||
| @@ -79,10 +79,10 @@ static void __tunnel_dst_set(struct ip_tunnel_dst *idst, | |||
| 79 | idst->saddr = saddr; | 79 | idst->saddr = saddr; |
| 80 | } | 80 | } |
| 81 | 81 | ||
| 82 | static void tunnel_dst_set(struct ip_tunnel *t, | 82 | static noinline void tunnel_dst_set(struct ip_tunnel *t, |
| 83 | struct dst_entry *dst, __be32 saddr) | 83 | struct dst_entry *dst, __be32 saddr) |
| 84 | { | 84 | { |
| 85 | __tunnel_dst_set(this_cpu_ptr(t->dst_cache), dst, saddr); | 85 | __tunnel_dst_set(raw_cpu_ptr(t->dst_cache), dst, saddr); |
| 86 | } | 86 | } |
| 87 | 87 | ||
| 88 | static void tunnel_dst_reset(struct ip_tunnel *t) | 88 | static void tunnel_dst_reset(struct ip_tunnel *t) |
| @@ -106,7 +106,7 @@ static struct rtable *tunnel_rtable_get(struct ip_tunnel *t, | |||
| 106 | struct dst_entry *dst; | 106 | struct dst_entry *dst; |
| 107 | 107 | ||
| 108 | rcu_read_lock(); | 108 | rcu_read_lock(); |
| 109 | idst = this_cpu_ptr(t->dst_cache); | 109 | idst = raw_cpu_ptr(t->dst_cache); |
| 110 | dst = rcu_dereference(idst->dst); | 110 | dst = rcu_dereference(idst->dst); |
| 111 | if (dst && !atomic_inc_not_zero(&dst->__refcnt)) | 111 | if (dst && !atomic_inc_not_zero(&dst->__refcnt)) |
| 112 | dst = NULL; | 112 | dst = NULL; |
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index eaa4b000c7b4..173e7ea54c70 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
| @@ -2265,9 +2265,9 @@ struct rtable *ip_route_output_flow(struct net *net, struct flowi4 *flp4, | |||
| 2265 | return rt; | 2265 | return rt; |
| 2266 | 2266 | ||
| 2267 | if (flp4->flowi4_proto) | 2267 | if (flp4->flowi4_proto) |
| 2268 | rt = (struct rtable *) xfrm_lookup(net, &rt->dst, | 2268 | rt = (struct rtable *)xfrm_lookup_route(net, &rt->dst, |
| 2269 | flowi4_to_flowi(flp4), | 2269 | flowi4_to_flowi(flp4), |
| 2270 | sk, 0); | 2270 | sk, 0); |
| 2271 | 2271 | ||
| 2272 | return rt; | 2272 | return rt; |
| 2273 | } | 2273 | } |
diff --git a/net/ipv6/addrconf.c b/net/ipv6/addrconf.c index fc1fac2a0528..3342ee64f2e3 100644 --- a/net/ipv6/addrconf.c +++ b/net/ipv6/addrconf.c | |||
| @@ -3094,11 +3094,13 @@ static int addrconf_ifdown(struct net_device *dev, int how) | |||
| 3094 | 3094 | ||
| 3095 | write_unlock_bh(&idev->lock); | 3095 | write_unlock_bh(&idev->lock); |
| 3096 | 3096 | ||
| 3097 | /* Step 5: Discard multicast list */ | 3097 | /* Step 5: Discard anycast and multicast list */ |
| 3098 | if (how) | 3098 | if (how) { |
| 3099 | ipv6_ac_destroy_dev(idev); | ||
| 3099 | ipv6_mc_destroy_dev(idev); | 3100 | ipv6_mc_destroy_dev(idev); |
| 3100 | else | 3101 | } else { |
| 3101 | ipv6_mc_down(idev); | 3102 | ipv6_mc_down(idev); |
| 3103 | } | ||
| 3102 | 3104 | ||
| 3103 | idev->tstamp = jiffies; | 3105 | idev->tstamp = jiffies; |
| 3104 | 3106 | ||
diff --git a/net/ipv6/anycast.c b/net/ipv6/anycast.c index ff2de7d9d8e6..9a386842fd62 100644 --- a/net/ipv6/anycast.c +++ b/net/ipv6/anycast.c | |||
| @@ -351,6 +351,27 @@ static int ipv6_dev_ac_dec(struct net_device *dev, const struct in6_addr *addr) | |||
| 351 | return __ipv6_dev_ac_dec(idev, addr); | 351 | return __ipv6_dev_ac_dec(idev, addr); |
| 352 | } | 352 | } |
| 353 | 353 | ||
| 354 | void ipv6_ac_destroy_dev(struct inet6_dev *idev) | ||
| 355 | { | ||
| 356 | struct ifacaddr6 *aca; | ||
| 357 | |||
| 358 | write_lock_bh(&idev->lock); | ||
| 359 | while ((aca = idev->ac_list) != NULL) { | ||
| 360 | idev->ac_list = aca->aca_next; | ||
| 361 | write_unlock_bh(&idev->lock); | ||
| 362 | |||
| 363 | addrconf_leave_solict(idev, &aca->aca_addr); | ||
| 364 | |||
| 365 | dst_hold(&aca->aca_rt->dst); | ||
| 366 | ip6_del_rt(aca->aca_rt); | ||
| 367 | |||
| 368 | aca_put(aca); | ||
| 369 | |||
| 370 | write_lock_bh(&idev->lock); | ||
| 371 | } | ||
| 372 | write_unlock_bh(&idev->lock); | ||
| 373 | } | ||
| 374 | |||
| 354 | /* | 375 | /* |
| 355 | * check if the interface has this anycast address | 376 | * check if the interface has this anycast address |
| 356 | * called with rcu_read_lock() | 377 | * called with rcu_read_lock() |
diff --git a/net/ipv6/ip6_output.c b/net/ipv6/ip6_output.c index 315a55d66079..0a3448b2888f 100644 --- a/net/ipv6/ip6_output.c +++ b/net/ipv6/ip6_output.c | |||
| @@ -1009,7 +1009,7 @@ struct dst_entry *ip6_dst_lookup_flow(struct sock *sk, struct flowi6 *fl6, | |||
| 1009 | if (final_dst) | 1009 | if (final_dst) |
| 1010 | fl6->daddr = *final_dst; | 1010 | fl6->daddr = *final_dst; |
| 1011 | 1011 | ||
| 1012 | return xfrm_lookup(sock_net(sk), dst, flowi6_to_flowi(fl6), sk, 0); | 1012 | return xfrm_lookup_route(sock_net(sk), dst, flowi6_to_flowi(fl6), sk, 0); |
| 1013 | } | 1013 | } |
| 1014 | EXPORT_SYMBOL_GPL(ip6_dst_lookup_flow); | 1014 | EXPORT_SYMBOL_GPL(ip6_dst_lookup_flow); |
| 1015 | 1015 | ||
| @@ -1041,7 +1041,7 @@ struct dst_entry *ip6_sk_dst_lookup_flow(struct sock *sk, struct flowi6 *fl6, | |||
| 1041 | if (final_dst) | 1041 | if (final_dst) |
| 1042 | fl6->daddr = *final_dst; | 1042 | fl6->daddr = *final_dst; |
| 1043 | 1043 | ||
| 1044 | return xfrm_lookup(sock_net(sk), dst, flowi6_to_flowi(fl6), sk, 0); | 1044 | return xfrm_lookup_route(sock_net(sk), dst, flowi6_to_flowi(fl6), sk, 0); |
| 1045 | } | 1045 | } |
| 1046 | EXPORT_SYMBOL_GPL(ip6_sk_dst_lookup_flow); | 1046 | EXPORT_SYMBOL_GPL(ip6_sk_dst_lookup_flow); |
| 1047 | 1047 | ||
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c index 441875f03750..a1e433b88c66 100644 --- a/net/mac80211/sta_info.c +++ b/net/mac80211/sta_info.c | |||
| @@ -1822,7 +1822,7 @@ void sta_set_sinfo(struct sta_info *sta, struct station_info *sinfo) | |||
| 1822 | sinfo->bss_param.flags |= BSS_PARAM_FLAGS_SHORT_PREAMBLE; | 1822 | sinfo->bss_param.flags |= BSS_PARAM_FLAGS_SHORT_PREAMBLE; |
| 1823 | if (sdata->vif.bss_conf.use_short_slot) | 1823 | if (sdata->vif.bss_conf.use_short_slot) |
| 1824 | sinfo->bss_param.flags |= BSS_PARAM_FLAGS_SHORT_SLOT_TIME; | 1824 | sinfo->bss_param.flags |= BSS_PARAM_FLAGS_SHORT_SLOT_TIME; |
| 1825 | sinfo->bss_param.dtim_period = sdata->local->hw.conf.ps_dtim_period; | 1825 | sinfo->bss_param.dtim_period = sdata->vif.bss_conf.dtim_period; |
| 1826 | sinfo->bss_param.beacon_interval = sdata->vif.bss_conf.beacon_int; | 1826 | sinfo->bss_param.beacon_interval = sdata->vif.bss_conf.beacon_int; |
| 1827 | 1827 | ||
| 1828 | sinfo->sta_flags.set = 0; | 1828 | sinfo->sta_flags.set = 0; |
diff --git a/net/openvswitch/datapath.c b/net/openvswitch/datapath.c index 91d66b7e64ac..64dc864a417f 100644 --- a/net/openvswitch/datapath.c +++ b/net/openvswitch/datapath.c | |||
| @@ -78,11 +78,12 @@ static const struct genl_multicast_group ovs_dp_vport_multicast_group = { | |||
| 78 | 78 | ||
| 79 | /* Check if need to build a reply message. | 79 | /* Check if need to build a reply message. |
| 80 | * OVS userspace sets the NLM_F_ECHO flag if it needs the reply. */ | 80 | * OVS userspace sets the NLM_F_ECHO flag if it needs the reply. */ |
| 81 | static bool ovs_must_notify(struct genl_info *info, | 81 | static bool ovs_must_notify(struct genl_family *family, struct genl_info *info, |
| 82 | const struct genl_multicast_group *grp) | 82 | unsigned int group) |
| 83 | { | 83 | { |
| 84 | return info->nlhdr->nlmsg_flags & NLM_F_ECHO || | 84 | return info->nlhdr->nlmsg_flags & NLM_F_ECHO || |
| 85 | netlink_has_listeners(genl_info_net(info)->genl_sock, 0); | 85 | genl_has_listeners(family, genl_info_net(info)->genl_sock, |
| 86 | group); | ||
| 86 | } | 87 | } |
| 87 | 88 | ||
| 88 | static void ovs_notify(struct genl_family *family, | 89 | static void ovs_notify(struct genl_family *family, |
| @@ -763,7 +764,7 @@ static struct sk_buff *ovs_flow_cmd_alloc_info(const struct sw_flow_actions *act | |||
| 763 | { | 764 | { |
| 764 | struct sk_buff *skb; | 765 | struct sk_buff *skb; |
| 765 | 766 | ||
| 766 | if (!always && !ovs_must_notify(info, &ovs_dp_flow_multicast_group)) | 767 | if (!always && !ovs_must_notify(&dp_flow_genl_family, info, 0)) |
| 767 | return NULL; | 768 | return NULL; |
| 768 | 769 | ||
| 769 | skb = genlmsg_new_unicast(ovs_flow_cmd_msg_size(acts), info, GFP_KERNEL); | 770 | skb = genlmsg_new_unicast(ovs_flow_cmd_msg_size(acts), info, GFP_KERNEL); |
diff --git a/net/rfkill/rfkill-gpio.c b/net/rfkill/rfkill-gpio.c index 02a86a27fd84..5fa54dd78e25 100644 --- a/net/rfkill/rfkill-gpio.c +++ b/net/rfkill/rfkill-gpio.c | |||
| @@ -163,6 +163,7 @@ static const struct acpi_device_id rfkill_acpi_match[] = { | |||
| 163 | { "LNV4752", RFKILL_TYPE_GPS }, | 163 | { "LNV4752", RFKILL_TYPE_GPS }, |
| 164 | { }, | 164 | { }, |
| 165 | }; | 165 | }; |
| 166 | MODULE_DEVICE_TABLE(acpi, rfkill_acpi_match); | ||
| 166 | #endif | 167 | #endif |
| 167 | 168 | ||
| 168 | static struct platform_driver rfkill_gpio_driver = { | 169 | static struct platform_driver rfkill_gpio_driver = { |
diff --git a/net/rxrpc/ar-key.c b/net/rxrpc/ar-key.c index b45d080e64a7..1b24191167f1 100644 --- a/net/rxrpc/ar-key.c +++ b/net/rxrpc/ar-key.c | |||
| @@ -1143,7 +1143,7 @@ static long rxrpc_read(const struct key *key, | |||
| 1143 | if (copy_to_user(xdr, (s), _l) != 0) \ | 1143 | if (copy_to_user(xdr, (s), _l) != 0) \ |
| 1144 | goto fault; \ | 1144 | goto fault; \ |
| 1145 | if (_l & 3 && \ | 1145 | if (_l & 3 && \ |
| 1146 | copy_to_user((u8 *)xdr + _l, &zero, 4 - (_l & 3)) != 0) \ | 1146 | copy_to_user((u8 __user *)xdr + _l, &zero, 4 - (_l & 3)) != 0) \ |
| 1147 | goto fault; \ | 1147 | goto fault; \ |
| 1148 | xdr += (_l + 3) >> 2; \ | 1148 | xdr += (_l + 3) >> 2; \ |
| 1149 | } while(0) | 1149 | } while(0) |
diff --git a/net/sched/sch_choke.c b/net/sched/sch_choke.c index ed30e436128b..fb666d1e4de3 100644 --- a/net/sched/sch_choke.c +++ b/net/sched/sch_choke.c | |||
| @@ -133,10 +133,16 @@ static void choke_drop_by_idx(struct Qdisc *sch, unsigned int idx) | |||
| 133 | --sch->q.qlen; | 133 | --sch->q.qlen; |
| 134 | } | 134 | } |
| 135 | 135 | ||
| 136 | /* private part of skb->cb[] that a qdisc is allowed to use | ||
| 137 | * is limited to QDISC_CB_PRIV_LEN bytes. | ||
| 138 | * As a flow key might be too large, we store a part of it only. | ||
| 139 | */ | ||
| 140 | #define CHOKE_K_LEN min_t(u32, sizeof(struct flow_keys), QDISC_CB_PRIV_LEN - 3) | ||
| 141 | |||
| 136 | struct choke_skb_cb { | 142 | struct choke_skb_cb { |
| 137 | u16 classid; | 143 | u16 classid; |
| 138 | u8 keys_valid; | 144 | u8 keys_valid; |
| 139 | struct flow_keys keys; | 145 | u8 keys[QDISC_CB_PRIV_LEN - 3]; |
| 140 | }; | 146 | }; |
| 141 | 147 | ||
| 142 | static inline struct choke_skb_cb *choke_skb_cb(const struct sk_buff *skb) | 148 | static inline struct choke_skb_cb *choke_skb_cb(const struct sk_buff *skb) |
| @@ -163,22 +169,26 @@ static u16 choke_get_classid(const struct sk_buff *skb) | |||
| 163 | static bool choke_match_flow(struct sk_buff *skb1, | 169 | static bool choke_match_flow(struct sk_buff *skb1, |
| 164 | struct sk_buff *skb2) | 170 | struct sk_buff *skb2) |
| 165 | { | 171 | { |
| 172 | struct flow_keys temp; | ||
| 173 | |||
| 166 | if (skb1->protocol != skb2->protocol) | 174 | if (skb1->protocol != skb2->protocol) |
| 167 | return false; | 175 | return false; |
| 168 | 176 | ||
| 169 | if (!choke_skb_cb(skb1)->keys_valid) { | 177 | if (!choke_skb_cb(skb1)->keys_valid) { |
| 170 | choke_skb_cb(skb1)->keys_valid = 1; | 178 | choke_skb_cb(skb1)->keys_valid = 1; |
| 171 | skb_flow_dissect(skb1, &choke_skb_cb(skb1)->keys); | 179 | skb_flow_dissect(skb1, &temp); |
| 180 | memcpy(&choke_skb_cb(skb1)->keys, &temp, CHOKE_K_LEN); | ||
| 172 | } | 181 | } |
| 173 | 182 | ||
| 174 | if (!choke_skb_cb(skb2)->keys_valid) { | 183 | if (!choke_skb_cb(skb2)->keys_valid) { |
| 175 | choke_skb_cb(skb2)->keys_valid = 1; | 184 | choke_skb_cb(skb2)->keys_valid = 1; |
| 176 | skb_flow_dissect(skb2, &choke_skb_cb(skb2)->keys); | 185 | skb_flow_dissect(skb2, &temp); |
| 186 | memcpy(&choke_skb_cb(skb2)->keys, &temp, CHOKE_K_LEN); | ||
| 177 | } | 187 | } |
| 178 | 188 | ||
| 179 | return !memcmp(&choke_skb_cb(skb1)->keys, | 189 | return !memcmp(&choke_skb_cb(skb1)->keys, |
| 180 | &choke_skb_cb(skb2)->keys, | 190 | &choke_skb_cb(skb2)->keys, |
| 181 | sizeof(struct flow_keys)); | 191 | CHOKE_K_LEN); |
| 182 | } | 192 | } |
| 183 | 193 | ||
| 184 | /* | 194 | /* |
diff --git a/net/socket.c b/net/socket.c index 2e2586e2dee1..4cdbc107606f 100644 --- a/net/socket.c +++ b/net/socket.c | |||
| @@ -1996,6 +1996,9 @@ static int copy_msghdr_from_user(struct msghdr *kmsg, | |||
| 1996 | if (copy_from_user(kmsg, umsg, sizeof(struct msghdr))) | 1996 | if (copy_from_user(kmsg, umsg, sizeof(struct msghdr))) |
| 1997 | return -EFAULT; | 1997 | return -EFAULT; |
| 1998 | 1998 | ||
| 1999 | if (kmsg->msg_name == NULL) | ||
| 2000 | kmsg->msg_namelen = 0; | ||
| 2001 | |||
| 1999 | if (kmsg->msg_namelen < 0) | 2002 | if (kmsg->msg_namelen < 0) |
| 2000 | return -EINVAL; | 2003 | return -EINVAL; |
| 2001 | 2004 | ||
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index df7b1332a1ec..7257164af91b 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c | |||
| @@ -6969,6 +6969,9 @@ void __cfg80211_send_event_skb(struct sk_buff *skb, gfp_t gfp) | |||
| 6969 | struct nlattr *data = ((void **)skb->cb)[2]; | 6969 | struct nlattr *data = ((void **)skb->cb)[2]; |
| 6970 | enum nl80211_multicast_groups mcgrp = NL80211_MCGRP_TESTMODE; | 6970 | enum nl80211_multicast_groups mcgrp = NL80211_MCGRP_TESTMODE; |
| 6971 | 6971 | ||
| 6972 | /* clear CB data for netlink core to own from now on */ | ||
| 6973 | memset(skb->cb, 0, sizeof(skb->cb)); | ||
| 6974 | |||
| 6972 | nla_nest_end(skb, data); | 6975 | nla_nest_end(skb, data); |
| 6973 | genlmsg_end(skb, hdr); | 6976 | genlmsg_end(skb, hdr); |
| 6974 | 6977 | ||
| @@ -9294,6 +9297,9 @@ int cfg80211_vendor_cmd_reply(struct sk_buff *skb) | |||
| 9294 | void *hdr = ((void **)skb->cb)[1]; | 9297 | void *hdr = ((void **)skb->cb)[1]; |
| 9295 | struct nlattr *data = ((void **)skb->cb)[2]; | 9298 | struct nlattr *data = ((void **)skb->cb)[2]; |
| 9296 | 9299 | ||
| 9300 | /* clear CB data for netlink core to own from now on */ | ||
| 9301 | memset(skb->cb, 0, sizeof(skb->cb)); | ||
| 9302 | |||
| 9297 | if (WARN_ON(!rdev->cur_cmd_info)) { | 9303 | if (WARN_ON(!rdev->cur_cmd_info)) { |
| 9298 | kfree_skb(skb); | 9304 | kfree_skb(skb); |
| 9299 | return -EINVAL; | 9305 | return -EINVAL; |
diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c index beeed602aeb3..fdde51f4271a 100644 --- a/net/xfrm/xfrm_policy.c +++ b/net/xfrm/xfrm_policy.c | |||
| @@ -39,6 +39,11 @@ | |||
| 39 | #define XFRM_QUEUE_TMO_MAX ((unsigned)(60*HZ)) | 39 | #define XFRM_QUEUE_TMO_MAX ((unsigned)(60*HZ)) |
| 40 | #define XFRM_MAX_QUEUE_LEN 100 | 40 | #define XFRM_MAX_QUEUE_LEN 100 |
| 41 | 41 | ||
| 42 | struct xfrm_flo { | ||
| 43 | struct dst_entry *dst_orig; | ||
| 44 | u8 flags; | ||
| 45 | }; | ||
| 46 | |||
| 42 | static DEFINE_SPINLOCK(xfrm_policy_afinfo_lock); | 47 | static DEFINE_SPINLOCK(xfrm_policy_afinfo_lock); |
| 43 | static struct xfrm_policy_afinfo __rcu *xfrm_policy_afinfo[NPROTO] | 48 | static struct xfrm_policy_afinfo __rcu *xfrm_policy_afinfo[NPROTO] |
| 44 | __read_mostly; | 49 | __read_mostly; |
| @@ -1877,13 +1882,14 @@ static int xdst_queue_output(struct sock *sk, struct sk_buff *skb) | |||
| 1877 | } | 1882 | } |
| 1878 | 1883 | ||
| 1879 | static struct xfrm_dst *xfrm_create_dummy_bundle(struct net *net, | 1884 | static struct xfrm_dst *xfrm_create_dummy_bundle(struct net *net, |
| 1880 | struct dst_entry *dst, | 1885 | struct xfrm_flo *xflo, |
| 1881 | const struct flowi *fl, | 1886 | const struct flowi *fl, |
| 1882 | int num_xfrms, | 1887 | int num_xfrms, |
| 1883 | u16 family) | 1888 | u16 family) |
| 1884 | { | 1889 | { |
| 1885 | int err; | 1890 | int err; |
| 1886 | struct net_device *dev; | 1891 | struct net_device *dev; |
| 1892 | struct dst_entry *dst; | ||
| 1887 | struct dst_entry *dst1; | 1893 | struct dst_entry *dst1; |
| 1888 | struct xfrm_dst *xdst; | 1894 | struct xfrm_dst *xdst; |
| 1889 | 1895 | ||
| @@ -1891,9 +1897,12 @@ static struct xfrm_dst *xfrm_create_dummy_bundle(struct net *net, | |||
| 1891 | if (IS_ERR(xdst)) | 1897 | if (IS_ERR(xdst)) |
| 1892 | return xdst; | 1898 | return xdst; |
| 1893 | 1899 | ||
| 1894 | if (net->xfrm.sysctl_larval_drop || num_xfrms <= 0) | 1900 | if (!(xflo->flags & XFRM_LOOKUP_QUEUE) || |
| 1901 | net->xfrm.sysctl_larval_drop || | ||
| 1902 | num_xfrms <= 0) | ||
| 1895 | return xdst; | 1903 | return xdst; |
| 1896 | 1904 | ||
| 1905 | dst = xflo->dst_orig; | ||
| 1897 | dst1 = &xdst->u.dst; | 1906 | dst1 = &xdst->u.dst; |
| 1898 | dst_hold(dst); | 1907 | dst_hold(dst); |
| 1899 | xdst->route = dst; | 1908 | xdst->route = dst; |
| @@ -1935,7 +1944,7 @@ static struct flow_cache_object * | |||
| 1935 | xfrm_bundle_lookup(struct net *net, const struct flowi *fl, u16 family, u8 dir, | 1944 | xfrm_bundle_lookup(struct net *net, const struct flowi *fl, u16 family, u8 dir, |
| 1936 | struct flow_cache_object *oldflo, void *ctx) | 1945 | struct flow_cache_object *oldflo, void *ctx) |
| 1937 | { | 1946 | { |
| 1938 | struct dst_entry *dst_orig = (struct dst_entry *)ctx; | 1947 | struct xfrm_flo *xflo = (struct xfrm_flo *)ctx; |
| 1939 | struct xfrm_policy *pols[XFRM_POLICY_TYPE_MAX]; | 1948 | struct xfrm_policy *pols[XFRM_POLICY_TYPE_MAX]; |
| 1940 | struct xfrm_dst *xdst, *new_xdst; | 1949 | struct xfrm_dst *xdst, *new_xdst; |
| 1941 | int num_pols = 0, num_xfrms = 0, i, err, pol_dead; | 1950 | int num_pols = 0, num_xfrms = 0, i, err, pol_dead; |
| @@ -1976,7 +1985,8 @@ xfrm_bundle_lookup(struct net *net, const struct flowi *fl, u16 family, u8 dir, | |||
| 1976 | goto make_dummy_bundle; | 1985 | goto make_dummy_bundle; |
| 1977 | } | 1986 | } |
| 1978 | 1987 | ||
| 1979 | new_xdst = xfrm_resolve_and_create_bundle(pols, num_pols, fl, family, dst_orig); | 1988 | new_xdst = xfrm_resolve_and_create_bundle(pols, num_pols, fl, family, |
| 1989 | xflo->dst_orig); | ||
| 1980 | if (IS_ERR(new_xdst)) { | 1990 | if (IS_ERR(new_xdst)) { |
| 1981 | err = PTR_ERR(new_xdst); | 1991 | err = PTR_ERR(new_xdst); |
| 1982 | if (err != -EAGAIN) | 1992 | if (err != -EAGAIN) |
| @@ -2010,7 +2020,7 @@ make_dummy_bundle: | |||
| 2010 | /* We found policies, but there's no bundles to instantiate: | 2020 | /* We found policies, but there's no bundles to instantiate: |
| 2011 | * either because the policy blocks, has no transformations or | 2021 | * either because the policy blocks, has no transformations or |
| 2012 | * we could not build template (no xfrm_states).*/ | 2022 | * we could not build template (no xfrm_states).*/ |
| 2013 | xdst = xfrm_create_dummy_bundle(net, dst_orig, fl, num_xfrms, family); | 2023 | xdst = xfrm_create_dummy_bundle(net, xflo, fl, num_xfrms, family); |
| 2014 | if (IS_ERR(xdst)) { | 2024 | if (IS_ERR(xdst)) { |
| 2015 | xfrm_pols_put(pols, num_pols); | 2025 | xfrm_pols_put(pols, num_pols); |
| 2016 | return ERR_CAST(xdst); | 2026 | return ERR_CAST(xdst); |
| @@ -2104,13 +2114,18 @@ struct dst_entry *xfrm_lookup(struct net *net, struct dst_entry *dst_orig, | |||
| 2104 | } | 2114 | } |
| 2105 | 2115 | ||
| 2106 | if (xdst == NULL) { | 2116 | if (xdst == NULL) { |
| 2117 | struct xfrm_flo xflo; | ||
| 2118 | |||
| 2119 | xflo.dst_orig = dst_orig; | ||
| 2120 | xflo.flags = flags; | ||
| 2121 | |||
| 2107 | /* To accelerate a bit... */ | 2122 | /* To accelerate a bit... */ |
| 2108 | if ((dst_orig->flags & DST_NOXFRM) || | 2123 | if ((dst_orig->flags & DST_NOXFRM) || |
| 2109 | !net->xfrm.policy_count[XFRM_POLICY_OUT]) | 2124 | !net->xfrm.policy_count[XFRM_POLICY_OUT]) |
| 2110 | goto nopol; | 2125 | goto nopol; |
| 2111 | 2126 | ||
| 2112 | flo = flow_cache_lookup(net, fl, family, dir, | 2127 | flo = flow_cache_lookup(net, fl, family, dir, |
| 2113 | xfrm_bundle_lookup, dst_orig); | 2128 | xfrm_bundle_lookup, &xflo); |
| 2114 | if (flo == NULL) | 2129 | if (flo == NULL) |
| 2115 | goto nopol; | 2130 | goto nopol; |
| 2116 | if (IS_ERR(flo)) { | 2131 | if (IS_ERR(flo)) { |
| @@ -2138,7 +2153,7 @@ struct dst_entry *xfrm_lookup(struct net *net, struct dst_entry *dst_orig, | |||
| 2138 | xfrm_pols_put(pols, drop_pols); | 2153 | xfrm_pols_put(pols, drop_pols); |
| 2139 | XFRM_INC_STATS(net, LINUX_MIB_XFRMOUTNOSTATES); | 2154 | XFRM_INC_STATS(net, LINUX_MIB_XFRMOUTNOSTATES); |
| 2140 | 2155 | ||
| 2141 | return make_blackhole(net, family, dst_orig); | 2156 | return ERR_PTR(-EREMOTE); |
| 2142 | } | 2157 | } |
| 2143 | 2158 | ||
| 2144 | err = -EAGAIN; | 2159 | err = -EAGAIN; |
| @@ -2195,6 +2210,23 @@ dropdst: | |||
| 2195 | } | 2210 | } |
| 2196 | EXPORT_SYMBOL(xfrm_lookup); | 2211 | EXPORT_SYMBOL(xfrm_lookup); |
| 2197 | 2212 | ||
| 2213 | /* Callers of xfrm_lookup_route() must ensure a call to dst_output(). | ||
| 2214 | * Otherwise we may send out blackholed packets. | ||
| 2215 | */ | ||
| 2216 | struct dst_entry *xfrm_lookup_route(struct net *net, struct dst_entry *dst_orig, | ||
| 2217 | const struct flowi *fl, | ||
| 2218 | struct sock *sk, int flags) | ||
| 2219 | { | ||
| 2220 | struct dst_entry *dst = xfrm_lookup(net, dst_orig, fl, sk, | ||
| 2221 | flags | XFRM_LOOKUP_QUEUE); | ||
| 2222 | |||
| 2223 | if (IS_ERR(dst) && PTR_ERR(dst) == -EREMOTE) | ||
| 2224 | return make_blackhole(net, dst_orig->ops->family, dst_orig); | ||
| 2225 | |||
| 2226 | return dst; | ||
| 2227 | } | ||
| 2228 | EXPORT_SYMBOL(xfrm_lookup_route); | ||
| 2229 | |||
| 2198 | static inline int | 2230 | static inline int |
| 2199 | xfrm_secpath_reject(int idx, struct sk_buff *skb, const struct flowi *fl) | 2231 | xfrm_secpath_reject(int idx, struct sk_buff *skb, const struct flowi *fl) |
| 2200 | { | 2232 | { |
| @@ -2460,7 +2492,7 @@ int __xfrm_route_forward(struct sk_buff *skb, unsigned short family) | |||
| 2460 | 2492 | ||
| 2461 | skb_dst_force(skb); | 2493 | skb_dst_force(skb); |
| 2462 | 2494 | ||
| 2463 | dst = xfrm_lookup(net, skb_dst(skb), &fl, NULL, 0); | 2495 | dst = xfrm_lookup(net, skb_dst(skb), &fl, NULL, XFRM_LOOKUP_QUEUE); |
| 2464 | if (IS_ERR(dst)) { | 2496 | if (IS_ERR(dst)) { |
| 2465 | res = 0; | 2497 | res = 0; |
| 2466 | dst = NULL; | 2498 | dst = NULL; |
