Merge git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net
Pull networking fixes from David Miller: "Various fixes, all over: 1) Fix overflow in ptp_qoriq_adjfine(), from Yangbo Lu. 2) Always store the rx queue mapping in veth, from Maciej Fijalkowski. 3) Don't allow vmlinux btf in map_create, from Alexei Starovoitov. 4) Fix memory leak in octeontx2-af from Colin Ian King. 5) Use kvalloc in bpf x86 JIT for storing jit'd addresses, from Yonghong Song. 6) Fix tx ptp stats in mlx5, from Aya Levin. 7) Check correct ip version in tun decap, fropm Roi Dayan. 8) Fix rate calculation in mlx5 E-Switch code, from arav Pandit. 9) Work item memork leak in mlx5, from Shay Drory. 10) Fix ip6ip6 tunnel crash with bpf, from Daniel Borkmann. 11) Lack of preemptrion awareness in macvlan, from Eric Dumazet. 12) Fix data race in pxa168_eth, from Pavel Andrianov. 13) Range validate stab in red_check_params(), from Eric Dumazet. 14) Inherit vlan filtering setting properly in b53 driver, from Florian Fainelli. 15) Fix rtnl locking in igc driver, from Sasha Neftin. 16) Pause handling fixes in igc driver, from Muhammad Husaini Zulkifli. 17) Missing rtnl locking in e1000_reset_task, from Vitaly Lifshits. 18) Use after free in qlcnic, from Lv Yunlong. 19) fix crash in fritzpci mISDN, from Tong Zhang. 20) Premature rx buffer reuse in igb, from Li RongQing. 21) Missing termination of ip[a driver message handler arrays, from Alex Elder. 22) Fix race between "x25_close" and "x25_xmit"/"x25_rx" in hdlc_x25 driver, from Xie He. 23) Use after free in c_can_pci_remove(), from Tong Zhang. 24) Uninitialized variable use in nl80211, from Jarod Wilson. 25) Off by one size calc in bpf verifier, from Piotr Krysiuk. 26) Use delayed work instead of deferrable for flowtable GC, from Yinjun Zhang. 27) Fix infinite loop in NPC unmap of octeontx2 driver, from Hariprasad Kelam. 28) Fix being unable to change MTU of dwmac-sun8i devices due to lack of fifo sizes, from Corentin Labbe. 29) DMA use after free in r8169 with WoL, fom Heiner Kallweit. 30) Mismatched prototypes in isdn-capi, from Arnd Bergmann. 31) Fix psample UAPI breakage, from Ido Schimmel" * git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net: (171 commits) psample: Fix user API breakage math: Export mul_u64_u64_div_u64 ch_ktls: fix enum-conversion warning octeontx2-af: Fix memory leak of object buf ptp_qoriq: fix overflow in ptp_qoriq_adjfine() u64 calcalation net: bridge: don't notify switchdev for local FDB addresses net/sched: act_ct: clear post_ct if doing ct_clear net: dsa: don't assign an error value to tag_ops isdn: capi: fix mismatched prototypes net/mlx5: SF, do not use ecpu bit for vhca state processing net/mlx5e: Fix division by 0 in mlx5e_select_queue net/mlx5e: Fix error path for ethtool set-priv-flag net/mlx5e: Offload tuple rewrite for non-CT flows net/mlx5e: Allow to match on MPLS parameters only for MPLS over UDP net/mlx5: Add back multicast stats for uplink representor net: ipconfig: ic_dev can be NULL in ic_close_devs MAINTAINERS: Combine "QLOGIC QLGE 10Gb ETHERNET DRIVER" sections into one docs: networking: Fix a typo r8169: fix DMA being used after buffer free if WoL is enabled net: ipa: fix init header command validation ...
This commit is contained in:
commit
e138138003
|
@ -267,7 +267,7 @@ DATA PATH
|
||||||
Tx
|
Tx
|
||||||
--
|
--
|
||||||
|
|
||||||
end_start_xmit() is called by the stack. This function does the following:
|
ena_start_xmit() is called by the stack. This function does the following:
|
||||||
|
|
||||||
- Maps data buffers (skb->data and frags).
|
- Maps data buffers (skb->data and frags).
|
||||||
- Populates ena_buf for the push buffer (if the driver and device are
|
- Populates ena_buf for the push buffer (if the driver and device are
|
||||||
|
|
|
@ -52,7 +52,7 @@ purposes as a standard complementary tool. The system's view from
|
||||||
``devlink-dpipe`` should change according to the changes done by the
|
``devlink-dpipe`` should change according to the changes done by the
|
||||||
standard configuration tools.
|
standard configuration tools.
|
||||||
|
|
||||||
For example, it’s quiet common to implement Access Control Lists (ACL)
|
For example, it’s quite common to implement Access Control Lists (ACL)
|
||||||
using Ternary Content Addressable Memory (TCAM). The TCAM memory can be
|
using Ternary Content Addressable Memory (TCAM). The TCAM memory can be
|
||||||
divided into TCAM regions. Complex TC filters can have multiple rules with
|
divided into TCAM regions. Complex TC filters can have multiple rules with
|
||||||
different priorities and different lookup keys. On the other hand hardware
|
different priorities and different lookup keys. On the other hand hardware
|
||||||
|
|
|
@ -151,7 +151,7 @@ representor netdevice.
|
||||||
-------------
|
-------------
|
||||||
A subfunction devlink port is created but it is not active yet. That means the
|
A subfunction devlink port is created but it is not active yet. That means the
|
||||||
entities are created on devlink side, the e-switch port representor is created,
|
entities are created on devlink side, the e-switch port representor is created,
|
||||||
but the subfunction device itself it not created. A user might use e-switch port
|
but the subfunction device itself is not created. A user might use e-switch port
|
||||||
representor to do settings, putting it into bridge, adding TC rules, etc. A user
|
representor to do settings, putting it into bridge, adding TC rules, etc. A user
|
||||||
might as well configure the hardware address (such as MAC address) of the
|
might as well configure the hardware address (such as MAC address) of the
|
||||||
subfunction while subfunction is inactive.
|
subfunction while subfunction is inactive.
|
||||||
|
@ -173,7 +173,7 @@ Terms and Definitions
|
||||||
* - Term
|
* - Term
|
||||||
- Definitions
|
- Definitions
|
||||||
* - ``PCI device``
|
* - ``PCI device``
|
||||||
- A physical PCI device having one or more PCI bus consists of one or
|
- A physical PCI device having one or more PCI buses consists of one or
|
||||||
more PCI controllers.
|
more PCI controllers.
|
||||||
* - ``PCI controller``
|
* - ``PCI controller``
|
||||||
- A controller consists of potentially multiple physical functions,
|
- A controller consists of potentially multiple physical functions,
|
||||||
|
|
|
@ -50,7 +50,7 @@ Callbacks to implement
|
||||||
|
|
||||||
The NIC driver offering ipsec offload will need to implement these
|
The NIC driver offering ipsec offload will need to implement these
|
||||||
callbacks to make the offload available to the network stack's
|
callbacks to make the offload available to the network stack's
|
||||||
XFRM subsytem. Additionally, the feature bits NETIF_F_HW_ESP and
|
XFRM subsystem. Additionally, the feature bits NETIF_F_HW_ESP and
|
||||||
NETIF_F_HW_ESP_TX_CSUM will signal the availability of the offload.
|
NETIF_F_HW_ESP_TX_CSUM will signal the availability of the offload.
|
||||||
|
|
||||||
|
|
||||||
|
|
15
MAINTAINERS
15
MAINTAINERS
|
@ -8520,6 +8520,7 @@ IBM Power SRIOV Virtual NIC Device Driver
|
||||||
M: Dany Madden <drt@linux.ibm.com>
|
M: Dany Madden <drt@linux.ibm.com>
|
||||||
M: Lijun Pan <ljp@linux.ibm.com>
|
M: Lijun Pan <ljp@linux.ibm.com>
|
||||||
M: Sukadev Bhattiprolu <sukadev@linux.ibm.com>
|
M: Sukadev Bhattiprolu <sukadev@linux.ibm.com>
|
||||||
|
R: Thomas Falcon <tlfalcon@linux.ibm.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/net/ethernet/ibm/ibmvnic.*
|
F: drivers/net/ethernet/ibm/ibmvnic.*
|
||||||
|
@ -12537,7 +12538,7 @@ NETWORKING [MPTCP]
|
||||||
M: Mat Martineau <mathew.j.martineau@linux.intel.com>
|
M: Mat Martineau <mathew.j.martineau@linux.intel.com>
|
||||||
M: Matthieu Baerts <matthieu.baerts@tessares.net>
|
M: Matthieu Baerts <matthieu.baerts@tessares.net>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
L: mptcp@lists.01.org
|
L: mptcp@lists.linux.dev
|
||||||
S: Maintained
|
S: Maintained
|
||||||
W: https://github.com/multipath-tcp/mptcp_net-next/wiki
|
W: https://github.com/multipath-tcp/mptcp_net-next/wiki
|
||||||
B: https://github.com/multipath-tcp/mptcp_net-next/issues
|
B: https://github.com/multipath-tcp/mptcp_net-next/issues
|
||||||
|
@ -14708,15 +14709,11 @@ F: drivers/net/ethernet/qlogic/qlcnic/
|
||||||
QLOGIC QLGE 10Gb ETHERNET DRIVER
|
QLOGIC QLGE 10Gb ETHERNET DRIVER
|
||||||
M: Manish Chopra <manishc@marvell.com>
|
M: Manish Chopra <manishc@marvell.com>
|
||||||
M: GR-Linux-NIC-Dev@marvell.com
|
M: GR-Linux-NIC-Dev@marvell.com
|
||||||
L: netdev@vger.kernel.org
|
|
||||||
S: Supported
|
|
||||||
F: drivers/staging/qlge/
|
|
||||||
|
|
||||||
QLOGIC QLGE 10Gb ETHERNET DRIVER
|
|
||||||
M: Coiby Xu <coiby.xu@gmail.com>
|
M: Coiby Xu <coiby.xu@gmail.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Maintained
|
S: Supported
|
||||||
F: Documentation/networking/device_drivers/qlogic/qlge.rst
|
F: Documentation/networking/device_drivers/qlogic/qlge.rst
|
||||||
|
F: drivers/staging/qlge/
|
||||||
|
|
||||||
QM1D1B0004 MEDIA DRIVER
|
QM1D1B0004 MEDIA DRIVER
|
||||||
M: Akihiro Tsukada <tskd08@gmail.com>
|
M: Akihiro Tsukada <tskd08@gmail.com>
|
||||||
|
@ -16886,8 +16883,10 @@ F: tools/spi/
|
||||||
|
|
||||||
SPIDERNET NETWORK DRIVER for CELL
|
SPIDERNET NETWORK DRIVER for CELL
|
||||||
M: Ishizaki Kou <kou.ishizaki@toshiba.co.jp>
|
M: Ishizaki Kou <kou.ishizaki@toshiba.co.jp>
|
||||||
|
M: Geoff Levand <geoff@infradead.org>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
L: linuxppc-dev@lists.ozlabs.org
|
||||||
|
S: Maintained
|
||||||
F: Documentation/networking/device_drivers/ethernet/toshiba/spider_net.rst
|
F: Documentation/networking/device_drivers/ethernet/toshiba/spider_net.rst
|
||||||
F: drivers/net/ethernet/toshiba/spider_net*
|
F: drivers/net/ethernet/toshiba/spider_net*
|
||||||
|
|
||||||
|
|
|
@ -1936,7 +1936,7 @@ static int invoke_bpf_mod_ret(const struct btf_func_model *m, u8 **pprog,
|
||||||
* add rsp, 8 // skip eth_type_trans's frame
|
* add rsp, 8 // skip eth_type_trans's frame
|
||||||
* ret // return to its caller
|
* ret // return to its caller
|
||||||
*/
|
*/
|
||||||
int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
int arch_prepare_bpf_trampoline(struct bpf_tramp_image *im, void *image, void *image_end,
|
||||||
const struct btf_func_model *m, u32 flags,
|
const struct btf_func_model *m, u32 flags,
|
||||||
struct bpf_tramp_progs *tprogs,
|
struct bpf_tramp_progs *tprogs,
|
||||||
void *orig_call)
|
void *orig_call)
|
||||||
|
@ -1975,6 +1975,15 @@ int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
||||||
|
|
||||||
save_regs(m, &prog, nr_args, stack_size);
|
save_regs(m, &prog, nr_args, stack_size);
|
||||||
|
|
||||||
|
if (flags & BPF_TRAMP_F_CALL_ORIG) {
|
||||||
|
/* arg1: mov rdi, im */
|
||||||
|
emit_mov_imm64(&prog, BPF_REG_1, (long) im >> 32, (u32) (long) im);
|
||||||
|
if (emit_call(&prog, __bpf_tramp_enter, prog)) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (fentry->nr_progs)
|
if (fentry->nr_progs)
|
||||||
if (invoke_bpf(m, &prog, fentry, stack_size))
|
if (invoke_bpf(m, &prog, fentry, stack_size))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -1993,8 +2002,7 @@ int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & BPF_TRAMP_F_CALL_ORIG) {
|
if (flags & BPF_TRAMP_F_CALL_ORIG) {
|
||||||
if (fentry->nr_progs || fmod_ret->nr_progs)
|
restore_regs(m, &prog, nr_args, stack_size);
|
||||||
restore_regs(m, &prog, nr_args, stack_size);
|
|
||||||
|
|
||||||
/* call original function */
|
/* call original function */
|
||||||
if (emit_call(&prog, orig_call, prog)) {
|
if (emit_call(&prog, orig_call, prog)) {
|
||||||
|
@ -2003,6 +2011,9 @@ int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
||||||
}
|
}
|
||||||
/* remember return value in a stack for bpf prog to access */
|
/* remember return value in a stack for bpf prog to access */
|
||||||
emit_stx(&prog, BPF_DW, BPF_REG_FP, BPF_REG_0, -8);
|
emit_stx(&prog, BPF_DW, BPF_REG_FP, BPF_REG_0, -8);
|
||||||
|
im->ip_after_call = prog;
|
||||||
|
memcpy(prog, ideal_nops[NOP_ATOMIC5], X86_PATCH_SIZE);
|
||||||
|
prog += X86_PATCH_SIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fmod_ret->nr_progs) {
|
if (fmod_ret->nr_progs) {
|
||||||
|
@ -2033,9 +2044,17 @@ int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
||||||
* the return value is only updated on the stack and still needs to be
|
* the return value is only updated on the stack and still needs to be
|
||||||
* restored to R0.
|
* restored to R0.
|
||||||
*/
|
*/
|
||||||
if (flags & BPF_TRAMP_F_CALL_ORIG)
|
if (flags & BPF_TRAMP_F_CALL_ORIG) {
|
||||||
|
im->ip_epilogue = prog;
|
||||||
|
/* arg1: mov rdi, im */
|
||||||
|
emit_mov_imm64(&prog, BPF_REG_1, (long) im >> 32, (u32) (long) im);
|
||||||
|
if (emit_call(&prog, __bpf_tramp_exit, prog)) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
/* restore original return value back into RAX */
|
/* restore original return value back into RAX */
|
||||||
emit_ldx(&prog, BPF_DW, BPF_REG_0, BPF_REG_FP, -8);
|
emit_ldx(&prog, BPF_DW, BPF_REG_0, BPF_REG_FP, -8);
|
||||||
|
}
|
||||||
|
|
||||||
EMIT1(0x5B); /* pop rbx */
|
EMIT1(0x5B); /* pop rbx */
|
||||||
EMIT1(0xC9); /* leave */
|
EMIT1(0xC9); /* leave */
|
||||||
|
@ -2225,7 +2244,7 @@ struct bpf_prog *bpf_int_jit_compile(struct bpf_prog *prog)
|
||||||
padding = true;
|
padding = true;
|
||||||
goto skip_init_addrs;
|
goto skip_init_addrs;
|
||||||
}
|
}
|
||||||
addrs = kmalloc_array(prog->len + 1, sizeof(*addrs), GFP_KERNEL);
|
addrs = kvmalloc_array(prog->len + 1, sizeof(*addrs), GFP_KERNEL);
|
||||||
if (!addrs) {
|
if (!addrs) {
|
||||||
prog = orig_prog;
|
prog = orig_prog;
|
||||||
goto out_addrs;
|
goto out_addrs;
|
||||||
|
@ -2317,7 +2336,7 @@ out_image:
|
||||||
if (image)
|
if (image)
|
||||||
bpf_prog_fill_jited_linfo(prog, addrs + 1);
|
bpf_prog_fill_jited_linfo(prog, addrs + 1);
|
||||||
out_addrs:
|
out_addrs:
|
||||||
kfree(addrs);
|
kvfree(addrs);
|
||||||
kfree(jit_data);
|
kfree(jit_data);
|
||||||
prog->aux->jit_data = NULL;
|
prog->aux->jit_data = NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1078,7 +1078,7 @@ static int _create_kernel_qp(struct mlx5_ib_dev *dev,
|
||||||
|
|
||||||
qpc = MLX5_ADDR_OF(create_qp_in, *in, qpc);
|
qpc = MLX5_ADDR_OF(create_qp_in, *in, qpc);
|
||||||
MLX5_SET(qpc, qpc, uar_page, uar_index);
|
MLX5_SET(qpc, qpc, uar_page, uar_index);
|
||||||
MLX5_SET(qpc, qpc, ts_format, MLX5_QPC_TIMESTAMP_FORMAT_DEFAULT);
|
MLX5_SET(qpc, qpc, ts_format, mlx5_get_qp_default_ts(dev->mdev));
|
||||||
MLX5_SET(qpc, qpc, log_page_size, qp->buf.page_shift - MLX5_ADAPTER_PAGE_SHIFT);
|
MLX5_SET(qpc, qpc, log_page_size, qp->buf.page_shift - MLX5_ADAPTER_PAGE_SHIFT);
|
||||||
|
|
||||||
/* Set "fast registration enabled" for all kernel QPs */
|
/* Set "fast registration enabled" for all kernel QPs */
|
||||||
|
@ -1188,7 +1188,8 @@ static int get_rq_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq)
|
||||||
}
|
}
|
||||||
return MLX5_RQC_TIMESTAMP_FORMAT_FREE_RUNNING;
|
return MLX5_RQC_TIMESTAMP_FORMAT_FREE_RUNNING;
|
||||||
}
|
}
|
||||||
return MLX5_RQC_TIMESTAMP_FORMAT_DEFAULT;
|
return fr_supported ? MLX5_RQC_TIMESTAMP_FORMAT_FREE_RUNNING :
|
||||||
|
MLX5_RQC_TIMESTAMP_FORMAT_DEFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int get_sq_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq)
|
static int get_sq_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq)
|
||||||
|
@ -1206,7 +1207,8 @@ static int get_sq_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq)
|
||||||
}
|
}
|
||||||
return MLX5_SQC_TIMESTAMP_FORMAT_FREE_RUNNING;
|
return MLX5_SQC_TIMESTAMP_FORMAT_FREE_RUNNING;
|
||||||
}
|
}
|
||||||
return MLX5_SQC_TIMESTAMP_FORMAT_DEFAULT;
|
return fr_supported ? MLX5_SQC_TIMESTAMP_FORMAT_FREE_RUNNING :
|
||||||
|
MLX5_SQC_TIMESTAMP_FORMAT_DEFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int get_qp_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq,
|
static int get_qp_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq,
|
||||||
|
@ -1217,7 +1219,8 @@ static int get_qp_ts_format(struct mlx5_ib_dev *dev, struct mlx5_ib_cq *send_cq,
|
||||||
MLX5_QP_TIMESTAMP_FORMAT_CAP_FREE_RUNNING ||
|
MLX5_QP_TIMESTAMP_FORMAT_CAP_FREE_RUNNING ||
|
||||||
MLX5_CAP_ROCE(dev->mdev, qp_ts_format) ==
|
MLX5_CAP_ROCE(dev->mdev, qp_ts_format) ==
|
||||||
MLX5_QP_TIMESTAMP_FORMAT_CAP_FREE_RUNNING_AND_REAL_TIME;
|
MLX5_QP_TIMESTAMP_FORMAT_CAP_FREE_RUNNING_AND_REAL_TIME;
|
||||||
int ts_format = MLX5_QPC_TIMESTAMP_FORMAT_DEFAULT;
|
int ts_format = fr_supported ? MLX5_QPC_TIMESTAMP_FORMAT_FREE_RUNNING :
|
||||||
|
MLX5_QPC_TIMESTAMP_FORMAT_DEFAULT;
|
||||||
|
|
||||||
if (recv_cq &&
|
if (recv_cq &&
|
||||||
recv_cq->create_flags & IB_UVERBS_CQ_FLAGS_TIMESTAMP_COMPLETION)
|
recv_cq->create_flags & IB_UVERBS_CQ_FLAGS_TIMESTAMP_COMPLETION)
|
||||||
|
@ -1930,6 +1933,7 @@ static int create_xrc_tgt_qp(struct mlx5_ib_dev *dev, struct mlx5_ib_qp *qp,
|
||||||
if (qp->flags & IB_QP_CREATE_MANAGED_RECV)
|
if (qp->flags & IB_QP_CREATE_MANAGED_RECV)
|
||||||
MLX5_SET(qpc, qpc, cd_slave_receive, 1);
|
MLX5_SET(qpc, qpc, cd_slave_receive, 1);
|
||||||
|
|
||||||
|
MLX5_SET(qpc, qpc, ts_format, mlx5_get_qp_default_ts(dev->mdev));
|
||||||
MLX5_SET(qpc, qpc, rq_type, MLX5_SRQ_RQ);
|
MLX5_SET(qpc, qpc, rq_type, MLX5_SRQ_RQ);
|
||||||
MLX5_SET(qpc, qpc, no_sq, 1);
|
MLX5_SET(qpc, qpc, no_sq, 1);
|
||||||
MLX5_SET(qpc, qpc, cqn_rcv, to_mcq(devr->c0)->mcq.cqn);
|
MLX5_SET(qpc, qpc, cqn_rcv, to_mcq(devr->c0)->mcq.cqn);
|
||||||
|
@ -4873,6 +4877,7 @@ static int create_rq(struct mlx5_ib_rwq *rwq, struct ib_pd *pd,
|
||||||
struct mlx5_ib_dev *dev;
|
struct mlx5_ib_dev *dev;
|
||||||
int has_net_offloads;
|
int has_net_offloads;
|
||||||
__be64 *rq_pas0;
|
__be64 *rq_pas0;
|
||||||
|
int ts_format;
|
||||||
void *in;
|
void *in;
|
||||||
void *rqc;
|
void *rqc;
|
||||||
void *wq;
|
void *wq;
|
||||||
|
@ -4881,6 +4886,10 @@ static int create_rq(struct mlx5_ib_rwq *rwq, struct ib_pd *pd,
|
||||||
|
|
||||||
dev = to_mdev(pd->device);
|
dev = to_mdev(pd->device);
|
||||||
|
|
||||||
|
ts_format = get_rq_ts_format(dev, to_mcq(init_attr->cq));
|
||||||
|
if (ts_format < 0)
|
||||||
|
return ts_format;
|
||||||
|
|
||||||
inlen = MLX5_ST_SZ_BYTES(create_rq_in) + sizeof(u64) * rwq->rq_num_pas;
|
inlen = MLX5_ST_SZ_BYTES(create_rq_in) + sizeof(u64) * rwq->rq_num_pas;
|
||||||
in = kvzalloc(inlen, GFP_KERNEL);
|
in = kvzalloc(inlen, GFP_KERNEL);
|
||||||
if (!in)
|
if (!in)
|
||||||
|
@ -4890,6 +4899,7 @@ static int create_rq(struct mlx5_ib_rwq *rwq, struct ib_pd *pd,
|
||||||
rqc = MLX5_ADDR_OF(create_rq_in, in, ctx);
|
rqc = MLX5_ADDR_OF(create_rq_in, in, ctx);
|
||||||
MLX5_SET(rqc, rqc, mem_rq_type,
|
MLX5_SET(rqc, rqc, mem_rq_type,
|
||||||
MLX5_RQC_MEM_RQ_TYPE_MEMORY_RQ_INLINE);
|
MLX5_RQC_MEM_RQ_TYPE_MEMORY_RQ_INLINE);
|
||||||
|
MLX5_SET(rqc, rqc, ts_format, ts_format);
|
||||||
MLX5_SET(rqc, rqc, user_index, rwq->user_index);
|
MLX5_SET(rqc, rqc, user_index, rwq->user_index);
|
||||||
MLX5_SET(rqc, rqc, cqn, to_mcq(init_attr->cq)->mcq.cqn);
|
MLX5_SET(rqc, rqc, cqn, to_mcq(init_attr->cq)->mcq.cqn);
|
||||||
MLX5_SET(rqc, rqc, state, MLX5_RQC_STATE_RST);
|
MLX5_SET(rqc, rqc, state, MLX5_RQC_STATE_RST);
|
||||||
|
|
|
@ -721,7 +721,7 @@ u16 capi20_put_message(struct capi20_appl *ap, struct sk_buff *skb)
|
||||||
* Return value: CAPI result code
|
* Return value: CAPI result code
|
||||||
*/
|
*/
|
||||||
|
|
||||||
u16 capi20_get_manufacturer(u32 contr, u8 *buf)
|
u16 capi20_get_manufacturer(u32 contr, u8 buf[CAPI_MANUFACTURER_LEN])
|
||||||
{
|
{
|
||||||
struct capi_ctr *ctr;
|
struct capi_ctr *ctr;
|
||||||
u16 ret;
|
u16 ret;
|
||||||
|
@ -787,7 +787,7 @@ u16 capi20_get_version(u32 contr, struct capi_version *verp)
|
||||||
* Return value: CAPI result code
|
* Return value: CAPI result code
|
||||||
*/
|
*/
|
||||||
|
|
||||||
u16 capi20_get_serial(u32 contr, u8 *serial)
|
u16 capi20_get_serial(u32 contr, u8 serial[CAPI_SERIAL_LEN])
|
||||||
{
|
{
|
||||||
struct capi_ctr *ctr;
|
struct capi_ctr *ctr;
|
||||||
u16 ret;
|
u16 ret;
|
||||||
|
|
|
@ -694,7 +694,7 @@ isac_release(struct isac_hw *isac)
|
||||||
{
|
{
|
||||||
if (isac->type & IPAC_TYPE_ISACX)
|
if (isac->type & IPAC_TYPE_ISACX)
|
||||||
WriteISAC(isac, ISACX_MASK, 0xff);
|
WriteISAC(isac, ISACX_MASK, 0xff);
|
||||||
else
|
else if (isac->type != 0)
|
||||||
WriteISAC(isac, ISAC_MASK, 0xff);
|
WriteISAC(isac, ISAC_MASK, 0xff);
|
||||||
if (isac->dch.timer.function != NULL) {
|
if (isac->dch.timer.function != NULL) {
|
||||||
del_timer(&isac->dch.timer);
|
del_timer(&isac->dch.timer);
|
||||||
|
|
|
@ -127,6 +127,8 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
int i, ioaddr, ret;
|
int i, ioaddr, ret;
|
||||||
struct resource *r;
|
struct resource *r;
|
||||||
|
|
||||||
|
ret = 0;
|
||||||
|
|
||||||
if (pci_enable_device(pdev))
|
if (pci_enable_device(pdev))
|
||||||
return -EIO;
|
return -EIO;
|
||||||
|
|
||||||
|
@ -139,6 +141,8 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
priv->ci = ci;
|
priv->ci = ci;
|
||||||
mm = &ci->misc_map;
|
mm = &ci->misc_map;
|
||||||
|
|
||||||
|
pci_set_drvdata(pdev, priv);
|
||||||
|
|
||||||
INIT_LIST_HEAD(&priv->list_dev);
|
INIT_LIST_HEAD(&priv->list_dev);
|
||||||
|
|
||||||
if (mm->size) {
|
if (mm->size) {
|
||||||
|
@ -161,7 +165,7 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
dev = alloc_arcdev(device);
|
dev = alloc_arcdev(device);
|
||||||
if (!dev) {
|
if (!dev) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto out_port;
|
break;
|
||||||
}
|
}
|
||||||
dev->dev_port = i;
|
dev->dev_port = i;
|
||||||
|
|
||||||
|
@ -178,7 +182,7 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
pr_err("IO region %xh-%xh already allocated\n",
|
pr_err("IO region %xh-%xh already allocated\n",
|
||||||
ioaddr, ioaddr + cm->size - 1);
|
ioaddr, ioaddr + cm->size - 1);
|
||||||
ret = -EBUSY;
|
ret = -EBUSY;
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Dummy access after Reset
|
/* Dummy access after Reset
|
||||||
|
@ -216,18 +220,18 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
if (arcnet_inb(ioaddr, COM20020_REG_R_STATUS) == 0xFF) {
|
if (arcnet_inb(ioaddr, COM20020_REG_R_STATUS) == 0xFF) {
|
||||||
pr_err("IO address %Xh is empty!\n", ioaddr);
|
pr_err("IO address %Xh is empty!\n", ioaddr);
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
}
|
}
|
||||||
if (com20020_check(dev)) {
|
if (com20020_check(dev)) {
|
||||||
ret = -EIO;
|
ret = -EIO;
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
}
|
}
|
||||||
|
|
||||||
card = devm_kzalloc(&pdev->dev, sizeof(struct com20020_dev),
|
card = devm_kzalloc(&pdev->dev, sizeof(struct com20020_dev),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
if (!card) {
|
if (!card) {
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
}
|
}
|
||||||
|
|
||||||
card->index = i;
|
card->index = i;
|
||||||
|
@ -253,29 +257,29 @@ static int com20020pci_probe(struct pci_dev *pdev,
|
||||||
|
|
||||||
ret = devm_led_classdev_register(&pdev->dev, &card->tx_led);
|
ret = devm_led_classdev_register(&pdev->dev, &card->tx_led);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
|
|
||||||
ret = devm_led_classdev_register(&pdev->dev, &card->recon_led);
|
ret = devm_led_classdev_register(&pdev->dev, &card->recon_led);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
|
|
||||||
dev_set_drvdata(&dev->dev, card);
|
dev_set_drvdata(&dev->dev, card);
|
||||||
|
|
||||||
ret = com20020_found(dev, IRQF_SHARED);
|
ret = com20020_found(dev, IRQF_SHARED);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto out_port;
|
goto err_free_arcdev;
|
||||||
|
|
||||||
devm_arcnet_led_init(dev, dev->dev_id, i);
|
devm_arcnet_led_init(dev, dev->dev_id, i);
|
||||||
|
|
||||||
list_add(&card->list, &priv->list_dev);
|
list_add(&card->list, &priv->list_dev);
|
||||||
|
continue;
|
||||||
|
|
||||||
|
err_free_arcdev:
|
||||||
|
free_arcdev(dev);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
if (ret)
|
||||||
pci_set_drvdata(pdev, priv);
|
com20020pci_remove(pdev);
|
||||||
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
out_port:
|
|
||||||
com20020pci_remove(pdev);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3978,15 +3978,11 @@ static int bond_neigh_init(struct neighbour *n)
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
slave = bond_first_slave_rcu(bond);
|
slave = bond_first_slave_rcu(bond);
|
||||||
if (!slave) {
|
if (!slave)
|
||||||
ret = -EINVAL;
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
slave_ops = slave->dev->netdev_ops;
|
slave_ops = slave->dev->netdev_ops;
|
||||||
if (!slave_ops->ndo_neigh_setup) {
|
if (!slave_ops->ndo_neigh_setup)
|
||||||
ret = -EINVAL;
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
/* TODO: find another way [1] to implement this.
|
/* TODO: find another way [1] to implement this.
|
||||||
* Passing a zeroed structure is fragile,
|
* Passing a zeroed structure is fragile,
|
||||||
|
|
|
@ -212,18 +212,6 @@ static const struct can_bittiming_const c_can_bittiming_const = {
|
||||||
.brp_inc = 1,
|
.brp_inc = 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline void c_can_pm_runtime_enable(const struct c_can_priv *priv)
|
|
||||||
{
|
|
||||||
if (priv->device)
|
|
||||||
pm_runtime_enable(priv->device);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void c_can_pm_runtime_disable(const struct c_can_priv *priv)
|
|
||||||
{
|
|
||||||
if (priv->device)
|
|
||||||
pm_runtime_disable(priv->device);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void c_can_pm_runtime_get_sync(const struct c_can_priv *priv)
|
static inline void c_can_pm_runtime_get_sync(const struct c_can_priv *priv)
|
||||||
{
|
{
|
||||||
if (priv->device)
|
if (priv->device)
|
||||||
|
@ -1335,7 +1323,6 @@ static const struct net_device_ops c_can_netdev_ops = {
|
||||||
|
|
||||||
int register_c_can_dev(struct net_device *dev)
|
int register_c_can_dev(struct net_device *dev)
|
||||||
{
|
{
|
||||||
struct c_can_priv *priv = netdev_priv(dev);
|
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
/* Deactivate pins to prevent DRA7 DCAN IP from being
|
/* Deactivate pins to prevent DRA7 DCAN IP from being
|
||||||
|
@ -1345,28 +1332,19 @@ int register_c_can_dev(struct net_device *dev)
|
||||||
*/
|
*/
|
||||||
pinctrl_pm_select_sleep_state(dev->dev.parent);
|
pinctrl_pm_select_sleep_state(dev->dev.parent);
|
||||||
|
|
||||||
c_can_pm_runtime_enable(priv);
|
|
||||||
|
|
||||||
dev->flags |= IFF_ECHO; /* we support local echo */
|
dev->flags |= IFF_ECHO; /* we support local echo */
|
||||||
dev->netdev_ops = &c_can_netdev_ops;
|
dev->netdev_ops = &c_can_netdev_ops;
|
||||||
|
|
||||||
err = register_candev(dev);
|
err = register_candev(dev);
|
||||||
if (err)
|
if (!err)
|
||||||
c_can_pm_runtime_disable(priv);
|
|
||||||
else
|
|
||||||
devm_can_led_init(dev);
|
devm_can_led_init(dev);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(register_c_can_dev);
|
EXPORT_SYMBOL_GPL(register_c_can_dev);
|
||||||
|
|
||||||
void unregister_c_can_dev(struct net_device *dev)
|
void unregister_c_can_dev(struct net_device *dev)
|
||||||
{
|
{
|
||||||
struct c_can_priv *priv = netdev_priv(dev);
|
|
||||||
|
|
||||||
unregister_candev(dev);
|
unregister_candev(dev);
|
||||||
|
|
||||||
c_can_pm_runtime_disable(priv);
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(unregister_c_can_dev);
|
EXPORT_SYMBOL_GPL(unregister_c_can_dev);
|
||||||
|
|
||||||
|
|
|
@ -239,12 +239,13 @@ static void c_can_pci_remove(struct pci_dev *pdev)
|
||||||
{
|
{
|
||||||
struct net_device *dev = pci_get_drvdata(pdev);
|
struct net_device *dev = pci_get_drvdata(pdev);
|
||||||
struct c_can_priv *priv = netdev_priv(dev);
|
struct c_can_priv *priv = netdev_priv(dev);
|
||||||
|
void __iomem *addr = priv->base;
|
||||||
|
|
||||||
unregister_c_can_dev(dev);
|
unregister_c_can_dev(dev);
|
||||||
|
|
||||||
free_c_can_dev(dev);
|
free_c_can_dev(dev);
|
||||||
|
|
||||||
pci_iounmap(pdev, priv->base);
|
pci_iounmap(pdev, addr);
|
||||||
pci_disable_msi(pdev);
|
pci_disable_msi(pdev);
|
||||||
pci_clear_master(pdev);
|
pci_clear_master(pdev);
|
||||||
pci_release_regions(pdev);
|
pci_release_regions(pdev);
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include <linux/list.h>
|
#include <linux/list.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/pm_runtime.h>
|
||||||
#include <linux/clk.h>
|
#include <linux/clk.h>
|
||||||
#include <linux/of.h>
|
#include <linux/of.h>
|
||||||
#include <linux/of_device.h>
|
#include <linux/of_device.h>
|
||||||
|
@ -386,6 +387,7 @@ static int c_can_plat_probe(struct platform_device *pdev)
|
||||||
platform_set_drvdata(pdev, dev);
|
platform_set_drvdata(pdev, dev);
|
||||||
SET_NETDEV_DEV(dev, &pdev->dev);
|
SET_NETDEV_DEV(dev, &pdev->dev);
|
||||||
|
|
||||||
|
pm_runtime_enable(priv->device);
|
||||||
ret = register_c_can_dev(dev);
|
ret = register_c_can_dev(dev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(&pdev->dev, "registering %s failed (err=%d)\n",
|
dev_err(&pdev->dev, "registering %s failed (err=%d)\n",
|
||||||
|
@ -398,6 +400,7 @@ static int c_can_plat_probe(struct platform_device *pdev)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
exit_free_device:
|
exit_free_device:
|
||||||
|
pm_runtime_disable(priv->device);
|
||||||
free_c_can_dev(dev);
|
free_c_can_dev(dev);
|
||||||
exit:
|
exit:
|
||||||
dev_err(&pdev->dev, "probe failed\n");
|
dev_err(&pdev->dev, "probe failed\n");
|
||||||
|
@ -408,9 +411,10 @@ exit:
|
||||||
static int c_can_plat_remove(struct platform_device *pdev)
|
static int c_can_plat_remove(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct net_device *dev = platform_get_drvdata(pdev);
|
struct net_device *dev = platform_get_drvdata(pdev);
|
||||||
|
struct c_can_priv *priv = netdev_priv(dev);
|
||||||
|
|
||||||
unregister_c_can_dev(dev);
|
unregister_c_can_dev(dev);
|
||||||
|
pm_runtime_disable(priv->device);
|
||||||
free_c_can_dev(dev);
|
free_c_can_dev(dev);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -355,6 +355,7 @@ static void can_dellink(struct net_device *dev, struct list_head *head)
|
||||||
|
|
||||||
struct rtnl_link_ops can_link_ops __read_mostly = {
|
struct rtnl_link_ops can_link_ops __read_mostly = {
|
||||||
.kind = "can",
|
.kind = "can",
|
||||||
|
.netns_refund = true,
|
||||||
.maxtype = IFLA_CAN_MAX,
|
.maxtype = IFLA_CAN_MAX,
|
||||||
.policy = can_policy,
|
.policy = can_policy,
|
||||||
.setup = can_setup,
|
.setup = can_setup,
|
||||||
|
|
|
@ -697,9 +697,15 @@ static int flexcan_chip_disable(struct flexcan_priv *priv)
|
||||||
static int flexcan_chip_freeze(struct flexcan_priv *priv)
|
static int flexcan_chip_freeze(struct flexcan_priv *priv)
|
||||||
{
|
{
|
||||||
struct flexcan_regs __iomem *regs = priv->regs;
|
struct flexcan_regs __iomem *regs = priv->regs;
|
||||||
unsigned int timeout = 1000 * 1000 * 10 / priv->can.bittiming.bitrate;
|
unsigned int timeout;
|
||||||
|
u32 bitrate = priv->can.bittiming.bitrate;
|
||||||
u32 reg;
|
u32 reg;
|
||||||
|
|
||||||
|
if (bitrate)
|
||||||
|
timeout = 1000 * 1000 * 10 / bitrate;
|
||||||
|
else
|
||||||
|
timeout = FLEXCAN_TIMEOUT_US / 10;
|
||||||
|
|
||||||
reg = priv->read(®s->mcr);
|
reg = priv->read(®s->mcr);
|
||||||
reg |= FLEXCAN_MCR_FRZ | FLEXCAN_MCR_HALT;
|
reg |= FLEXCAN_MCR_FRZ | FLEXCAN_MCR_HALT;
|
||||||
priv->write(reg, ®s->mcr);
|
priv->write(reg, ®s->mcr);
|
||||||
|
|
|
@ -57,6 +57,7 @@ MODULE_DESCRIPTION("CAN driver for Kvaser CAN/PCIe devices");
|
||||||
#define KVASER_PCIEFD_KCAN_STAT_REG 0x418
|
#define KVASER_PCIEFD_KCAN_STAT_REG 0x418
|
||||||
#define KVASER_PCIEFD_KCAN_MODE_REG 0x41c
|
#define KVASER_PCIEFD_KCAN_MODE_REG 0x41c
|
||||||
#define KVASER_PCIEFD_KCAN_BTRN_REG 0x420
|
#define KVASER_PCIEFD_KCAN_BTRN_REG 0x420
|
||||||
|
#define KVASER_PCIEFD_KCAN_BUS_LOAD_REG 0x424
|
||||||
#define KVASER_PCIEFD_KCAN_BTRD_REG 0x428
|
#define KVASER_PCIEFD_KCAN_BTRD_REG 0x428
|
||||||
#define KVASER_PCIEFD_KCAN_PWM_REG 0x430
|
#define KVASER_PCIEFD_KCAN_PWM_REG 0x430
|
||||||
/* Loopback control register */
|
/* Loopback control register */
|
||||||
|
@ -949,6 +950,9 @@ static int kvaser_pciefd_setup_can_ctrls(struct kvaser_pciefd *pcie)
|
||||||
timer_setup(&can->bec_poll_timer, kvaser_pciefd_bec_poll_timer,
|
timer_setup(&can->bec_poll_timer, kvaser_pciefd_bec_poll_timer,
|
||||||
0);
|
0);
|
||||||
|
|
||||||
|
/* Disable Bus load reporting */
|
||||||
|
iowrite32(0, can->reg_base + KVASER_PCIEFD_KCAN_BUS_LOAD_REG);
|
||||||
|
|
||||||
tx_npackets = ioread32(can->reg_base +
|
tx_npackets = ioread32(can->reg_base +
|
||||||
KVASER_PCIEFD_KCAN_TX_NPACKETS_REG);
|
KVASER_PCIEFD_KCAN_TX_NPACKETS_REG);
|
||||||
if (((tx_npackets >> KVASER_PCIEFD_KCAN_TX_NPACKETS_MAX_SHIFT) &
|
if (((tx_npackets >> KVASER_PCIEFD_KCAN_TX_NPACKETS_MAX_SHIFT) &
|
||||||
|
|
|
@ -501,9 +501,6 @@ static int m_can_do_rx_poll(struct net_device *dev, int quota)
|
||||||
}
|
}
|
||||||
|
|
||||||
while ((rxfs & RXFS_FFL_MASK) && (quota > 0)) {
|
while ((rxfs & RXFS_FFL_MASK) && (quota > 0)) {
|
||||||
if (rxfs & RXFS_RFL)
|
|
||||||
netdev_warn(dev, "Rx FIFO 0 Message Lost\n");
|
|
||||||
|
|
||||||
m_can_read_fifo(dev, rxfs);
|
m_can_read_fifo(dev, rxfs);
|
||||||
|
|
||||||
quota--;
|
quota--;
|
||||||
|
@ -876,7 +873,7 @@ static int m_can_rx_peripheral(struct net_device *dev)
|
||||||
{
|
{
|
||||||
struct m_can_classdev *cdev = netdev_priv(dev);
|
struct m_can_classdev *cdev = netdev_priv(dev);
|
||||||
|
|
||||||
m_can_rx_handler(dev, 1);
|
m_can_rx_handler(dev, M_CAN_NAPI_WEIGHT);
|
||||||
|
|
||||||
m_can_enable_all_interrupts(cdev);
|
m_can_enable_all_interrupts(cdev);
|
||||||
|
|
||||||
|
|
|
@ -73,6 +73,7 @@ config CAN_KVASER_USB
|
||||||
- Kvaser Memorator Pro 5xHS
|
- Kvaser Memorator Pro 5xHS
|
||||||
- Kvaser USBcan Light 4xHS
|
- Kvaser USBcan Light 4xHS
|
||||||
- Kvaser USBcan Pro 2xHS v2
|
- Kvaser USBcan Pro 2xHS v2
|
||||||
|
- Kvaser USBcan Pro 4xHS
|
||||||
- Kvaser USBcan Pro 5xHS
|
- Kvaser USBcan Pro 5xHS
|
||||||
- Kvaser U100
|
- Kvaser U100
|
||||||
- Kvaser U100P
|
- Kvaser U100P
|
||||||
|
|
|
@ -86,8 +86,9 @@
|
||||||
#define USB_U100_PRODUCT_ID 273
|
#define USB_U100_PRODUCT_ID 273
|
||||||
#define USB_U100P_PRODUCT_ID 274
|
#define USB_U100P_PRODUCT_ID 274
|
||||||
#define USB_U100S_PRODUCT_ID 275
|
#define USB_U100S_PRODUCT_ID 275
|
||||||
|
#define USB_USBCAN_PRO_4HS_PRODUCT_ID 276
|
||||||
#define USB_HYDRA_PRODUCT_ID_END \
|
#define USB_HYDRA_PRODUCT_ID_END \
|
||||||
USB_U100S_PRODUCT_ID
|
USB_USBCAN_PRO_4HS_PRODUCT_ID
|
||||||
|
|
||||||
static inline bool kvaser_is_leaf(const struct usb_device_id *id)
|
static inline bool kvaser_is_leaf(const struct usb_device_id *id)
|
||||||
{
|
{
|
||||||
|
@ -193,6 +194,7 @@ static const struct usb_device_id kvaser_usb_table[] = {
|
||||||
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100_PRODUCT_ID) },
|
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100_PRODUCT_ID) },
|
||||||
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100P_PRODUCT_ID) },
|
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100P_PRODUCT_ID) },
|
||||||
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100S_PRODUCT_ID) },
|
{ USB_DEVICE(KVASER_VENDOR_ID, USB_U100S_PRODUCT_ID) },
|
||||||
|
{ USB_DEVICE(KVASER_VENDOR_ID, USB_USBCAN_PRO_4HS_PRODUCT_ID) },
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(usb, kvaser_usb_table);
|
MODULE_DEVICE_TABLE(usb, kvaser_usb_table);
|
||||||
|
|
|
@ -1105,13 +1105,6 @@ static int b53_setup(struct dsa_switch *ds)
|
||||||
b53_disable_port(ds, port);
|
b53_disable_port(ds, port);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Let DSA handle the case were multiple bridges span the same switch
|
|
||||||
* device and different VLAN awareness settings are requested, which
|
|
||||||
* would be breaking filtering semantics for any of the other bridge
|
|
||||||
* devices. (not hardware supported)
|
|
||||||
*/
|
|
||||||
ds->vlan_filtering_is_global = true;
|
|
||||||
|
|
||||||
return b53_setup_devlink_resources(ds);
|
return b53_setup_devlink_resources(ds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2664,6 +2657,13 @@ struct b53_device *b53_switch_alloc(struct device *base,
|
||||||
ds->ops = &b53_switch_ops;
|
ds->ops = &b53_switch_ops;
|
||||||
ds->untag_bridge_pvid = true;
|
ds->untag_bridge_pvid = true;
|
||||||
dev->vlan_enabled = true;
|
dev->vlan_enabled = true;
|
||||||
|
/* Let DSA handle the case were multiple bridges span the same switch
|
||||||
|
* device and different VLAN awareness settings are requested, which
|
||||||
|
* would be breaking filtering semantics for any of the other bridge
|
||||||
|
* devices. (not hardware supported)
|
||||||
|
*/
|
||||||
|
ds->vlan_filtering_is_global = true;
|
||||||
|
|
||||||
mutex_init(&dev->reg_mutex);
|
mutex_init(&dev->reg_mutex);
|
||||||
mutex_init(&dev->stats_mutex);
|
mutex_init(&dev->stats_mutex);
|
||||||
|
|
||||||
|
|
|
@ -114,7 +114,10 @@ static void bcm_sf2_imp_setup(struct dsa_switch *ds, int port)
|
||||||
/* Force link status for IMP port */
|
/* Force link status for IMP port */
|
||||||
reg = core_readl(priv, offset);
|
reg = core_readl(priv, offset);
|
||||||
reg |= (MII_SW_OR | LINK_STS);
|
reg |= (MII_SW_OR | LINK_STS);
|
||||||
reg &= ~GMII_SPEED_UP_2G;
|
if (priv->type == BCM4908_DEVICE_ID)
|
||||||
|
reg |= GMII_SPEED_UP_2G;
|
||||||
|
else
|
||||||
|
reg &= ~GMII_SPEED_UP_2G;
|
||||||
core_writel(priv, reg, offset);
|
core_writel(priv, reg, offset);
|
||||||
|
|
||||||
/* Enable Broadcast, Multicast, Unicast forwarding to IMP port */
|
/* Enable Broadcast, Multicast, Unicast forwarding to IMP port */
|
||||||
|
@ -585,8 +588,10 @@ static u32 bcm_sf2_sw_get_phy_flags(struct dsa_switch *ds, int port)
|
||||||
* in bits 15:8 and the patch level in bits 7:0 which is exactly what
|
* in bits 15:8 and the patch level in bits 7:0 which is exactly what
|
||||||
* the REG_PHY_REVISION register layout is.
|
* the REG_PHY_REVISION register layout is.
|
||||||
*/
|
*/
|
||||||
|
if (priv->int_phy_mask & BIT(port))
|
||||||
return priv->hw_params.gphy_rev;
|
return priv->hw_params.gphy_rev;
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bcm_sf2_sw_validate(struct dsa_switch *ds, int port,
|
static void bcm_sf2_sw_validate(struct dsa_switch *ds, int port,
|
||||||
|
|
|
@ -436,34 +436,32 @@ mt7530_pad_clk_setup(struct dsa_switch *ds, phy_interface_t interface)
|
||||||
TD_DM_DRVP(8) | TD_DM_DRVN(8));
|
TD_DM_DRVP(8) | TD_DM_DRVN(8));
|
||||||
|
|
||||||
/* Setup core clock for MT7530 */
|
/* Setup core clock for MT7530 */
|
||||||
if (!trgint) {
|
/* Disable MT7530 core clock */
|
||||||
/* Disable MT7530 core clock */
|
core_clear(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
||||||
core_clear(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
|
||||||
|
|
||||||
/* Disable PLL, since phy_device has not yet been created
|
/* Disable PLL, since phy_device has not yet been created
|
||||||
* provided for phy_[read,write]_mmd_indirect is called, we
|
* provided for phy_[read,write]_mmd_indirect is called, we
|
||||||
* provide our own core_write_mmd_indirect to complete this
|
* provide our own core_write_mmd_indirect to complete this
|
||||||
* function.
|
* function.
|
||||||
*/
|
*/
|
||||||
core_write_mmd_indirect(priv,
|
core_write_mmd_indirect(priv,
|
||||||
CORE_GSWPLL_GRP1,
|
CORE_GSWPLL_GRP1,
|
||||||
MDIO_MMD_VEND2,
|
MDIO_MMD_VEND2,
|
||||||
0);
|
0);
|
||||||
|
|
||||||
/* Set core clock into 500Mhz */
|
/* Set core clock into 500Mhz */
|
||||||
core_write(priv, CORE_GSWPLL_GRP2,
|
core_write(priv, CORE_GSWPLL_GRP2,
|
||||||
RG_GSWPLL_POSDIV_500M(1) |
|
RG_GSWPLL_POSDIV_500M(1) |
|
||||||
RG_GSWPLL_FBKDIV_500M(25));
|
RG_GSWPLL_FBKDIV_500M(25));
|
||||||
|
|
||||||
/* Enable PLL */
|
/* Enable PLL */
|
||||||
core_write(priv, CORE_GSWPLL_GRP1,
|
core_write(priv, CORE_GSWPLL_GRP1,
|
||||||
RG_GSWPLL_EN_PRE |
|
RG_GSWPLL_EN_PRE |
|
||||||
RG_GSWPLL_POSDIV_200M(2) |
|
RG_GSWPLL_POSDIV_200M(2) |
|
||||||
RG_GSWPLL_FBKDIV_200M(32));
|
RG_GSWPLL_FBKDIV_200M(32));
|
||||||
|
|
||||||
/* Enable MT7530 core clock */
|
/* Enable MT7530 core clock */
|
||||||
core_set(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
core_set(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
||||||
}
|
|
||||||
|
|
||||||
/* Setup the MT7530 TRGMII Tx Clock */
|
/* Setup the MT7530 TRGMII Tx Clock */
|
||||||
core_set(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
core_set(priv, CORE_TRGMII_GSW_CLK_CG, REG_GSWCK_EN);
|
||||||
|
|
|
@ -54,7 +54,7 @@ config B44_PCI
|
||||||
config BCM4908_ENET
|
config BCM4908_ENET
|
||||||
tristate "Broadcom BCM4908 internal mac support"
|
tristate "Broadcom BCM4908 internal mac support"
|
||||||
depends on ARCH_BCM4908 || COMPILE_TEST
|
depends on ARCH_BCM4908 || COMPILE_TEST
|
||||||
default y
|
default y if ARCH_BCM4908
|
||||||
help
|
help
|
||||||
This driver supports Ethernet controller integrated into Broadcom
|
This driver supports Ethernet controller integrated into Broadcom
|
||||||
BCM4908 family SoCs.
|
BCM4908 family SoCs.
|
||||||
|
|
|
@ -722,7 +722,7 @@ static int chcr_ktls_cpl_set_tcb_rpl(struct adapter *adap, unsigned char *input)
|
||||||
kvfree(tx_info);
|
kvfree(tx_info);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
tx_info->open_state = false;
|
tx_info->open_state = CH_KTLS_OPEN_SUCCESS;
|
||||||
spin_unlock(&tx_info->lock);
|
spin_unlock(&tx_info->lock);
|
||||||
|
|
||||||
complete(&tx_info->completion);
|
complete(&tx_info->completion);
|
||||||
|
|
|
@ -1337,6 +1337,7 @@ static int ftgmac100_poll(struct napi_struct *napi, int budget)
|
||||||
*/
|
*/
|
||||||
if (unlikely(priv->need_mac_restart)) {
|
if (unlikely(priv->need_mac_restart)) {
|
||||||
ftgmac100_start_hw(priv);
|
ftgmac100_start_hw(priv);
|
||||||
|
priv->need_mac_restart = false;
|
||||||
|
|
||||||
/* Re-enable "bad" interrupts */
|
/* Re-enable "bad" interrupts */
|
||||||
iowrite32(FTGMAC100_INT_BAD,
|
iowrite32(FTGMAC100_INT_BAD,
|
||||||
|
|
|
@ -899,6 +899,8 @@ static s32 e1000_set_d0_lplu_state_82571(struct e1000_hw *hw, bool active)
|
||||||
} else {
|
} else {
|
||||||
data &= ~IGP02E1000_PM_D0_LPLU;
|
data &= ~IGP02E1000_PM_D0_LPLU;
|
||||||
ret_val = e1e_wphy(hw, IGP02E1000_PHY_POWER_MGMT, data);
|
ret_val = e1e_wphy(hw, IGP02E1000_PHY_POWER_MGMT, data);
|
||||||
|
if (ret_val)
|
||||||
|
return ret_val;
|
||||||
/* LPLU and SmartSpeed are mutually exclusive. LPLU is used
|
/* LPLU and SmartSpeed are mutually exclusive. LPLU is used
|
||||||
* during Dx states where the power conservation is most
|
* during Dx states where the power conservation is most
|
||||||
* important. During driver activity we should enable
|
* important. During driver activity we should enable
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* SPDX-License-Identifier: GPL-2.0 */
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
/* Copyright(c) 1999 - 2018 Intel Corporation. */
|
/* Copyright(c) 1999 - 2018 Intel Corporation. */
|
||||||
|
|
||||||
#ifndef _E1000_HW_H_
|
#ifndef _E1000E_HW_H_
|
||||||
#define _E1000_HW_H_
|
#define _E1000E_HW_H_
|
||||||
|
|
||||||
#include "regs.h"
|
#include "regs.h"
|
||||||
#include "defines.h"
|
#include "defines.h"
|
||||||
|
@ -714,4 +714,4 @@ struct e1000_hw {
|
||||||
#include "80003es2lan.h"
|
#include "80003es2lan.h"
|
||||||
#include "ich8lan.h"
|
#include "ich8lan.h"
|
||||||
|
|
||||||
#endif
|
#endif /* _E1000E_HW_H_ */
|
||||||
|
|
|
@ -5974,15 +5974,19 @@ static void e1000_reset_task(struct work_struct *work)
|
||||||
struct e1000_adapter *adapter;
|
struct e1000_adapter *adapter;
|
||||||
adapter = container_of(work, struct e1000_adapter, reset_task);
|
adapter = container_of(work, struct e1000_adapter, reset_task);
|
||||||
|
|
||||||
|
rtnl_lock();
|
||||||
/* don't run the task if already down */
|
/* don't run the task if already down */
|
||||||
if (test_bit(__E1000_DOWN, &adapter->state))
|
if (test_bit(__E1000_DOWN, &adapter->state)) {
|
||||||
|
rtnl_unlock();
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (!(adapter->flags & FLAG_RESTART_NOW)) {
|
if (!(adapter->flags & FLAG_RESTART_NOW)) {
|
||||||
e1000e_dump(adapter);
|
e1000e_dump(adapter);
|
||||||
e_err("Reset adapter unexpectedly\n");
|
e_err("Reset adapter unexpectedly\n");
|
||||||
}
|
}
|
||||||
e1000e_reinit_locked(adapter);
|
e1000e_reinit_locked(adapter);
|
||||||
|
rtnl_unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -3258,6 +3258,17 @@ static int i40e_configure_tx_ring(struct i40e_ring *ring)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* i40e_rx_offset - Return expected offset into page to access data
|
||||||
|
* @rx_ring: Ring we are requesting offset of
|
||||||
|
*
|
||||||
|
* Returns the offset value for ring into the data buffer.
|
||||||
|
*/
|
||||||
|
static unsigned int i40e_rx_offset(struct i40e_ring *rx_ring)
|
||||||
|
{
|
||||||
|
return ring_uses_build_skb(rx_ring) ? I40E_SKB_PAD : 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* i40e_configure_rx_ring - Configure a receive ring context
|
* i40e_configure_rx_ring - Configure a receive ring context
|
||||||
* @ring: The Rx ring to configure
|
* @ring: The Rx ring to configure
|
||||||
|
@ -3369,6 +3380,8 @@ static int i40e_configure_rx_ring(struct i40e_ring *ring)
|
||||||
else
|
else
|
||||||
set_ring_build_skb_enabled(ring);
|
set_ring_build_skb_enabled(ring);
|
||||||
|
|
||||||
|
ring->rx_offset = i40e_rx_offset(ring);
|
||||||
|
|
||||||
/* cache tail for quicker writes, and clear the reg before use */
|
/* cache tail for quicker writes, and clear the reg before use */
|
||||||
ring->tail = hw->hw_addr + I40E_QRX_TAIL(pf_q);
|
ring->tail = hw->hw_addr + I40E_QRX_TAIL(pf_q);
|
||||||
writel(0, ring->tail);
|
writel(0, ring->tail);
|
||||||
|
|
|
@ -1569,17 +1569,6 @@ void i40e_free_rx_resources(struct i40e_ring *rx_ring)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* i40e_rx_offset - Return expected offset into page to access data
|
|
||||||
* @rx_ring: Ring we are requesting offset of
|
|
||||||
*
|
|
||||||
* Returns the offset value for ring into the data buffer.
|
|
||||||
*/
|
|
||||||
static unsigned int i40e_rx_offset(struct i40e_ring *rx_ring)
|
|
||||||
{
|
|
||||||
return ring_uses_build_skb(rx_ring) ? I40E_SKB_PAD : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* i40e_setup_rx_descriptors - Allocate Rx descriptors
|
* i40e_setup_rx_descriptors - Allocate Rx descriptors
|
||||||
* @rx_ring: Rx descriptor ring (for a specific queue) to setup
|
* @rx_ring: Rx descriptor ring (for a specific queue) to setup
|
||||||
|
@ -1608,7 +1597,6 @@ int i40e_setup_rx_descriptors(struct i40e_ring *rx_ring)
|
||||||
rx_ring->next_to_alloc = 0;
|
rx_ring->next_to_alloc = 0;
|
||||||
rx_ring->next_to_clean = 0;
|
rx_ring->next_to_clean = 0;
|
||||||
rx_ring->next_to_use = 0;
|
rx_ring->next_to_use = 0;
|
||||||
rx_ring->rx_offset = i40e_rx_offset(rx_ring);
|
|
||||||
|
|
||||||
/* XDP RX-queue info only needed for RX rings exposed to XDP */
|
/* XDP RX-queue info only needed for RX rings exposed to XDP */
|
||||||
if (rx_ring->vsi->type == I40E_VSI_MAIN) {
|
if (rx_ring->vsi->type == I40E_VSI_MAIN) {
|
||||||
|
|
|
@ -274,6 +274,22 @@ ice_setup_tx_ctx(struct ice_ring *ring, struct ice_tlan_ctx *tlan_ctx, u16 pf_q)
|
||||||
tlan_ctx->legacy_int = ICE_TX_LEGACY;
|
tlan_ctx->legacy_int = ICE_TX_LEGACY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ice_rx_offset - Return expected offset into page to access data
|
||||||
|
* @rx_ring: Ring we are requesting offset of
|
||||||
|
*
|
||||||
|
* Returns the offset value for ring into the data buffer.
|
||||||
|
*/
|
||||||
|
static unsigned int ice_rx_offset(struct ice_ring *rx_ring)
|
||||||
|
{
|
||||||
|
if (ice_ring_uses_build_skb(rx_ring))
|
||||||
|
return ICE_SKB_PAD;
|
||||||
|
else if (ice_is_xdp_ena_vsi(rx_ring->vsi))
|
||||||
|
return XDP_PACKET_HEADROOM;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ice_setup_rx_ctx - Configure a receive ring context
|
* ice_setup_rx_ctx - Configure a receive ring context
|
||||||
* @ring: The Rx ring to configure
|
* @ring: The Rx ring to configure
|
||||||
|
@ -413,11 +429,15 @@ int ice_setup_rx_ctx(struct ice_ring *ring)
|
||||||
else
|
else
|
||||||
ice_set_ring_build_skb_ena(ring);
|
ice_set_ring_build_skb_ena(ring);
|
||||||
|
|
||||||
|
ring->rx_offset = ice_rx_offset(ring);
|
||||||
|
|
||||||
/* init queue specific tail register */
|
/* init queue specific tail register */
|
||||||
ring->tail = hw->hw_addr + QRX_TAIL(pf_q);
|
ring->tail = hw->hw_addr + QRX_TAIL(pf_q);
|
||||||
writel(0, ring->tail);
|
writel(0, ring->tail);
|
||||||
|
|
||||||
if (ring->xsk_pool) {
|
if (ring->xsk_pool) {
|
||||||
|
bool ok;
|
||||||
|
|
||||||
if (!xsk_buff_can_alloc(ring->xsk_pool, num_bufs)) {
|
if (!xsk_buff_can_alloc(ring->xsk_pool, num_bufs)) {
|
||||||
dev_warn(dev, "XSK buffer pool does not provide enough addresses to fill %d buffers on Rx ring %d\n",
|
dev_warn(dev, "XSK buffer pool does not provide enough addresses to fill %d buffers on Rx ring %d\n",
|
||||||
num_bufs, ring->q_index);
|
num_bufs, ring->q_index);
|
||||||
|
@ -426,8 +446,8 @@ int ice_setup_rx_ctx(struct ice_ring *ring)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ice_alloc_rx_bufs_zc(ring, num_bufs);
|
ok = ice_alloc_rx_bufs_zc(ring, num_bufs);
|
||||||
if (err)
|
if (!ok)
|
||||||
dev_info(dev, "Failed to allocate some buffers on XSK buffer pool enabled Rx ring %d (pf_q %d)\n",
|
dev_info(dev, "Failed to allocate some buffers on XSK buffer pool enabled Rx ring %d (pf_q %d)\n",
|
||||||
ring->q_index, pf_q);
|
ring->q_index, pf_q);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -443,22 +443,6 @@ void ice_free_rx_ring(struct ice_ring *rx_ring)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* ice_rx_offset - Return expected offset into page to access data
|
|
||||||
* @rx_ring: Ring we are requesting offset of
|
|
||||||
*
|
|
||||||
* Returns the offset value for ring into the data buffer.
|
|
||||||
*/
|
|
||||||
static unsigned int ice_rx_offset(struct ice_ring *rx_ring)
|
|
||||||
{
|
|
||||||
if (ice_ring_uses_build_skb(rx_ring))
|
|
||||||
return ICE_SKB_PAD;
|
|
||||||
else if (ice_is_xdp_ena_vsi(rx_ring->vsi))
|
|
||||||
return XDP_PACKET_HEADROOM;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ice_setup_rx_ring - Allocate the Rx descriptors
|
* ice_setup_rx_ring - Allocate the Rx descriptors
|
||||||
* @rx_ring: the Rx ring to set up
|
* @rx_ring: the Rx ring to set up
|
||||||
|
@ -493,7 +477,6 @@ int ice_setup_rx_ring(struct ice_ring *rx_ring)
|
||||||
|
|
||||||
rx_ring->next_to_use = 0;
|
rx_ring->next_to_use = 0;
|
||||||
rx_ring->next_to_clean = 0;
|
rx_ring->next_to_clean = 0;
|
||||||
rx_ring->rx_offset = ice_rx_offset(rx_ring);
|
|
||||||
|
|
||||||
if (ice_is_xdp_ena_vsi(rx_ring->vsi))
|
if (ice_is_xdp_ena_vsi(rx_ring->vsi))
|
||||||
WRITE_ONCE(rx_ring->xdp_prog, rx_ring->vsi->xdp_prog);
|
WRITE_ONCE(rx_ring->xdp_prog, rx_ring->vsi->xdp_prog);
|
||||||
|
|
|
@ -358,18 +358,18 @@ xsk_pool_if_up:
|
||||||
* This function allocates a number of Rx buffers from the fill ring
|
* This function allocates a number of Rx buffers from the fill ring
|
||||||
* or the internal recycle mechanism and places them on the Rx ring.
|
* or the internal recycle mechanism and places them on the Rx ring.
|
||||||
*
|
*
|
||||||
* Returns false if all allocations were successful, true if any fail.
|
* Returns true if all allocations were successful, false if any fail.
|
||||||
*/
|
*/
|
||||||
bool ice_alloc_rx_bufs_zc(struct ice_ring *rx_ring, u16 count)
|
bool ice_alloc_rx_bufs_zc(struct ice_ring *rx_ring, u16 count)
|
||||||
{
|
{
|
||||||
union ice_32b_rx_flex_desc *rx_desc;
|
union ice_32b_rx_flex_desc *rx_desc;
|
||||||
u16 ntu = rx_ring->next_to_use;
|
u16 ntu = rx_ring->next_to_use;
|
||||||
struct ice_rx_buf *rx_buf;
|
struct ice_rx_buf *rx_buf;
|
||||||
bool ret = false;
|
bool ok = true;
|
||||||
dma_addr_t dma;
|
dma_addr_t dma;
|
||||||
|
|
||||||
if (!count)
|
if (!count)
|
||||||
return false;
|
return true;
|
||||||
|
|
||||||
rx_desc = ICE_RX_DESC(rx_ring, ntu);
|
rx_desc = ICE_RX_DESC(rx_ring, ntu);
|
||||||
rx_buf = &rx_ring->rx_buf[ntu];
|
rx_buf = &rx_ring->rx_buf[ntu];
|
||||||
|
@ -377,7 +377,7 @@ bool ice_alloc_rx_bufs_zc(struct ice_ring *rx_ring, u16 count)
|
||||||
do {
|
do {
|
||||||
rx_buf->xdp = xsk_buff_alloc(rx_ring->xsk_pool);
|
rx_buf->xdp = xsk_buff_alloc(rx_ring->xsk_pool);
|
||||||
if (!rx_buf->xdp) {
|
if (!rx_buf->xdp) {
|
||||||
ret = true;
|
ok = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -402,7 +402,7 @@ bool ice_alloc_rx_bufs_zc(struct ice_ring *rx_ring, u16 count)
|
||||||
ice_release_rx_desc(rx_ring, ntu);
|
ice_release_rx_desc(rx_ring, ntu);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* SPDX-License-Identifier: GPL-2.0 */
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
/* Copyright(c) 2007 - 2018 Intel Corporation. */
|
/* Copyright(c) 2007 - 2018 Intel Corporation. */
|
||||||
|
|
||||||
#ifndef _E1000_HW_H_
|
#ifndef _E1000_IGB_HW_H_
|
||||||
#define _E1000_HW_H_
|
#define _E1000_IGB_HW_H_
|
||||||
|
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
@ -551,4 +551,4 @@ s32 igb_write_pcie_cap_reg(struct e1000_hw *hw, u32 reg, u16 *value);
|
||||||
|
|
||||||
void igb_read_pci_cfg(struct e1000_hw *hw, u32 reg, u16 *value);
|
void igb_read_pci_cfg(struct e1000_hw *hw, u32 reg, u16 *value);
|
||||||
void igb_write_pci_cfg(struct e1000_hw *hw, u32 reg, u16 *value);
|
void igb_write_pci_cfg(struct e1000_hw *hw, u32 reg, u16 *value);
|
||||||
#endif /* _E1000_HW_H_ */
|
#endif /* _E1000_IGB_HW_H_ */
|
||||||
|
|
|
@ -748,8 +748,8 @@ void igb_ptp_suspend(struct igb_adapter *adapter);
|
||||||
void igb_ptp_rx_hang(struct igb_adapter *adapter);
|
void igb_ptp_rx_hang(struct igb_adapter *adapter);
|
||||||
void igb_ptp_tx_hang(struct igb_adapter *adapter);
|
void igb_ptp_tx_hang(struct igb_adapter *adapter);
|
||||||
void igb_ptp_rx_rgtstamp(struct igb_q_vector *q_vector, struct sk_buff *skb);
|
void igb_ptp_rx_rgtstamp(struct igb_q_vector *q_vector, struct sk_buff *skb);
|
||||||
void igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
int igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
||||||
struct sk_buff *skb);
|
struct sk_buff *skb);
|
||||||
int igb_ptp_set_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
int igb_ptp_set_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
||||||
int igb_ptp_get_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
int igb_ptp_get_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
||||||
void igb_set_flag_queue_pairs(struct igb_adapter *, const u32);
|
void igb_set_flag_queue_pairs(struct igb_adapter *, const u32);
|
||||||
|
|
|
@ -8214,7 +8214,8 @@ static void igb_reuse_rx_page(struct igb_ring *rx_ring,
|
||||||
new_buff->pagecnt_bias = old_buff->pagecnt_bias;
|
new_buff->pagecnt_bias = old_buff->pagecnt_bias;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool igb_can_reuse_rx_page(struct igb_rx_buffer *rx_buffer)
|
static bool igb_can_reuse_rx_page(struct igb_rx_buffer *rx_buffer,
|
||||||
|
int rx_buf_pgcnt)
|
||||||
{
|
{
|
||||||
unsigned int pagecnt_bias = rx_buffer->pagecnt_bias;
|
unsigned int pagecnt_bias = rx_buffer->pagecnt_bias;
|
||||||
struct page *page = rx_buffer->page;
|
struct page *page = rx_buffer->page;
|
||||||
|
@ -8225,7 +8226,7 @@ static bool igb_can_reuse_rx_page(struct igb_rx_buffer *rx_buffer)
|
||||||
|
|
||||||
#if (PAGE_SIZE < 8192)
|
#if (PAGE_SIZE < 8192)
|
||||||
/* if we are only owner of page we can reuse it */
|
/* if we are only owner of page we can reuse it */
|
||||||
if (unlikely((page_ref_count(page) - pagecnt_bias) > 1))
|
if (unlikely((rx_buf_pgcnt - pagecnt_bias) > 1))
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
#define IGB_LAST_OFFSET \
|
#define IGB_LAST_OFFSET \
|
||||||
|
@ -8301,9 +8302,10 @@ static struct sk_buff *igb_construct_skb(struct igb_ring *rx_ring,
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
if (unlikely(igb_test_staterr(rx_desc, E1000_RXDADV_STAT_TSIP))) {
|
if (unlikely(igb_test_staterr(rx_desc, E1000_RXDADV_STAT_TSIP))) {
|
||||||
igb_ptp_rx_pktstamp(rx_ring->q_vector, xdp->data, skb);
|
if (!igb_ptp_rx_pktstamp(rx_ring->q_vector, xdp->data, skb)) {
|
||||||
xdp->data += IGB_TS_HDR_LEN;
|
xdp->data += IGB_TS_HDR_LEN;
|
||||||
size -= IGB_TS_HDR_LEN;
|
size -= IGB_TS_HDR_LEN;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Determine available headroom for copy */
|
/* Determine available headroom for copy */
|
||||||
|
@ -8364,8 +8366,8 @@ static struct sk_buff *igb_build_skb(struct igb_ring *rx_ring,
|
||||||
|
|
||||||
/* pull timestamp out of packet data */
|
/* pull timestamp out of packet data */
|
||||||
if (igb_test_staterr(rx_desc, E1000_RXDADV_STAT_TSIP)) {
|
if (igb_test_staterr(rx_desc, E1000_RXDADV_STAT_TSIP)) {
|
||||||
igb_ptp_rx_pktstamp(rx_ring->q_vector, skb->data, skb);
|
if (!igb_ptp_rx_pktstamp(rx_ring->q_vector, skb->data, skb))
|
||||||
__skb_pull(skb, IGB_TS_HDR_LEN);
|
__skb_pull(skb, IGB_TS_HDR_LEN);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* update buffer offset */
|
/* update buffer offset */
|
||||||
|
@ -8614,11 +8616,17 @@ static unsigned int igb_rx_offset(struct igb_ring *rx_ring)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct igb_rx_buffer *igb_get_rx_buffer(struct igb_ring *rx_ring,
|
static struct igb_rx_buffer *igb_get_rx_buffer(struct igb_ring *rx_ring,
|
||||||
const unsigned int size)
|
const unsigned int size, int *rx_buf_pgcnt)
|
||||||
{
|
{
|
||||||
struct igb_rx_buffer *rx_buffer;
|
struct igb_rx_buffer *rx_buffer;
|
||||||
|
|
||||||
rx_buffer = &rx_ring->rx_buffer_info[rx_ring->next_to_clean];
|
rx_buffer = &rx_ring->rx_buffer_info[rx_ring->next_to_clean];
|
||||||
|
*rx_buf_pgcnt =
|
||||||
|
#if (PAGE_SIZE < 8192)
|
||||||
|
page_count(rx_buffer->page);
|
||||||
|
#else
|
||||||
|
0;
|
||||||
|
#endif
|
||||||
prefetchw(rx_buffer->page);
|
prefetchw(rx_buffer->page);
|
||||||
|
|
||||||
/* we are reusing so sync this buffer for CPU use */
|
/* we are reusing so sync this buffer for CPU use */
|
||||||
|
@ -8634,9 +8642,9 @@ static struct igb_rx_buffer *igb_get_rx_buffer(struct igb_ring *rx_ring,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void igb_put_rx_buffer(struct igb_ring *rx_ring,
|
static void igb_put_rx_buffer(struct igb_ring *rx_ring,
|
||||||
struct igb_rx_buffer *rx_buffer)
|
struct igb_rx_buffer *rx_buffer, int rx_buf_pgcnt)
|
||||||
{
|
{
|
||||||
if (igb_can_reuse_rx_page(rx_buffer)) {
|
if (igb_can_reuse_rx_page(rx_buffer, rx_buf_pgcnt)) {
|
||||||
/* hand second half of page back to the ring */
|
/* hand second half of page back to the ring */
|
||||||
igb_reuse_rx_page(rx_ring, rx_buffer);
|
igb_reuse_rx_page(rx_ring, rx_buffer);
|
||||||
} else {
|
} else {
|
||||||
|
@ -8664,6 +8672,7 @@ static int igb_clean_rx_irq(struct igb_q_vector *q_vector, const int budget)
|
||||||
unsigned int xdp_xmit = 0;
|
unsigned int xdp_xmit = 0;
|
||||||
struct xdp_buff xdp;
|
struct xdp_buff xdp;
|
||||||
u32 frame_sz = 0;
|
u32 frame_sz = 0;
|
||||||
|
int rx_buf_pgcnt;
|
||||||
|
|
||||||
/* Frame size depend on rx_ring setup when PAGE_SIZE=4K */
|
/* Frame size depend on rx_ring setup when PAGE_SIZE=4K */
|
||||||
#if (PAGE_SIZE < 8192)
|
#if (PAGE_SIZE < 8192)
|
||||||
|
@ -8693,7 +8702,7 @@ static int igb_clean_rx_irq(struct igb_q_vector *q_vector, const int budget)
|
||||||
*/
|
*/
|
||||||
dma_rmb();
|
dma_rmb();
|
||||||
|
|
||||||
rx_buffer = igb_get_rx_buffer(rx_ring, size);
|
rx_buffer = igb_get_rx_buffer(rx_ring, size, &rx_buf_pgcnt);
|
||||||
|
|
||||||
/* retrieve a buffer from the ring */
|
/* retrieve a buffer from the ring */
|
||||||
if (!skb) {
|
if (!skb) {
|
||||||
|
@ -8736,7 +8745,7 @@ static int igb_clean_rx_irq(struct igb_q_vector *q_vector, const int budget)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
igb_put_rx_buffer(rx_ring, rx_buffer);
|
igb_put_rx_buffer(rx_ring, rx_buffer, rx_buf_pgcnt);
|
||||||
cleaned_count++;
|
cleaned_count++;
|
||||||
|
|
||||||
/* fetch next buffer in frame if non-eop */
|
/* fetch next buffer in frame if non-eop */
|
||||||
|
|
|
@ -856,6 +856,9 @@ static void igb_ptp_tx_hwtstamp(struct igb_adapter *adapter)
|
||||||
dev_kfree_skb_any(skb);
|
dev_kfree_skb_any(skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define IGB_RET_PTP_DISABLED 1
|
||||||
|
#define IGB_RET_PTP_INVALID 2
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* igb_ptp_rx_pktstamp - retrieve Rx per packet timestamp
|
* igb_ptp_rx_pktstamp - retrieve Rx per packet timestamp
|
||||||
* @q_vector: Pointer to interrupt specific structure
|
* @q_vector: Pointer to interrupt specific structure
|
||||||
|
@ -864,19 +867,29 @@ static void igb_ptp_tx_hwtstamp(struct igb_adapter *adapter)
|
||||||
*
|
*
|
||||||
* This function is meant to retrieve a timestamp from the first buffer of an
|
* This function is meant to retrieve a timestamp from the first buffer of an
|
||||||
* incoming frame. The value is stored in little endian format starting on
|
* incoming frame. The value is stored in little endian format starting on
|
||||||
* byte 8.
|
* byte 8
|
||||||
|
*
|
||||||
|
* Returns: 0 if success, nonzero if failure
|
||||||
**/
|
**/
|
||||||
void igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
int igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
||||||
struct sk_buff *skb)
|
struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
__le64 *regval = (__le64 *)va;
|
|
||||||
struct igb_adapter *adapter = q_vector->adapter;
|
struct igb_adapter *adapter = q_vector->adapter;
|
||||||
|
__le64 *regval = (__le64 *)va;
|
||||||
int adjust = 0;
|
int adjust = 0;
|
||||||
|
|
||||||
|
if (!(adapter->ptp_flags & IGB_PTP_ENABLED))
|
||||||
|
return IGB_RET_PTP_DISABLED;
|
||||||
|
|
||||||
/* The timestamp is recorded in little endian format.
|
/* The timestamp is recorded in little endian format.
|
||||||
* DWORD: 0 1 2 3
|
* DWORD: 0 1 2 3
|
||||||
* Field: Reserved Reserved SYSTIML SYSTIMH
|
* Field: Reserved Reserved SYSTIML SYSTIMH
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* check reserved dwords are zero, be/le doesn't matter for zero */
|
||||||
|
if (regval[0])
|
||||||
|
return IGB_RET_PTP_INVALID;
|
||||||
|
|
||||||
igb_ptp_systim_to_hwtstamp(adapter, skb_hwtstamps(skb),
|
igb_ptp_systim_to_hwtstamp(adapter, skb_hwtstamps(skb),
|
||||||
le64_to_cpu(regval[1]));
|
le64_to_cpu(regval[1]));
|
||||||
|
|
||||||
|
@ -896,6 +909,8 @@ void igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
||||||
}
|
}
|
||||||
skb_hwtstamps(skb)->hwtstamp =
|
skb_hwtstamps(skb)->hwtstamp =
|
||||||
ktime_sub_ns(skb_hwtstamps(skb)->hwtstamp, adjust);
|
ktime_sub_ns(skb_hwtstamps(skb)->hwtstamp, adjust);
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -906,13 +921,15 @@ void igb_ptp_rx_pktstamp(struct igb_q_vector *q_vector, void *va,
|
||||||
* This function is meant to retrieve a timestamp from the internal registers
|
* This function is meant to retrieve a timestamp from the internal registers
|
||||||
* of the adapter and store it in the skb.
|
* of the adapter and store it in the skb.
|
||||||
**/
|
**/
|
||||||
void igb_ptp_rx_rgtstamp(struct igb_q_vector *q_vector,
|
void igb_ptp_rx_rgtstamp(struct igb_q_vector *q_vector, struct sk_buff *skb)
|
||||||
struct sk_buff *skb)
|
|
||||||
{
|
{
|
||||||
struct igb_adapter *adapter = q_vector->adapter;
|
struct igb_adapter *adapter = q_vector->adapter;
|
||||||
struct e1000_hw *hw = &adapter->hw;
|
struct e1000_hw *hw = &adapter->hw;
|
||||||
u64 regval;
|
|
||||||
int adjust = 0;
|
int adjust = 0;
|
||||||
|
u64 regval;
|
||||||
|
|
||||||
|
if (!(adapter->ptp_flags & IGB_PTP_ENABLED))
|
||||||
|
return;
|
||||||
|
|
||||||
/* If this bit is set, then the RX registers contain the time stamp. No
|
/* If this bit is set, then the RX registers contain the time stamp. No
|
||||||
* other packet will be time stamped until we read these registers, so
|
* other packet will be time stamped until we read these registers, so
|
||||||
|
|
|
@ -547,7 +547,7 @@ void igc_ptp_init(struct igc_adapter *adapter);
|
||||||
void igc_ptp_reset(struct igc_adapter *adapter);
|
void igc_ptp_reset(struct igc_adapter *adapter);
|
||||||
void igc_ptp_suspend(struct igc_adapter *adapter);
|
void igc_ptp_suspend(struct igc_adapter *adapter);
|
||||||
void igc_ptp_stop(struct igc_adapter *adapter);
|
void igc_ptp_stop(struct igc_adapter *adapter);
|
||||||
void igc_ptp_rx_pktstamp(struct igc_q_vector *q_vector, void *va,
|
void igc_ptp_rx_pktstamp(struct igc_q_vector *q_vector, __le32 *va,
|
||||||
struct sk_buff *skb);
|
struct sk_buff *skb);
|
||||||
int igc_ptp_set_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
int igc_ptp_set_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
||||||
int igc_ptp_get_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
int igc_ptp_get_ts_config(struct net_device *netdev, struct ifreq *ifr);
|
||||||
|
|
|
@ -1711,6 +1711,9 @@ static int igc_ethtool_get_link_ksettings(struct net_device *netdev,
|
||||||
Autoneg);
|
Autoneg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Set pause flow control settings */
|
||||||
|
ethtool_link_ksettings_add_link_mode(cmd, supported, Pause);
|
||||||
|
|
||||||
switch (hw->fc.requested_mode) {
|
switch (hw->fc.requested_mode) {
|
||||||
case igc_fc_full:
|
case igc_fc_full:
|
||||||
ethtool_link_ksettings_add_link_mode(cmd, advertising, Pause);
|
ethtool_link_ksettings_add_link_mode(cmd, advertising, Pause);
|
||||||
|
@ -1725,9 +1728,7 @@ static int igc_ethtool_get_link_ksettings(struct net_device *netdev,
|
||||||
Asym_Pause);
|
Asym_Pause);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ethtool_link_ksettings_add_link_mode(cmd, advertising, Pause);
|
break;
|
||||||
ethtool_link_ksettings_add_link_mode(cmd, advertising,
|
|
||||||
Asym_Pause);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
status = pm_runtime_suspended(&adapter->pdev->dev) ?
|
status = pm_runtime_suspended(&adapter->pdev->dev) ?
|
||||||
|
|
|
@ -3831,10 +3831,19 @@ static void igc_reset_task(struct work_struct *work)
|
||||||
|
|
||||||
adapter = container_of(work, struct igc_adapter, reset_task);
|
adapter = container_of(work, struct igc_adapter, reset_task);
|
||||||
|
|
||||||
|
rtnl_lock();
|
||||||
|
/* If we're already down or resetting, just bail */
|
||||||
|
if (test_bit(__IGC_DOWN, &adapter->state) ||
|
||||||
|
test_bit(__IGC_RESETTING, &adapter->state)) {
|
||||||
|
rtnl_unlock();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
igc_rings_dump(adapter);
|
igc_rings_dump(adapter);
|
||||||
igc_regs_dump(adapter);
|
igc_regs_dump(adapter);
|
||||||
netdev_err(adapter->netdev, "Reset adapter\n");
|
netdev_err(adapter->netdev, "Reset adapter\n");
|
||||||
igc_reinit_locked(adapter);
|
igc_reinit_locked(adapter);
|
||||||
|
rtnl_unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -152,46 +152,54 @@ static void igc_ptp_systim_to_hwtstamp(struct igc_adapter *adapter,
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* igc_ptp_rx_pktstamp - retrieve Rx per packet timestamp
|
* igc_ptp_rx_pktstamp - Retrieve timestamp from Rx packet buffer
|
||||||
* @q_vector: Pointer to interrupt specific structure
|
* @q_vector: Pointer to interrupt specific structure
|
||||||
* @va: Pointer to address containing Rx buffer
|
* @va: Pointer to address containing Rx buffer
|
||||||
* @skb: Buffer containing timestamp and packet
|
* @skb: Buffer containing timestamp and packet
|
||||||
*
|
*
|
||||||
* This function is meant to retrieve the first timestamp from the
|
* This function retrieves the timestamp saved in the beginning of packet
|
||||||
* first buffer of an incoming frame. The value is stored in little
|
* buffer. While two timestamps are available, one in timer0 reference and the
|
||||||
* endian format starting on byte 0. There's a second timestamp
|
* other in timer1 reference, this function considers only the timestamp in
|
||||||
* starting on byte 8.
|
* timer0 reference.
|
||||||
**/
|
*/
|
||||||
void igc_ptp_rx_pktstamp(struct igc_q_vector *q_vector, void *va,
|
void igc_ptp_rx_pktstamp(struct igc_q_vector *q_vector, __le32 *va,
|
||||||
struct sk_buff *skb)
|
struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct igc_adapter *adapter = q_vector->adapter;
|
struct igc_adapter *adapter = q_vector->adapter;
|
||||||
__le64 *regval = (__le64 *)va;
|
u64 regval;
|
||||||
int adjust = 0;
|
int adjust;
|
||||||
|
|
||||||
/* The timestamp is recorded in little endian format.
|
/* Timestamps are saved in little endian at the beginning of the packet
|
||||||
* DWORD: | 0 | 1 | 2 | 3
|
* buffer following the layout:
|
||||||
* Field: | Timer0 Low | Timer0 High | Timer1 Low | Timer1 High
|
*
|
||||||
|
* DWORD: | 0 | 1 | 2 | 3 |
|
||||||
|
* Field: | Timer1 SYSTIML | Timer1 SYSTIMH | Timer0 SYSTIML | Timer0 SYSTIMH |
|
||||||
|
*
|
||||||
|
* SYSTIML holds the nanoseconds part while SYSTIMH holds the seconds
|
||||||
|
* part of the timestamp.
|
||||||
*/
|
*/
|
||||||
igc_ptp_systim_to_hwtstamp(adapter, skb_hwtstamps(skb),
|
regval = le32_to_cpu(va[2]);
|
||||||
le64_to_cpu(regval[0]));
|
regval |= (u64)le32_to_cpu(va[3]) << 32;
|
||||||
|
igc_ptp_systim_to_hwtstamp(adapter, skb_hwtstamps(skb), regval);
|
||||||
|
|
||||||
/* adjust timestamp for the RX latency based on link speed */
|
/* Adjust timestamp for the RX latency based on link speed */
|
||||||
if (adapter->hw.mac.type == igc_i225) {
|
switch (adapter->link_speed) {
|
||||||
switch (adapter->link_speed) {
|
case SPEED_10:
|
||||||
case SPEED_10:
|
adjust = IGC_I225_RX_LATENCY_10;
|
||||||
adjust = IGC_I225_RX_LATENCY_10;
|
break;
|
||||||
break;
|
case SPEED_100:
|
||||||
case SPEED_100:
|
adjust = IGC_I225_RX_LATENCY_100;
|
||||||
adjust = IGC_I225_RX_LATENCY_100;
|
break;
|
||||||
break;
|
case SPEED_1000:
|
||||||
case SPEED_1000:
|
adjust = IGC_I225_RX_LATENCY_1000;
|
||||||
adjust = IGC_I225_RX_LATENCY_1000;
|
break;
|
||||||
break;
|
case SPEED_2500:
|
||||||
case SPEED_2500:
|
adjust = IGC_I225_RX_LATENCY_2500;
|
||||||
adjust = IGC_I225_RX_LATENCY_2500;
|
break;
|
||||||
break;
|
default:
|
||||||
}
|
adjust = 0;
|
||||||
|
netdev_warn_once(adapter->netdev, "Imprecise timestamp\n");
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
skb_hwtstamps(skb)->hwtstamp =
|
skb_hwtstamps(skb)->hwtstamp =
|
||||||
ktime_sub_ns(skb_hwtstamps(skb)->hwtstamp, adjust);
|
ktime_sub_ns(skb_hwtstamps(skb)->hwtstamp, adjust);
|
||||||
|
|
|
@ -4118,6 +4118,8 @@ void ixgbe_configure_rx_ring(struct ixgbe_adapter *adapter,
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ring->rx_offset = ixgbe_rx_offset(ring);
|
||||||
|
|
||||||
if (ring->xsk_pool && hw->mac.type != ixgbe_mac_82599EB) {
|
if (ring->xsk_pool && hw->mac.type != ixgbe_mac_82599EB) {
|
||||||
u32 xsk_buf_len = xsk_pool_get_rx_frame_size(ring->xsk_pool);
|
u32 xsk_buf_len = xsk_pool_get_rx_frame_size(ring->xsk_pool);
|
||||||
|
|
||||||
|
@ -6578,7 +6580,6 @@ int ixgbe_setup_rx_resources(struct ixgbe_adapter *adapter,
|
||||||
|
|
||||||
rx_ring->next_to_clean = 0;
|
rx_ring->next_to_clean = 0;
|
||||||
rx_ring->next_to_use = 0;
|
rx_ring->next_to_use = 0;
|
||||||
rx_ring->rx_offset = ixgbe_rx_offset(rx_ring);
|
|
||||||
|
|
||||||
/* XDP RX-queue info */
|
/* XDP RX-queue info */
|
||||||
if (xdp_rxq_info_reg(&rx_ring->xdp_rxq, adapter->netdev,
|
if (xdp_rxq_info_reg(&rx_ring->xdp_rxq, adapter->netdev,
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
config NET_VENDOR_MARVELL
|
config NET_VENDOR_MARVELL
|
||||||
bool "Marvell devices"
|
bool "Marvell devices"
|
||||||
default y
|
default y
|
||||||
depends on PCI || CPU_PXA168 || MV64X60 || PPC32 || PLAT_ORION || INET || COMPILE_TEST
|
depends on PCI || CPU_PXA168 || PPC32 || PLAT_ORION || INET || COMPILE_TEST
|
||||||
help
|
help
|
||||||
If you have a network (Ethernet) card belonging to this class, say Y.
|
If you have a network (Ethernet) card belonging to this class, say Y.
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ if NET_VENDOR_MARVELL
|
||||||
|
|
||||||
config MV643XX_ETH
|
config MV643XX_ETH
|
||||||
tristate "Marvell Discovery (643XX) and Orion ethernet support"
|
tristate "Marvell Discovery (643XX) and Orion ethernet support"
|
||||||
depends on MV64X60 || PPC32 || PLAT_ORION || COMPILE_TEST
|
depends on PPC32 || PLAT_ORION || COMPILE_TEST
|
||||||
depends on INET
|
depends on INET
|
||||||
select PHYLIB
|
select PHYLIB
|
||||||
select MVMDIO
|
select MVMDIO
|
||||||
|
|
|
@ -2684,7 +2684,7 @@ static const struct of_device_id mv643xx_eth_shared_ids[] = {
|
||||||
MODULE_DEVICE_TABLE(of, mv643xx_eth_shared_ids);
|
MODULE_DEVICE_TABLE(of, mv643xx_eth_shared_ids);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_OF_IRQ) && !defined(CONFIG_MV64X60)
|
#ifdef CONFIG_OF_IRQ
|
||||||
#define mv643xx_eth_property(_np, _name, _v) \
|
#define mv643xx_eth_property(_np, _name, _v) \
|
||||||
do { \
|
do { \
|
||||||
u32 tmp; \
|
u32 tmp; \
|
||||||
|
|
|
@ -13499,8 +13499,6 @@ static struct npc_mcam_kex npc_mkex_default = {
|
||||||
[NPC_LT_LC_IP] = {
|
[NPC_LT_LC_IP] = {
|
||||||
/* SIP+DIP: 8 bytes, KW2[63:0] */
|
/* SIP+DIP: 8 bytes, KW2[63:0] */
|
||||||
KEX_LD_CFG(0x07, 0xc, 0x1, 0x0, 0x10),
|
KEX_LD_CFG(0x07, 0xc, 0x1, 0x0, 0x10),
|
||||||
/* TOS: 1 byte, KW1[63:56] */
|
|
||||||
KEX_LD_CFG(0x0, 0x1, 0x1, 0x0, 0xf),
|
|
||||||
},
|
},
|
||||||
/* Layer C: IPv6 */
|
/* Layer C: IPv6 */
|
||||||
[NPC_LT_LC_IP6] = {
|
[NPC_LT_LC_IP6] = {
|
||||||
|
|
|
@ -2462,8 +2462,10 @@ static void rvu_unregister_interrupts(struct rvu *rvu)
|
||||||
INTR_MASK(rvu->hw->total_pfs) & ~1ULL);
|
INTR_MASK(rvu->hw->total_pfs) & ~1ULL);
|
||||||
|
|
||||||
for (irq = 0; irq < rvu->num_vec; irq++) {
|
for (irq = 0; irq < rvu->num_vec; irq++) {
|
||||||
if (rvu->irq_allocated[irq])
|
if (rvu->irq_allocated[irq]) {
|
||||||
free_irq(pci_irq_vector(rvu->pdev, irq), rvu);
|
free_irq(pci_irq_vector(rvu->pdev, irq), rvu);
|
||||||
|
rvu->irq_allocated[irq] = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pci_free_irq_vectors(rvu->pdev);
|
pci_free_irq_vectors(rvu->pdev);
|
||||||
|
@ -2975,8 +2977,8 @@ static void rvu_remove(struct pci_dev *pdev)
|
||||||
struct rvu *rvu = pci_get_drvdata(pdev);
|
struct rvu *rvu = pci_get_drvdata(pdev);
|
||||||
|
|
||||||
rvu_dbg_exit(rvu);
|
rvu_dbg_exit(rvu);
|
||||||
rvu_unregister_interrupts(rvu);
|
|
||||||
rvu_unregister_dl(rvu);
|
rvu_unregister_dl(rvu);
|
||||||
|
rvu_unregister_interrupts(rvu);
|
||||||
rvu_flr_wq_destroy(rvu);
|
rvu_flr_wq_destroy(rvu);
|
||||||
rvu_cgx_exit(rvu);
|
rvu_cgx_exit(rvu);
|
||||||
rvu_fwdata_exit(rvu);
|
rvu_fwdata_exit(rvu);
|
||||||
|
|
|
@ -678,6 +678,7 @@ void npc_read_mcam_entry(struct rvu *rvu, struct npc_mcam *mcam,
|
||||||
u8 *intf, u8 *ena);
|
u8 *intf, u8 *ena);
|
||||||
bool is_mac_feature_supported(struct rvu *rvu, int pf, int feature);
|
bool is_mac_feature_supported(struct rvu *rvu, int pf, int feature);
|
||||||
u32 rvu_cgx_get_fifolen(struct rvu *rvu);
|
u32 rvu_cgx_get_fifolen(struct rvu *rvu);
|
||||||
|
void *rvu_first_cgx_pdata(struct rvu *rvu);
|
||||||
|
|
||||||
/* CPT APIs */
|
/* CPT APIs */
|
||||||
int rvu_cpt_lf_teardown(struct rvu *rvu, u16 pcifunc, int lf, int slot);
|
int rvu_cpt_lf_teardown(struct rvu *rvu, u16 pcifunc, int lf, int slot);
|
||||||
|
|
|
@ -89,6 +89,21 @@ void *rvu_cgx_pdata(u8 cgx_id, struct rvu *rvu)
|
||||||
return rvu->cgx_idmap[cgx_id];
|
return rvu->cgx_idmap[cgx_id];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return first enabled CGX instance if none are enabled then return NULL */
|
||||||
|
void *rvu_first_cgx_pdata(struct rvu *rvu)
|
||||||
|
{
|
||||||
|
int first_enabled_cgx = 0;
|
||||||
|
void *cgxd = NULL;
|
||||||
|
|
||||||
|
for (; first_enabled_cgx < rvu->cgx_cnt_max; first_enabled_cgx++) {
|
||||||
|
cgxd = rvu_cgx_pdata(first_enabled_cgx, rvu);
|
||||||
|
if (cgxd)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return cgxd;
|
||||||
|
}
|
||||||
|
|
||||||
/* Based on P2X connectivity find mapped NIX block for a PF */
|
/* Based on P2X connectivity find mapped NIX block for a PF */
|
||||||
static void rvu_map_cgx_nix_block(struct rvu *rvu, int pf,
|
static void rvu_map_cgx_nix_block(struct rvu *rvu, int pf,
|
||||||
int cgx_id, int lmac_id)
|
int cgx_id, int lmac_id)
|
||||||
|
@ -711,10 +726,9 @@ int rvu_mbox_handler_cgx_features_get(struct rvu *rvu,
|
||||||
u32 rvu_cgx_get_fifolen(struct rvu *rvu)
|
u32 rvu_cgx_get_fifolen(struct rvu *rvu)
|
||||||
{
|
{
|
||||||
struct mac_ops *mac_ops;
|
struct mac_ops *mac_ops;
|
||||||
int rvu_def_cgx_id = 0;
|
|
||||||
u32 fifo_len;
|
u32 fifo_len;
|
||||||
|
|
||||||
mac_ops = get_mac_ops(rvu_cgx_pdata(rvu_def_cgx_id, rvu));
|
mac_ops = get_mac_ops(rvu_first_cgx_pdata(rvu));
|
||||||
fifo_len = mac_ops ? mac_ops->fifo_len : 0;
|
fifo_len = mac_ops ? mac_ops->fifo_len : 0;
|
||||||
|
|
||||||
return fifo_len;
|
return fifo_len;
|
||||||
|
|
|
@ -234,12 +234,14 @@ static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp,
|
||||||
char __user *buffer,
|
char __user *buffer,
|
||||||
size_t count, loff_t *ppos)
|
size_t count, loff_t *ppos)
|
||||||
{
|
{
|
||||||
int index, off = 0, flag = 0, go_back = 0, off_prev;
|
int index, off = 0, flag = 0, go_back = 0, len = 0;
|
||||||
struct rvu *rvu = filp->private_data;
|
struct rvu *rvu = filp->private_data;
|
||||||
int lf, pf, vf, pcifunc;
|
int lf, pf, vf, pcifunc;
|
||||||
struct rvu_block block;
|
struct rvu_block block;
|
||||||
int bytes_not_copied;
|
int bytes_not_copied;
|
||||||
|
int lf_str_size = 12;
|
||||||
int buf_size = 2048;
|
int buf_size = 2048;
|
||||||
|
char *lfs;
|
||||||
char *buf;
|
char *buf;
|
||||||
|
|
||||||
/* don't allow partial reads */
|
/* don't allow partial reads */
|
||||||
|
@ -249,12 +251,20 @@ static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp,
|
||||||
buf = kzalloc(buf_size, GFP_KERNEL);
|
buf = kzalloc(buf_size, GFP_KERNEL);
|
||||||
if (!buf)
|
if (!buf)
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
off += scnprintf(&buf[off], buf_size - 1 - off, "\npcifunc\t\t");
|
|
||||||
|
lfs = kzalloc(lf_str_size, GFP_KERNEL);
|
||||||
|
if (!lfs) {
|
||||||
|
kfree(buf);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
off += scnprintf(&buf[off], buf_size - 1 - off, "%-*s", lf_str_size,
|
||||||
|
"pcifunc");
|
||||||
for (index = 0; index < BLK_COUNT; index++)
|
for (index = 0; index < BLK_COUNT; index++)
|
||||||
if (strlen(rvu->hw->block[index].name))
|
if (strlen(rvu->hw->block[index].name)) {
|
||||||
off += scnprintf(&buf[off], buf_size - 1 - off,
|
off += scnprintf(&buf[off], buf_size - 1 - off,
|
||||||
"%*s\t", (index - 1) * 2,
|
"%-*s", lf_str_size,
|
||||||
rvu->hw->block[index].name);
|
rvu->hw->block[index].name);
|
||||||
|
}
|
||||||
off += scnprintf(&buf[off], buf_size - 1 - off, "\n");
|
off += scnprintf(&buf[off], buf_size - 1 - off, "\n");
|
||||||
for (pf = 0; pf < rvu->hw->total_pfs; pf++) {
|
for (pf = 0; pf < rvu->hw->total_pfs; pf++) {
|
||||||
for (vf = 0; vf <= rvu->hw->total_vfs; vf++) {
|
for (vf = 0; vf <= rvu->hw->total_vfs; vf++) {
|
||||||
|
@ -263,14 +273,15 @@ static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp,
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (vf) {
|
if (vf) {
|
||||||
|
sprintf(lfs, "PF%d:VF%d", pf, vf - 1);
|
||||||
go_back = scnprintf(&buf[off],
|
go_back = scnprintf(&buf[off],
|
||||||
buf_size - 1 - off,
|
buf_size - 1 - off,
|
||||||
"PF%d:VF%d\t\t", pf,
|
"%-*s", lf_str_size, lfs);
|
||||||
vf - 1);
|
|
||||||
} else {
|
} else {
|
||||||
|
sprintf(lfs, "PF%d", pf);
|
||||||
go_back = scnprintf(&buf[off],
|
go_back = scnprintf(&buf[off],
|
||||||
buf_size - 1 - off,
|
buf_size - 1 - off,
|
||||||
"PF%d\t\t", pf);
|
"%-*s", lf_str_size, lfs);
|
||||||
}
|
}
|
||||||
|
|
||||||
off += go_back;
|
off += go_back;
|
||||||
|
@ -278,20 +289,22 @@ static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp,
|
||||||
block = rvu->hw->block[index];
|
block = rvu->hw->block[index];
|
||||||
if (!strlen(block.name))
|
if (!strlen(block.name))
|
||||||
continue;
|
continue;
|
||||||
off_prev = off;
|
len = 0;
|
||||||
|
lfs[len] = '\0';
|
||||||
for (lf = 0; lf < block.lf.max; lf++) {
|
for (lf = 0; lf < block.lf.max; lf++) {
|
||||||
if (block.fn_map[lf] != pcifunc)
|
if (block.fn_map[lf] != pcifunc)
|
||||||
continue;
|
continue;
|
||||||
flag = 1;
|
flag = 1;
|
||||||
off += scnprintf(&buf[off], buf_size - 1
|
len += sprintf(&lfs[len], "%d,", lf);
|
||||||
- off, "%3d,", lf);
|
|
||||||
}
|
}
|
||||||
if (flag && off_prev != off)
|
|
||||||
off--;
|
if (flag)
|
||||||
else
|
len--;
|
||||||
go_back++;
|
lfs[len] = '\0';
|
||||||
off += scnprintf(&buf[off], buf_size - 1 - off,
|
off += scnprintf(&buf[off], buf_size - 1 - off,
|
||||||
"\t");
|
"%-*s", lf_str_size, lfs);
|
||||||
|
if (!strlen(lfs))
|
||||||
|
go_back += lf_str_size;
|
||||||
}
|
}
|
||||||
if (!flag)
|
if (!flag)
|
||||||
off -= go_back;
|
off -= go_back;
|
||||||
|
@ -303,6 +316,7 @@ static ssize_t rvu_dbg_rsrc_attach_status(struct file *filp,
|
||||||
}
|
}
|
||||||
|
|
||||||
bytes_not_copied = copy_to_user(buffer, buf, off);
|
bytes_not_copied = copy_to_user(buffer, buf, off);
|
||||||
|
kfree(lfs);
|
||||||
kfree(buf);
|
kfree(buf);
|
||||||
|
|
||||||
if (bytes_not_copied)
|
if (bytes_not_copied)
|
||||||
|
@ -319,7 +333,6 @@ static int rvu_dbg_rvu_pf_cgx_map_display(struct seq_file *filp, void *unused)
|
||||||
struct rvu *rvu = filp->private;
|
struct rvu *rvu = filp->private;
|
||||||
struct pci_dev *pdev = NULL;
|
struct pci_dev *pdev = NULL;
|
||||||
struct mac_ops *mac_ops;
|
struct mac_ops *mac_ops;
|
||||||
int rvu_def_cgx_id = 0;
|
|
||||||
char cgx[10], lmac[10];
|
char cgx[10], lmac[10];
|
||||||
struct rvu_pfvf *pfvf;
|
struct rvu_pfvf *pfvf;
|
||||||
int pf, domain, blkid;
|
int pf, domain, blkid;
|
||||||
|
@ -327,7 +340,10 @@ static int rvu_dbg_rvu_pf_cgx_map_display(struct seq_file *filp, void *unused)
|
||||||
u16 pcifunc;
|
u16 pcifunc;
|
||||||
|
|
||||||
domain = 2;
|
domain = 2;
|
||||||
mac_ops = get_mac_ops(rvu_cgx_pdata(rvu_def_cgx_id, rvu));
|
mac_ops = get_mac_ops(rvu_first_cgx_pdata(rvu));
|
||||||
|
/* There can be no CGX devices at all */
|
||||||
|
if (!mac_ops)
|
||||||
|
return 0;
|
||||||
seq_printf(filp, "PCI dev\t\tRVU PF Func\tNIX block\t%s\tLMAC\n",
|
seq_printf(filp, "PCI dev\t\tRVU PF Func\tNIX block\t%s\tLMAC\n",
|
||||||
mac_ops->name);
|
mac_ops->name);
|
||||||
for (pf = 0; pf < rvu->hw->total_pfs; pf++) {
|
for (pf = 0; pf < rvu->hw->total_pfs; pf++) {
|
||||||
|
@ -1818,7 +1834,6 @@ static void rvu_dbg_cgx_init(struct rvu *rvu)
|
||||||
{
|
{
|
||||||
struct mac_ops *mac_ops;
|
struct mac_ops *mac_ops;
|
||||||
unsigned long lmac_bmap;
|
unsigned long lmac_bmap;
|
||||||
int rvu_def_cgx_id = 0;
|
|
||||||
int i, lmac_id;
|
int i, lmac_id;
|
||||||
char dname[20];
|
char dname[20];
|
||||||
void *cgx;
|
void *cgx;
|
||||||
|
@ -1826,7 +1841,7 @@ static void rvu_dbg_cgx_init(struct rvu *rvu)
|
||||||
if (!cgx_get_cgxcnt_max())
|
if (!cgx_get_cgxcnt_max())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
mac_ops = get_mac_ops(rvu_cgx_pdata(rvu_def_cgx_id, rvu));
|
mac_ops = get_mac_ops(rvu_first_cgx_pdata(rvu));
|
||||||
if (!mac_ops)
|
if (!mac_ops)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -2629,7 +2629,7 @@ static int set_flowkey_fields(struct nix_rx_flowkey_alg *alg, u32 flow_cfg)
|
||||||
struct nix_rx_flowkey_alg *field;
|
struct nix_rx_flowkey_alg *field;
|
||||||
struct nix_rx_flowkey_alg tmp;
|
struct nix_rx_flowkey_alg tmp;
|
||||||
u32 key_type, valid_key;
|
u32 key_type, valid_key;
|
||||||
int l4_key_offset;
|
int l4_key_offset = 0;
|
||||||
|
|
||||||
if (!alg)
|
if (!alg)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
|
@ -2490,10 +2490,10 @@ int rvu_mbox_handler_npc_mcam_free_counter(struct rvu *rvu,
|
||||||
index = find_next_bit(mcam->bmap, mcam->bmap_entries, entry);
|
index = find_next_bit(mcam->bmap, mcam->bmap_entries, entry);
|
||||||
if (index >= mcam->bmap_entries)
|
if (index >= mcam->bmap_entries)
|
||||||
break;
|
break;
|
||||||
|
entry = index + 1;
|
||||||
if (mcam->entry2cntr_map[index] != req->cntr)
|
if (mcam->entry2cntr_map[index] != req->cntr)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
entry = index + 1;
|
|
||||||
npc_unmap_mcam_entry_and_cntr(rvu, mcam, blkaddr,
|
npc_unmap_mcam_entry_and_cntr(rvu, mcam, blkaddr,
|
||||||
index, req->cntr);
|
index, req->cntr);
|
||||||
}
|
}
|
||||||
|
|
|
@ -257,17 +257,19 @@ int otx2_get_flow(struct otx2_nic *pfvf, struct ethtool_rxnfc *nfc,
|
||||||
int otx2_get_all_flows(struct otx2_nic *pfvf, struct ethtool_rxnfc *nfc,
|
int otx2_get_all_flows(struct otx2_nic *pfvf, struct ethtool_rxnfc *nfc,
|
||||||
u32 *rule_locs)
|
u32 *rule_locs)
|
||||||
{
|
{
|
||||||
|
u32 rule_cnt = nfc->rule_cnt;
|
||||||
u32 location = 0;
|
u32 location = 0;
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
nfc->data = pfvf->flow_cfg->ntuple_max_flows;
|
nfc->data = pfvf->flow_cfg->ntuple_max_flows;
|
||||||
while ((!err || err == -ENOENT) && idx < nfc->rule_cnt) {
|
while ((!err || err == -ENOENT) && idx < rule_cnt) {
|
||||||
err = otx2_get_flow(pfvf, nfc, location);
|
err = otx2_get_flow(pfvf, nfc, location);
|
||||||
if (!err)
|
if (!err)
|
||||||
rule_locs[idx++] = location;
|
rule_locs[idx++] = location;
|
||||||
location++;
|
location++;
|
||||||
}
|
}
|
||||||
|
nfc->rule_cnt = rule_cnt;
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1672,6 +1672,7 @@ int otx2_stop(struct net_device *netdev)
|
||||||
struct otx2_nic *pf = netdev_priv(netdev);
|
struct otx2_nic *pf = netdev_priv(netdev);
|
||||||
struct otx2_cq_poll *cq_poll = NULL;
|
struct otx2_cq_poll *cq_poll = NULL;
|
||||||
struct otx2_qset *qset = &pf->qset;
|
struct otx2_qset *qset = &pf->qset;
|
||||||
|
struct otx2_rss_info *rss;
|
||||||
int qidx, vec, wrk;
|
int qidx, vec, wrk;
|
||||||
|
|
||||||
netif_carrier_off(netdev);
|
netif_carrier_off(netdev);
|
||||||
|
@ -1684,6 +1685,10 @@ int otx2_stop(struct net_device *netdev)
|
||||||
/* First stop packet Rx/Tx */
|
/* First stop packet Rx/Tx */
|
||||||
otx2_rxtx_enable(pf, false);
|
otx2_rxtx_enable(pf, false);
|
||||||
|
|
||||||
|
/* Clear RSS enable flag */
|
||||||
|
rss = &pf->hw.rss_info;
|
||||||
|
rss->enable = false;
|
||||||
|
|
||||||
/* Cleanup Queue IRQ */
|
/* Cleanup Queue IRQ */
|
||||||
vec = pci_irq_vector(pf->pdev,
|
vec = pci_irq_vector(pf->pdev,
|
||||||
pf->hw.nix_msixoff + NIX_LF_QINT_VEC_START);
|
pf->hw.nix_msixoff + NIX_LF_QINT_VEC_START);
|
||||||
|
|
|
@ -1544,8 +1544,8 @@ static int pxa168_eth_remove(struct platform_device *pdev)
|
||||||
clk_disable_unprepare(pep->clk);
|
clk_disable_unprepare(pep->clk);
|
||||||
mdiobus_unregister(pep->smi_bus);
|
mdiobus_unregister(pep->smi_bus);
|
||||||
mdiobus_free(pep->smi_bus);
|
mdiobus_free(pep->smi_bus);
|
||||||
unregister_netdev(dev);
|
|
||||||
cancel_work_sync(&pep->tx_timeout_task);
|
cancel_work_sync(&pep->tx_timeout_task);
|
||||||
|
unregister_netdev(dev);
|
||||||
free_netdev(dev);
|
free_netdev(dev);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -92,14 +92,15 @@ struct page_pool;
|
||||||
MLX5_MPWRQ_LOG_WQE_SZ - PAGE_SHIFT : 0)
|
MLX5_MPWRQ_LOG_WQE_SZ - PAGE_SHIFT : 0)
|
||||||
#define MLX5_MPWRQ_PAGES_PER_WQE BIT(MLX5_MPWRQ_WQE_PAGE_ORDER)
|
#define MLX5_MPWRQ_PAGES_PER_WQE BIT(MLX5_MPWRQ_WQE_PAGE_ORDER)
|
||||||
|
|
||||||
#define MLX5_MTT_OCTW(npages) (ALIGN(npages, 8) / 2)
|
#define MLX5_ALIGN_MTTS(mtts) (ALIGN(mtts, 8))
|
||||||
|
#define MLX5_ALIGNED_MTTS_OCTW(mtts) ((mtts) / 2)
|
||||||
|
#define MLX5_MTT_OCTW(mtts) (MLX5_ALIGNED_MTTS_OCTW(MLX5_ALIGN_MTTS(mtts)))
|
||||||
/* Add another page to MLX5E_REQUIRED_WQE_MTTS as a buffer between
|
/* Add another page to MLX5E_REQUIRED_WQE_MTTS as a buffer between
|
||||||
* WQEs, This page will absorb write overflow by the hardware, when
|
* WQEs, This page will absorb write overflow by the hardware, when
|
||||||
* receiving packets larger than MTU. These oversize packets are
|
* receiving packets larger than MTU. These oversize packets are
|
||||||
* dropped by the driver at a later stage.
|
* dropped by the driver at a later stage.
|
||||||
*/
|
*/
|
||||||
#define MLX5E_REQUIRED_WQE_MTTS (ALIGN(MLX5_MPWRQ_PAGES_PER_WQE + 1, 8))
|
#define MLX5E_REQUIRED_WQE_MTTS (MLX5_ALIGN_MTTS(MLX5_MPWRQ_PAGES_PER_WQE + 1))
|
||||||
#define MLX5E_LOG_ALIGNED_MPWQE_PPW (ilog2(MLX5E_REQUIRED_WQE_MTTS))
|
|
||||||
#define MLX5E_REQUIRED_MTTS(wqes) (wqes * MLX5E_REQUIRED_WQE_MTTS)
|
#define MLX5E_REQUIRED_MTTS(wqes) (wqes * MLX5E_REQUIRED_WQE_MTTS)
|
||||||
#define MLX5E_MAX_RQ_NUM_MTTS \
|
#define MLX5E_MAX_RQ_NUM_MTTS \
|
||||||
((1 << 16) * 2) /* So that MLX5_MTT_OCTW(num_mtts) fits into u16 */
|
((1 << 16) * 2) /* So that MLX5_MTT_OCTW(num_mtts) fits into u16 */
|
||||||
|
|
|
@ -1181,7 +1181,8 @@ int mlx5_tc_ct_add_no_trk_match(struct mlx5_flow_spec *spec)
|
||||||
|
|
||||||
mlx5e_tc_match_to_reg_get_match(spec, CTSTATE_TO_REG,
|
mlx5e_tc_match_to_reg_get_match(spec, CTSTATE_TO_REG,
|
||||||
&ctstate, &ctstate_mask);
|
&ctstate, &ctstate_mask);
|
||||||
if (ctstate_mask)
|
|
||||||
|
if ((ctstate & ctstate_mask) == MLX5_CT_STATE_TRK_BIT)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
ctstate_mask |= MLX5_CT_STATE_TRK_BIT;
|
ctstate_mask |= MLX5_CT_STATE_TRK_BIT;
|
||||||
|
|
|
@ -685,14 +685,14 @@ int mlx5e_tc_tun_route_lookup(struct mlx5e_priv *priv,
|
||||||
u16 vport_num;
|
u16 vport_num;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
if (flow_attr->ip_version == 4) {
|
if (flow_attr->tun_ip_version == 4) {
|
||||||
/* Addresses are swapped for decap */
|
/* Addresses are swapped for decap */
|
||||||
attr.fl.fl4.saddr = esw_attr->rx_tun_attr->dst_ip.v4;
|
attr.fl.fl4.saddr = esw_attr->rx_tun_attr->dst_ip.v4;
|
||||||
attr.fl.fl4.daddr = esw_attr->rx_tun_attr->src_ip.v4;
|
attr.fl.fl4.daddr = esw_attr->rx_tun_attr->src_ip.v4;
|
||||||
err = mlx5e_route_lookup_ipv4_get(priv, priv->netdev, &attr);
|
err = mlx5e_route_lookup_ipv4_get(priv, priv->netdev, &attr);
|
||||||
}
|
}
|
||||||
#if IS_ENABLED(CONFIG_INET) && IS_ENABLED(CONFIG_IPV6)
|
#if IS_ENABLED(CONFIG_INET) && IS_ENABLED(CONFIG_IPV6)
|
||||||
else if (flow_attr->ip_version == 6) {
|
else if (flow_attr->tun_ip_version == 6) {
|
||||||
/* Addresses are swapped for decap */
|
/* Addresses are swapped for decap */
|
||||||
attr.fl.fl6.saddr = esw_attr->rx_tun_attr->dst_ip.v6;
|
attr.fl.fl6.saddr = esw_attr->rx_tun_attr->dst_ip.v6;
|
||||||
attr.fl.fl6.daddr = esw_attr->rx_tun_attr->src_ip.v6;
|
attr.fl.fl6.daddr = esw_attr->rx_tun_attr->src_ip.v6;
|
||||||
|
@ -718,10 +718,10 @@ int mlx5e_tc_tun_route_lookup(struct mlx5e_priv *priv,
|
||||||
esw_attr->rx_tun_attr->decap_vport = vport_num;
|
esw_attr->rx_tun_attr->decap_vport = vport_num;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
if (flow_attr->ip_version == 4)
|
if (flow_attr->tun_ip_version == 4)
|
||||||
mlx5e_route_lookup_ipv4_put(&attr);
|
mlx5e_route_lookup_ipv4_put(&attr);
|
||||||
#if IS_ENABLED(CONFIG_INET) && IS_ENABLED(CONFIG_IPV6)
|
#if IS_ENABLED(CONFIG_INET) && IS_ENABLED(CONFIG_IPV6)
|
||||||
else if (flow_attr->ip_version == 6)
|
else if (flow_attr->tun_ip_version == 6)
|
||||||
mlx5e_route_lookup_ipv6_put(&attr);
|
mlx5e_route_lookup_ipv6_put(&attr);
|
||||||
#endif
|
#endif
|
||||||
return err;
|
return err;
|
||||||
|
|
|
@ -89,6 +89,7 @@ int mlx5e_tc_set_attr_rx_tun(struct mlx5e_tc_flow *flow,
|
||||||
* required to establish routing.
|
* required to establish routing.
|
||||||
*/
|
*/
|
||||||
flow_flag_set(flow, TUN_RX);
|
flow_flag_set(flow, TUN_RX);
|
||||||
|
flow->attr->tun_ip_version = ip_version;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1091,7 +1092,7 @@ int mlx5e_attach_decap_route(struct mlx5e_priv *priv,
|
||||||
if (err || !esw_attr->rx_tun_attr->decap_vport)
|
if (err || !esw_attr->rx_tun_attr->decap_vport)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
key.ip_version = attr->ip_version;
|
key.ip_version = attr->tun_ip_version;
|
||||||
if (key.ip_version == 4)
|
if (key.ip_version == 4)
|
||||||
key.endpoint_ip.v4 = esw_attr->rx_tun_attr->dst_ip.v4;
|
key.endpoint_ip.v4 = esw_attr->rx_tun_attr->dst_ip.v4;
|
||||||
else
|
else
|
||||||
|
|
|
@ -227,6 +227,10 @@ static int mlx5e_tc_tun_parse_geneve_options(struct mlx5e_priv *priv,
|
||||||
option_key = (struct geneve_opt *)&enc_opts.key->data[0];
|
option_key = (struct geneve_opt *)&enc_opts.key->data[0];
|
||||||
option_mask = (struct geneve_opt *)&enc_opts.mask->data[0];
|
option_mask = (struct geneve_opt *)&enc_opts.mask->data[0];
|
||||||
|
|
||||||
|
if (option_mask->opt_class == 0 && option_mask->type == 0 &&
|
||||||
|
!memchr_inv(option_mask->opt_data, 0, option_mask->length * 4))
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (option_key->length > max_tlv_option_data_len) {
|
if (option_key->length > max_tlv_option_data_len) {
|
||||||
NL_SET_ERR_MSG_MOD(extack,
|
NL_SET_ERR_MSG_MOD(extack,
|
||||||
"Matching on GENEVE options: unsupported option len");
|
"Matching on GENEVE options: unsupported option len");
|
||||||
|
|
|
@ -1887,6 +1887,7 @@ static int set_pflag_rx_cqe_compress(struct net_device *netdev,
|
||||||
{
|
{
|
||||||
struct mlx5e_priv *priv = netdev_priv(netdev);
|
struct mlx5e_priv *priv = netdev_priv(netdev);
|
||||||
struct mlx5_core_dev *mdev = priv->mdev;
|
struct mlx5_core_dev *mdev = priv->mdev;
|
||||||
|
int err;
|
||||||
|
|
||||||
if (!MLX5_CAP_GEN(mdev, cqe_compression))
|
if (!MLX5_CAP_GEN(mdev, cqe_compression))
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
@ -1896,7 +1897,10 @@ static int set_pflag_rx_cqe_compress(struct net_device *netdev,
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
mlx5e_modify_rx_cqe_compression_locked(priv, enable);
|
err = mlx5e_modify_rx_cqe_compression_locked(priv, enable);
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
priv->channels.params.rx_cqe_compress_def = enable;
|
priv->channels.params.rx_cqe_compress_def = enable;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2014,8 +2018,13 @@ static int set_pflag_tx_port_ts(struct net_device *netdev, bool enable)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!test_bit(MLX5E_STATE_OPENED, &priv->state)) {
|
if (!test_bit(MLX5E_STATE_OPENED, &priv->state)) {
|
||||||
|
struct mlx5e_params old_params;
|
||||||
|
|
||||||
|
old_params = priv->channels.params;
|
||||||
priv->channels.params = new_channels.params;
|
priv->channels.params = new_channels.params;
|
||||||
err = mlx5e_num_channels_changed(priv);
|
err = mlx5e_num_channels_changed(priv);
|
||||||
|
if (err)
|
||||||
|
priv->channels.params = old_params;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -334,9 +334,9 @@ static int mlx5e_create_rq_umr_mkey(struct mlx5_core_dev *mdev, struct mlx5e_rq
|
||||||
rq->wqe_overflow.addr);
|
rq->wqe_overflow.addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline u64 mlx5e_get_mpwqe_offset(struct mlx5e_rq *rq, u16 wqe_ix)
|
static u64 mlx5e_get_mpwqe_offset(u16 wqe_ix)
|
||||||
{
|
{
|
||||||
return (wqe_ix << MLX5E_LOG_ALIGNED_MPWQE_PPW) << PAGE_SHIFT;
|
return MLX5E_REQUIRED_MTTS(wqe_ix) << PAGE_SHIFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mlx5e_init_frags_partition(struct mlx5e_rq *rq)
|
static void mlx5e_init_frags_partition(struct mlx5e_rq *rq)
|
||||||
|
@ -577,7 +577,7 @@ static int mlx5e_alloc_rq(struct mlx5e_channel *c,
|
||||||
mlx5_wq_ll_get_wqe(&rq->mpwqe.wq, i);
|
mlx5_wq_ll_get_wqe(&rq->mpwqe.wq, i);
|
||||||
u32 byte_count =
|
u32 byte_count =
|
||||||
rq->mpwqe.num_strides << rq->mpwqe.log_stride_sz;
|
rq->mpwqe.num_strides << rq->mpwqe.log_stride_sz;
|
||||||
u64 dma_offset = mlx5e_get_mpwqe_offset(rq, i);
|
u64 dma_offset = mlx5e_get_mpwqe_offset(i);
|
||||||
|
|
||||||
wqe->data[0].addr = cpu_to_be64(dma_offset + rq->buff.headroom);
|
wqe->data[0].addr = cpu_to_be64(dma_offset + rq->buff.headroom);
|
||||||
wqe->data[0].byte_count = cpu_to_be32(byte_count);
|
wqe->data[0].byte_count = cpu_to_be32(byte_count);
|
||||||
|
@ -2368,8 +2368,9 @@ static u8 mlx5e_build_icosq_log_wq_sz(struct mlx5e_params *params,
|
||||||
{
|
{
|
||||||
switch (params->rq_wq_type) {
|
switch (params->rq_wq_type) {
|
||||||
case MLX5_WQ_TYPE_LINKED_LIST_STRIDING_RQ:
|
case MLX5_WQ_TYPE_LINKED_LIST_STRIDING_RQ:
|
||||||
return order_base_2(MLX5E_UMR_WQEBBS) +
|
return max_t(u8, MLX5E_PARAMS_MINIMUM_LOG_SQ_SIZE,
|
||||||
mlx5e_get_rq_log_wq_sz(rqp->rqc);
|
order_base_2(MLX5E_UMR_WQEBBS) +
|
||||||
|
mlx5e_get_rq_log_wq_sz(rqp->rqc));
|
||||||
default: /* MLX5_WQ_TYPE_CYCLIC */
|
default: /* MLX5_WQ_TYPE_CYCLIC */
|
||||||
return MLX5E_PARAMS_MINIMUM_LOG_SQ_SIZE;
|
return MLX5E_PARAMS_MINIMUM_LOG_SQ_SIZE;
|
||||||
}
|
}
|
||||||
|
@ -2502,8 +2503,10 @@ void mlx5e_close_channels(struct mlx5e_channels *chs)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (chs->port_ptp)
|
if (chs->port_ptp) {
|
||||||
mlx5e_port_ptp_close(chs->port_ptp);
|
mlx5e_port_ptp_close(chs->port_ptp);
|
||||||
|
chs->port_ptp = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < chs->num; i++)
|
for (i = 0; i < chs->num; i++)
|
||||||
mlx5e_close_channel(chs->c[i]);
|
mlx5e_close_channel(chs->c[i]);
|
||||||
|
@ -3810,6 +3813,15 @@ void mlx5e_fold_sw_stats64(struct mlx5e_priv *priv, struct rtnl_link_stats64 *s)
|
||||||
for (j = 0; j < priv->max_opened_tc; j++) {
|
for (j = 0; j < priv->max_opened_tc; j++) {
|
||||||
struct mlx5e_sq_stats *sq_stats = &channel_stats->sq[j];
|
struct mlx5e_sq_stats *sq_stats = &channel_stats->sq[j];
|
||||||
|
|
||||||
|
s->tx_packets += sq_stats->packets;
|
||||||
|
s->tx_bytes += sq_stats->bytes;
|
||||||
|
s->tx_dropped += sq_stats->dropped;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (priv->port_ptp_opened) {
|
||||||
|
for (i = 0; i < priv->max_opened_tc; i++) {
|
||||||
|
struct mlx5e_sq_stats *sq_stats = &priv->port_ptp_stats.sq[i];
|
||||||
|
|
||||||
s->tx_packets += sq_stats->packets;
|
s->tx_packets += sq_stats->packets;
|
||||||
s->tx_bytes += sq_stats->bytes;
|
s->tx_bytes += sq_stats->bytes;
|
||||||
s->tx_dropped += sq_stats->dropped;
|
s->tx_dropped += sq_stats->dropped;
|
||||||
|
@ -3834,10 +3846,17 @@ mlx5e_get_stats(struct net_device *dev, struct rtnl_link_stats64 *stats)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mlx5e_is_uplink_rep(priv)) {
|
if (mlx5e_is_uplink_rep(priv)) {
|
||||||
|
struct mlx5e_vport_stats *vstats = &priv->stats.vport;
|
||||||
|
|
||||||
stats->rx_packets = PPORT_802_3_GET(pstats, a_frames_received_ok);
|
stats->rx_packets = PPORT_802_3_GET(pstats, a_frames_received_ok);
|
||||||
stats->rx_bytes = PPORT_802_3_GET(pstats, a_octets_received_ok);
|
stats->rx_bytes = PPORT_802_3_GET(pstats, a_octets_received_ok);
|
||||||
stats->tx_packets = PPORT_802_3_GET(pstats, a_frames_transmitted_ok);
|
stats->tx_packets = PPORT_802_3_GET(pstats, a_frames_transmitted_ok);
|
||||||
stats->tx_bytes = PPORT_802_3_GET(pstats, a_octets_transmitted_ok);
|
stats->tx_bytes = PPORT_802_3_GET(pstats, a_octets_transmitted_ok);
|
||||||
|
|
||||||
|
/* vport multicast also counts packets that are dropped due to steering
|
||||||
|
* or rx out of buffer
|
||||||
|
*/
|
||||||
|
stats->multicast = VPORT_COUNTER_GET(vstats, received_eth_multicast.packets);
|
||||||
} else {
|
} else {
|
||||||
mlx5e_fold_sw_stats64(priv, stats);
|
mlx5e_fold_sw_stats64(priv, stats);
|
||||||
}
|
}
|
||||||
|
@ -4683,8 +4702,10 @@ static int mlx5e_xdp_set(struct net_device *netdev, struct bpf_prog *prog)
|
||||||
struct mlx5e_channel *c = priv->channels.c[i];
|
struct mlx5e_channel *c = priv->channels.c[i];
|
||||||
|
|
||||||
mlx5e_rq_replace_xdp_prog(&c->rq, prog);
|
mlx5e_rq_replace_xdp_prog(&c->rq, prog);
|
||||||
if (test_bit(MLX5E_CHANNEL_STATE_XSK, c->state))
|
if (test_bit(MLX5E_CHANNEL_STATE_XSK, c->state)) {
|
||||||
|
bpf_prog_inc(prog);
|
||||||
mlx5e_rq_replace_xdp_prog(&c->xskrq, prog);
|
mlx5e_rq_replace_xdp_prog(&c->xskrq, prog);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock:
|
unlock:
|
||||||
|
@ -4958,6 +4979,11 @@ void mlx5e_build_nic_params(struct mlx5e_priv *priv, struct mlx5e_xsk *xsk, u16
|
||||||
priv->max_nch);
|
priv->max_nch);
|
||||||
params->num_tc = 1;
|
params->num_tc = 1;
|
||||||
|
|
||||||
|
/* Set an initial non-zero value, so that mlx5e_select_queue won't
|
||||||
|
* divide by zero if called before first activating channels.
|
||||||
|
*/
|
||||||
|
priv->num_tc_x_num_ch = params->num_channels * params->num_tc;
|
||||||
|
|
||||||
/* SQ */
|
/* SQ */
|
||||||
params->log_sq_size = is_kdump_kernel() ?
|
params->log_sq_size = is_kdump_kernel() ?
|
||||||
MLX5E_PARAMS_MINIMUM_LOG_SQ_SIZE :
|
MLX5E_PARAMS_MINIMUM_LOG_SQ_SIZE :
|
||||||
|
@ -5474,8 +5500,6 @@ int mlx5e_priv_init(struct mlx5e_priv *priv,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
struct mlx5_core_dev *mdev)
|
struct mlx5_core_dev *mdev)
|
||||||
{
|
{
|
||||||
memset(priv, 0, sizeof(*priv));
|
|
||||||
|
|
||||||
/* priv init */
|
/* priv init */
|
||||||
priv->mdev = mdev;
|
priv->mdev = mdev;
|
||||||
priv->netdev = netdev;
|
priv->netdev = netdev;
|
||||||
|
@ -5508,12 +5532,18 @@ void mlx5e_priv_cleanup(struct mlx5e_priv *priv)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* bail if change profile failed and also rollback failed */
|
||||||
|
if (!priv->mdev)
|
||||||
|
return;
|
||||||
|
|
||||||
destroy_workqueue(priv->wq);
|
destroy_workqueue(priv->wq);
|
||||||
free_cpumask_var(priv->scratchpad.cpumask);
|
free_cpumask_var(priv->scratchpad.cpumask);
|
||||||
|
|
||||||
for (i = 0; i < priv->htb.max_qos_sqs; i++)
|
for (i = 0; i < priv->htb.max_qos_sqs; i++)
|
||||||
kfree(priv->htb.qos_sq_stats[i]);
|
kfree(priv->htb.qos_sq_stats[i]);
|
||||||
kvfree(priv->htb.qos_sq_stats);
|
kvfree(priv->htb.qos_sq_stats);
|
||||||
|
|
||||||
|
memset(priv, 0, sizeof(*priv));
|
||||||
}
|
}
|
||||||
|
|
||||||
struct net_device *
|
struct net_device *
|
||||||
|
@ -5630,11 +5660,10 @@ void mlx5e_detach_netdev(struct mlx5e_priv *priv)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
mlx5e_netdev_attach_profile(struct mlx5e_priv *priv,
|
mlx5e_netdev_attach_profile(struct net_device *netdev, struct mlx5_core_dev *mdev,
|
||||||
const struct mlx5e_profile *new_profile, void *new_ppriv)
|
const struct mlx5e_profile *new_profile, void *new_ppriv)
|
||||||
{
|
{
|
||||||
struct net_device *netdev = priv->netdev;
|
struct mlx5e_priv *priv = netdev_priv(netdev);
|
||||||
struct mlx5_core_dev *mdev = priv->mdev;
|
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = mlx5e_priv_init(priv, netdev, mdev);
|
err = mlx5e_priv_init(priv, netdev, mdev);
|
||||||
|
@ -5647,10 +5676,16 @@ mlx5e_netdev_attach_profile(struct mlx5e_priv *priv,
|
||||||
priv->ppriv = new_ppriv;
|
priv->ppriv = new_ppriv;
|
||||||
err = new_profile->init(priv->mdev, priv->netdev);
|
err = new_profile->init(priv->mdev, priv->netdev);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
goto priv_cleanup;
|
||||||
err = mlx5e_attach_netdev(priv);
|
err = mlx5e_attach_netdev(priv);
|
||||||
if (err)
|
if (err)
|
||||||
new_profile->cleanup(priv);
|
goto profile_cleanup;
|
||||||
|
return err;
|
||||||
|
|
||||||
|
profile_cleanup:
|
||||||
|
new_profile->cleanup(priv);
|
||||||
|
priv_cleanup:
|
||||||
|
mlx5e_priv_cleanup(priv);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5659,13 +5694,14 @@ int mlx5e_netdev_change_profile(struct mlx5e_priv *priv,
|
||||||
{
|
{
|
||||||
unsigned int new_max_nch = mlx5e_calc_max_nch(priv, new_profile);
|
unsigned int new_max_nch = mlx5e_calc_max_nch(priv, new_profile);
|
||||||
const struct mlx5e_profile *orig_profile = priv->profile;
|
const struct mlx5e_profile *orig_profile = priv->profile;
|
||||||
|
struct net_device *netdev = priv->netdev;
|
||||||
|
struct mlx5_core_dev *mdev = priv->mdev;
|
||||||
void *orig_ppriv = priv->ppriv;
|
void *orig_ppriv = priv->ppriv;
|
||||||
int err, rollback_err;
|
int err, rollback_err;
|
||||||
|
|
||||||
/* sanity */
|
/* sanity */
|
||||||
if (new_max_nch != priv->max_nch) {
|
if (new_max_nch != priv->max_nch) {
|
||||||
netdev_warn(priv->netdev,
|
netdev_warn(netdev, "%s: Replacing profile with different max channels\n",
|
||||||
"%s: Replacing profile with different max channels\n",
|
|
||||||
__func__);
|
__func__);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -5675,22 +5711,19 @@ int mlx5e_netdev_change_profile(struct mlx5e_priv *priv,
|
||||||
priv->profile->cleanup(priv);
|
priv->profile->cleanup(priv);
|
||||||
mlx5e_priv_cleanup(priv);
|
mlx5e_priv_cleanup(priv);
|
||||||
|
|
||||||
err = mlx5e_netdev_attach_profile(priv, new_profile, new_ppriv);
|
err = mlx5e_netdev_attach_profile(netdev, mdev, new_profile, new_ppriv);
|
||||||
if (err) { /* roll back to original profile */
|
if (err) { /* roll back to original profile */
|
||||||
netdev_warn(priv->netdev, "%s: new profile init failed, %d\n",
|
netdev_warn(netdev, "%s: new profile init failed, %d\n", __func__, err);
|
||||||
__func__, err);
|
|
||||||
goto rollback;
|
goto rollback;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
rollback:
|
rollback:
|
||||||
rollback_err = mlx5e_netdev_attach_profile(priv, orig_profile, orig_ppriv);
|
rollback_err = mlx5e_netdev_attach_profile(netdev, mdev, orig_profile, orig_ppriv);
|
||||||
if (rollback_err) {
|
if (rollback_err)
|
||||||
netdev_err(priv->netdev,
|
netdev_err(netdev, "%s: failed to rollback to orig profile, %d\n",
|
||||||
"%s: failed to rollback to orig profile, %d\n",
|
|
||||||
__func__, rollback_err);
|
__func__, rollback_err);
|
||||||
}
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -500,7 +500,6 @@ static int mlx5e_alloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
|
||||||
struct mlx5e_icosq *sq = rq->icosq;
|
struct mlx5e_icosq *sq = rq->icosq;
|
||||||
struct mlx5_wq_cyc *wq = &sq->wq;
|
struct mlx5_wq_cyc *wq = &sq->wq;
|
||||||
struct mlx5e_umr_wqe *umr_wqe;
|
struct mlx5e_umr_wqe *umr_wqe;
|
||||||
u16 xlt_offset = ix << (MLX5E_LOG_ALIGNED_MPWQE_PPW - 1);
|
|
||||||
u16 pi;
|
u16 pi;
|
||||||
int err;
|
int err;
|
||||||
int i;
|
int i;
|
||||||
|
@ -531,7 +530,8 @@ static int mlx5e_alloc_rx_mpwqe(struct mlx5e_rq *rq, u16 ix)
|
||||||
umr_wqe->ctrl.opmod_idx_opcode =
|
umr_wqe->ctrl.opmod_idx_opcode =
|
||||||
cpu_to_be32((sq->pc << MLX5_WQE_CTRL_WQE_INDEX_SHIFT) |
|
cpu_to_be32((sq->pc << MLX5_WQE_CTRL_WQE_INDEX_SHIFT) |
|
||||||
MLX5_OPCODE_UMR);
|
MLX5_OPCODE_UMR);
|
||||||
umr_wqe->uctrl.xlt_offset = cpu_to_be16(xlt_offset);
|
umr_wqe->uctrl.xlt_offset =
|
||||||
|
cpu_to_be16(MLX5_ALIGNED_MTTS_OCTW(MLX5E_REQUIRED_MTTS(ix)));
|
||||||
|
|
||||||
sq->db.wqe_info[pi] = (struct mlx5e_icosq_wqe_info) {
|
sq->db.wqe_info[pi] = (struct mlx5e_icosq_wqe_info) {
|
||||||
.wqe_type = MLX5E_ICOSQ_WQE_UMR_RX,
|
.wqe_type = MLX5E_ICOSQ_WQE_UMR_RX,
|
||||||
|
|
|
@ -2296,6 +2296,16 @@ static int __parse_cls_flower(struct mlx5e_priv *priv,
|
||||||
*match_level = MLX5_MATCH_L4;
|
*match_level = MLX5_MATCH_L4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Currenlty supported only for MPLS over UDP */
|
||||||
|
if (flow_rule_match_key(rule, FLOW_DISSECTOR_KEY_MPLS) &&
|
||||||
|
!netif_is_bareudp(filter_dev)) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack,
|
||||||
|
"Matching on MPLS is supported only for MPLS over UDP");
|
||||||
|
netdev_err(priv->netdev,
|
||||||
|
"Matching on MPLS is supported only for MPLS over UDP\n");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2899,6 +2909,37 @@ static int is_action_keys_supported(const struct flow_action_entry *act,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool modify_tuple_supported(bool modify_tuple, bool ct_clear,
|
||||||
|
bool ct_flow, struct netlink_ext_ack *extack,
|
||||||
|
struct mlx5e_priv *priv,
|
||||||
|
struct mlx5_flow_spec *spec)
|
||||||
|
{
|
||||||
|
if (!modify_tuple || ct_clear)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (ct_flow) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack,
|
||||||
|
"can't offload tuple modification with non-clear ct()");
|
||||||
|
netdev_info(priv->netdev,
|
||||||
|
"can't offload tuple modification with non-clear ct()");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add ct_state=-trk match so it will be offloaded for non ct flows
|
||||||
|
* (or after clear action), as otherwise, since the tuple is changed,
|
||||||
|
* we can't restore ct state
|
||||||
|
*/
|
||||||
|
if (mlx5_tc_ct_add_no_trk_match(spec)) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack,
|
||||||
|
"can't offload tuple modification with ct matches and no ct(clear) action");
|
||||||
|
netdev_info(priv->netdev,
|
||||||
|
"can't offload tuple modification with ct matches and no ct(clear) action");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
static bool modify_header_match_supported(struct mlx5e_priv *priv,
|
static bool modify_header_match_supported(struct mlx5e_priv *priv,
|
||||||
struct mlx5_flow_spec *spec,
|
struct mlx5_flow_spec *spec,
|
||||||
struct flow_action *flow_action,
|
struct flow_action *flow_action,
|
||||||
|
@ -2937,18 +2978,9 @@ static bool modify_header_match_supported(struct mlx5e_priv *priv,
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Add ct_state=-trk match so it will be offloaded for non ct flows
|
if (!modify_tuple_supported(modify_tuple, ct_clear, ct_flow, extack,
|
||||||
* (or after clear action), as otherwise, since the tuple is changed,
|
priv, spec))
|
||||||
* we can't restore ct state
|
|
||||||
*/
|
|
||||||
if (!ct_clear && modify_tuple &&
|
|
||||||
mlx5_tc_ct_add_no_trk_match(spec)) {
|
|
||||||
NL_SET_ERR_MSG_MOD(extack,
|
|
||||||
"can't offload tuple modify header with ct matches");
|
|
||||||
netdev_info(priv->netdev,
|
|
||||||
"can't offload tuple modify header with ct matches");
|
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
ip_proto = MLX5_GET(fte_match_set_lyr_2_4, headers_v, ip_protocol);
|
ip_proto = MLX5_GET(fte_match_set_lyr_2_4, headers_v, ip_protocol);
|
||||||
if (modify_ip_header && ip_proto != IPPROTO_TCP &&
|
if (modify_ip_header && ip_proto != IPPROTO_TCP &&
|
||||||
|
@ -4445,7 +4477,8 @@ static int apply_police_params(struct mlx5e_priv *priv, u64 rate,
|
||||||
*/
|
*/
|
||||||
if (rate) {
|
if (rate) {
|
||||||
rate = (rate * BITS_PER_BYTE) + 500000;
|
rate = (rate * BITS_PER_BYTE) + 500000;
|
||||||
rate_mbps = max_t(u64, do_div(rate, 1000000), 1);
|
do_div(rate, 1000000);
|
||||||
|
rate_mbps = max_t(u32, rate, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mlx5_esw_modify_vport_rate(esw, vport_num, rate_mbps);
|
err = mlx5_esw_modify_vport_rate(esw, vport_num, rate_mbps);
|
||||||
|
|
|
@ -79,6 +79,7 @@ struct mlx5_flow_attr {
|
||||||
u8 inner_match_level;
|
u8 inner_match_level;
|
||||||
u8 outer_match_level;
|
u8 outer_match_level;
|
||||||
u8 ip_version;
|
u8 ip_version;
|
||||||
|
u8 tun_ip_version;
|
||||||
u32 flags;
|
u32 flags;
|
||||||
union {
|
union {
|
||||||
struct mlx5_esw_flow_attr esw_attr[0];
|
struct mlx5_esw_flow_attr esw_attr[0];
|
||||||
|
|
|
@ -551,7 +551,8 @@ esw_setup_dests(struct mlx5_flow_destination *dest,
|
||||||
|
|
||||||
if (!mlx5_eswitch_termtbl_required(esw, attr, flow_act, spec) &&
|
if (!mlx5_eswitch_termtbl_required(esw, attr, flow_act, spec) &&
|
||||||
MLX5_CAP_GEN(esw_attr->in_mdev, reg_c_preserve) &&
|
MLX5_CAP_GEN(esw_attr->in_mdev, reg_c_preserve) &&
|
||||||
mlx5_eswitch_vport_match_metadata_enabled(esw))
|
mlx5_eswitch_vport_match_metadata_enabled(esw) &&
|
||||||
|
MLX5_CAP_ESW_FLOWTABLE_FDB(esw->dev, ignore_flow_level))
|
||||||
attr->flags |= MLX5_ESW_ATTR_FLAG_SRC_REWRITE;
|
attr->flags |= MLX5_ESW_ATTR_FLAG_SRC_REWRITE;
|
||||||
|
|
||||||
if (attr->dest_ft) {
|
if (attr->dest_ft) {
|
||||||
|
|
|
@ -575,6 +575,7 @@ static int mlx5_fpga_conn_create_qp(struct mlx5_fpga_conn *conn,
|
||||||
MLX5_SET(qpc, qpc, log_sq_size, ilog2(conn->qp.sq.size));
|
MLX5_SET(qpc, qpc, log_sq_size, ilog2(conn->qp.sq.size));
|
||||||
MLX5_SET(qpc, qpc, cqn_snd, conn->cq.mcq.cqn);
|
MLX5_SET(qpc, qpc, cqn_snd, conn->cq.mcq.cqn);
|
||||||
MLX5_SET(qpc, qpc, cqn_rcv, conn->cq.mcq.cqn);
|
MLX5_SET(qpc, qpc, cqn_rcv, conn->cq.mcq.cqn);
|
||||||
|
MLX5_SET(qpc, qpc, ts_format, mlx5_get_qp_default_ts(mdev));
|
||||||
MLX5_SET64(qpc, qpc, dbr_addr, conn->qp.wq_ctrl.db.dma);
|
MLX5_SET64(qpc, qpc, dbr_addr, conn->qp.wq_ctrl.db.dma);
|
||||||
if (MLX5_CAP_GEN(mdev, cqe_version) == 1)
|
if (MLX5_CAP_GEN(mdev, cqe_version) == 1)
|
||||||
MLX5_SET(qpc, qpc, user_index, 0xFFFFFF);
|
MLX5_SET(qpc, qpc, user_index, 0xFFFFFF);
|
||||||
|
|
|
@ -233,6 +233,7 @@ int mlx5i_create_underlay_qp(struct mlx5e_priv *priv)
|
||||||
}
|
}
|
||||||
|
|
||||||
qpc = MLX5_ADDR_OF(create_qp_in, in, qpc);
|
qpc = MLX5_ADDR_OF(create_qp_in, in, qpc);
|
||||||
|
MLX5_SET(qpc, qpc, ts_format, mlx5_get_qp_default_ts(priv->mdev));
|
||||||
MLX5_SET(qpc, qpc, st, MLX5_QP_ST_UD);
|
MLX5_SET(qpc, qpc, st, MLX5_QP_ST_UD);
|
||||||
MLX5_SET(qpc, qpc, pm_state, MLX5_QP_PM_MIGRATED);
|
MLX5_SET(qpc, qpc, pm_state, MLX5_QP_PM_MIGRATED);
|
||||||
MLX5_SET(qpc, qpc, ulp_stateless_offload_mode,
|
MLX5_SET(qpc, qpc, ulp_stateless_offload_mode,
|
||||||
|
@ -694,6 +695,7 @@ static int mlx5i_check_required_hca_cap(struct mlx5_core_dev *mdev)
|
||||||
static void mlx5_rdma_netdev_free(struct net_device *netdev)
|
static void mlx5_rdma_netdev_free(struct net_device *netdev)
|
||||||
{
|
{
|
||||||
struct mlx5e_priv *priv = mlx5i_epriv(netdev);
|
struct mlx5e_priv *priv = mlx5i_epriv(netdev);
|
||||||
|
struct mlx5_core_dev *mdev = priv->mdev;
|
||||||
struct mlx5i_priv *ipriv = priv->ppriv;
|
struct mlx5i_priv *ipriv = priv->ppriv;
|
||||||
const struct mlx5e_profile *profile = priv->profile;
|
const struct mlx5e_profile *profile = priv->profile;
|
||||||
|
|
||||||
|
@ -702,7 +704,7 @@ static void mlx5_rdma_netdev_free(struct net_device *netdev)
|
||||||
|
|
||||||
if (!ipriv->sub_interface) {
|
if (!ipriv->sub_interface) {
|
||||||
mlx5i_pkey_qpn_ht_cleanup(netdev);
|
mlx5i_pkey_qpn_ht_cleanup(netdev);
|
||||||
mlx5e_destroy_mdev_resources(priv->mdev);
|
mlx5e_destroy_mdev_resources(mdev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -495,15 +495,15 @@ static int mlx5_perout_configure(struct ptp_clock_info *ptp,
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
field_select = MLX5_MTPPS_FS_ENABLE;
|
field_select = MLX5_MTPPS_FS_ENABLE;
|
||||||
|
pin = ptp_find_pin(clock->ptp, PTP_PF_PEROUT, rq->perout.index);
|
||||||
|
if (pin < 0)
|
||||||
|
return -EBUSY;
|
||||||
|
|
||||||
if (on) {
|
if (on) {
|
||||||
bool rt_mode = mlx5_real_time_mode(mdev);
|
bool rt_mode = mlx5_real_time_mode(mdev);
|
||||||
u32 nsec;
|
u32 nsec;
|
||||||
s64 sec;
|
s64 sec;
|
||||||
|
|
||||||
pin = ptp_find_pin(clock->ptp, PTP_PF_PEROUT, rq->perout.index);
|
|
||||||
if (pin < 0)
|
|
||||||
return -EBUSY;
|
|
||||||
|
|
||||||
pin_mode = MLX5_PIN_MODE_OUT;
|
pin_mode = MLX5_PIN_MODE_OUT;
|
||||||
pattern = MLX5_OUT_PATTERN_PERIODIC;
|
pattern = MLX5_OUT_PATTERN_PERIODIC;
|
||||||
ts.tv_sec = rq->perout.period.sec;
|
ts.tv_sec = rq->perout.period.sec;
|
||||||
|
|
|
@ -181,15 +181,13 @@ static int mlx5_sf_dev_vhca_arm_all(struct mlx5_sf_dev_table *table)
|
||||||
u16 max_functions;
|
u16 max_functions;
|
||||||
u16 function_id;
|
u16 function_id;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
bool ecpu;
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
max_functions = mlx5_sf_max_functions(dev);
|
max_functions = mlx5_sf_max_functions(dev);
|
||||||
function_id = MLX5_CAP_GEN(dev, sf_base_id);
|
function_id = MLX5_CAP_GEN(dev, sf_base_id);
|
||||||
ecpu = mlx5_read_embedded_cpu(dev);
|
|
||||||
/* Arm the vhca context as the vhca event notifier */
|
/* Arm the vhca context as the vhca event notifier */
|
||||||
for (i = 0; i < max_functions; i++) {
|
for (i = 0; i < max_functions; i++) {
|
||||||
err = mlx5_vhca_event_arm(dev, function_id, ecpu);
|
err = mlx5_vhca_event_arm(dev, function_id);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
#include "sf.h"
|
#include "sf.h"
|
||||||
#include "mlx5_ifc_vhca_event.h"
|
#include "mlx5_ifc_vhca_event.h"
|
||||||
#include "vhca_event.h"
|
#include "vhca_event.h"
|
||||||
#include "ecpf.h"
|
#include "mlx5_core.h"
|
||||||
|
|
||||||
struct mlx5_sf_hw {
|
struct mlx5_sf_hw {
|
||||||
u32 usr_sfnum;
|
u32 usr_sfnum;
|
||||||
|
@ -18,7 +18,6 @@ struct mlx5_sf_hw_table {
|
||||||
struct mlx5_core_dev *dev;
|
struct mlx5_core_dev *dev;
|
||||||
struct mlx5_sf_hw *sfs;
|
struct mlx5_sf_hw *sfs;
|
||||||
int max_local_functions;
|
int max_local_functions;
|
||||||
u8 ecpu: 1;
|
|
||||||
struct mutex table_lock; /* Serializes sf deletion and vhca state change handler. */
|
struct mutex table_lock; /* Serializes sf deletion and vhca state change handler. */
|
||||||
struct notifier_block vhca_nb;
|
struct notifier_block vhca_nb;
|
||||||
};
|
};
|
||||||
|
@ -64,7 +63,7 @@ int mlx5_sf_hw_table_sf_alloc(struct mlx5_core_dev *dev, u32 usr_sfnum)
|
||||||
}
|
}
|
||||||
if (sw_id == -ENOSPC) {
|
if (sw_id == -ENOSPC) {
|
||||||
err = -ENOSPC;
|
err = -ENOSPC;
|
||||||
goto err;
|
goto exist_err;
|
||||||
}
|
}
|
||||||
|
|
||||||
hw_fn_id = mlx5_sf_sw_to_hw_id(table->dev, sw_id);
|
hw_fn_id = mlx5_sf_sw_to_hw_id(table->dev, sw_id);
|
||||||
|
@ -72,7 +71,7 @@ int mlx5_sf_hw_table_sf_alloc(struct mlx5_core_dev *dev, u32 usr_sfnum)
|
||||||
if (err)
|
if (err)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
err = mlx5_modify_vhca_sw_id(dev, hw_fn_id, table->ecpu, usr_sfnum);
|
err = mlx5_modify_vhca_sw_id(dev, hw_fn_id, usr_sfnum);
|
||||||
if (err)
|
if (err)
|
||||||
goto vhca_err;
|
goto vhca_err;
|
||||||
|
|
||||||
|
@ -118,7 +117,7 @@ void mlx5_sf_hw_table_sf_deferred_free(struct mlx5_core_dev *dev, u16 id)
|
||||||
|
|
||||||
hw_fn_id = mlx5_sf_sw_to_hw_id(dev, id);
|
hw_fn_id = mlx5_sf_sw_to_hw_id(dev, id);
|
||||||
mutex_lock(&table->table_lock);
|
mutex_lock(&table->table_lock);
|
||||||
err = mlx5_cmd_query_vhca_state(dev, hw_fn_id, table->ecpu, out, sizeof(out));
|
err = mlx5_cmd_query_vhca_state(dev, hw_fn_id, out, sizeof(out));
|
||||||
if (err)
|
if (err)
|
||||||
goto err;
|
goto err;
|
||||||
state = MLX5_GET(query_vhca_state_out, out, vhca_state_context.vhca_state);
|
state = MLX5_GET(query_vhca_state_out, out, vhca_state_context.vhca_state);
|
||||||
|
@ -164,7 +163,6 @@ int mlx5_sf_hw_table_init(struct mlx5_core_dev *dev)
|
||||||
table->dev = dev;
|
table->dev = dev;
|
||||||
table->sfs = sfs;
|
table->sfs = sfs;
|
||||||
table->max_local_functions = max_functions;
|
table->max_local_functions = max_functions;
|
||||||
table->ecpu = mlx5_read_embedded_cpu(dev);
|
|
||||||
dev->priv.sf_hw_table = table;
|
dev->priv.sf_hw_table = table;
|
||||||
mlx5_core_dbg(dev, "SF HW table: max sfs = %d\n", max_functions);
|
mlx5_core_dbg(dev, "SF HW table: max sfs = %d\n", max_functions);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -20,7 +20,7 @@ struct mlx5_ifc_vhca_state_context_bits {
|
||||||
|
|
||||||
u8 sw_function_id[0x20];
|
u8 sw_function_id[0x20];
|
||||||
|
|
||||||
u8 reserved_at_40[0x80];
|
u8 reserved_at_40[0x40];
|
||||||
};
|
};
|
||||||
|
|
||||||
struct mlx5_ifc_query_vhca_state_out_bits {
|
struct mlx5_ifc_query_vhca_state_out_bits {
|
||||||
|
|
|
@ -19,52 +19,51 @@ struct mlx5_vhca_event_work {
|
||||||
struct mlx5_vhca_state_event event;
|
struct mlx5_vhca_state_event event;
|
||||||
};
|
};
|
||||||
|
|
||||||
int mlx5_cmd_query_vhca_state(struct mlx5_core_dev *dev, u16 function_id,
|
int mlx5_cmd_query_vhca_state(struct mlx5_core_dev *dev, u16 function_id, u32 *out, u32 outlen)
|
||||||
bool ecpu, u32 *out, u32 outlen)
|
|
||||||
{
|
{
|
||||||
u32 in[MLX5_ST_SZ_DW(query_vhca_state_in)] = {};
|
u32 in[MLX5_ST_SZ_DW(query_vhca_state_in)] = {};
|
||||||
|
|
||||||
MLX5_SET(query_vhca_state_in, in, opcode, MLX5_CMD_OP_QUERY_VHCA_STATE);
|
MLX5_SET(query_vhca_state_in, in, opcode, MLX5_CMD_OP_QUERY_VHCA_STATE);
|
||||||
MLX5_SET(query_vhca_state_in, in, function_id, function_id);
|
MLX5_SET(query_vhca_state_in, in, function_id, function_id);
|
||||||
MLX5_SET(query_vhca_state_in, in, embedded_cpu_function, ecpu);
|
MLX5_SET(query_vhca_state_in, in, embedded_cpu_function, 0);
|
||||||
|
|
||||||
return mlx5_cmd_exec(dev, in, sizeof(in), out, outlen);
|
return mlx5_cmd_exec(dev, in, sizeof(in), out, outlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int mlx5_cmd_modify_vhca_state(struct mlx5_core_dev *dev, u16 function_id,
|
static int mlx5_cmd_modify_vhca_state(struct mlx5_core_dev *dev, u16 function_id,
|
||||||
bool ecpu, u32 *in, u32 inlen)
|
u32 *in, u32 inlen)
|
||||||
{
|
{
|
||||||
u32 out[MLX5_ST_SZ_DW(modify_vhca_state_out)] = {};
|
u32 out[MLX5_ST_SZ_DW(modify_vhca_state_out)] = {};
|
||||||
|
|
||||||
MLX5_SET(modify_vhca_state_in, in, opcode, MLX5_CMD_OP_MODIFY_VHCA_STATE);
|
MLX5_SET(modify_vhca_state_in, in, opcode, MLX5_CMD_OP_MODIFY_VHCA_STATE);
|
||||||
MLX5_SET(modify_vhca_state_in, in, function_id, function_id);
|
MLX5_SET(modify_vhca_state_in, in, function_id, function_id);
|
||||||
MLX5_SET(modify_vhca_state_in, in, embedded_cpu_function, ecpu);
|
MLX5_SET(modify_vhca_state_in, in, embedded_cpu_function, 0);
|
||||||
|
|
||||||
return mlx5_cmd_exec(dev, in, inlen, out, sizeof(out));
|
return mlx5_cmd_exec(dev, in, inlen, out, sizeof(out));
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5_modify_vhca_sw_id(struct mlx5_core_dev *dev, u16 function_id, bool ecpu, u32 sw_fn_id)
|
int mlx5_modify_vhca_sw_id(struct mlx5_core_dev *dev, u16 function_id, u32 sw_fn_id)
|
||||||
{
|
{
|
||||||
u32 out[MLX5_ST_SZ_DW(modify_vhca_state_out)] = {};
|
u32 out[MLX5_ST_SZ_DW(modify_vhca_state_out)] = {};
|
||||||
u32 in[MLX5_ST_SZ_DW(modify_vhca_state_in)] = {};
|
u32 in[MLX5_ST_SZ_DW(modify_vhca_state_in)] = {};
|
||||||
|
|
||||||
MLX5_SET(modify_vhca_state_in, in, opcode, MLX5_CMD_OP_MODIFY_VHCA_STATE);
|
MLX5_SET(modify_vhca_state_in, in, opcode, MLX5_CMD_OP_MODIFY_VHCA_STATE);
|
||||||
MLX5_SET(modify_vhca_state_in, in, function_id, function_id);
|
MLX5_SET(modify_vhca_state_in, in, function_id, function_id);
|
||||||
MLX5_SET(modify_vhca_state_in, in, embedded_cpu_function, ecpu);
|
MLX5_SET(modify_vhca_state_in, in, embedded_cpu_function, 0);
|
||||||
MLX5_SET(modify_vhca_state_in, in, vhca_state_field_select.sw_function_id, 1);
|
MLX5_SET(modify_vhca_state_in, in, vhca_state_field_select.sw_function_id, 1);
|
||||||
MLX5_SET(modify_vhca_state_in, in, vhca_state_context.sw_function_id, sw_fn_id);
|
MLX5_SET(modify_vhca_state_in, in, vhca_state_context.sw_function_id, sw_fn_id);
|
||||||
|
|
||||||
return mlx5_cmd_exec_inout(dev, modify_vhca_state, in, out);
|
return mlx5_cmd_exec_inout(dev, modify_vhca_state, in, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
int mlx5_vhca_event_arm(struct mlx5_core_dev *dev, u16 function_id, bool ecpu)
|
int mlx5_vhca_event_arm(struct mlx5_core_dev *dev, u16 function_id)
|
||||||
{
|
{
|
||||||
u32 in[MLX5_ST_SZ_DW(modify_vhca_state_in)] = {};
|
u32 in[MLX5_ST_SZ_DW(modify_vhca_state_in)] = {};
|
||||||
|
|
||||||
MLX5_SET(modify_vhca_state_in, in, vhca_state_context.arm_change_event, 1);
|
MLX5_SET(modify_vhca_state_in, in, vhca_state_context.arm_change_event, 1);
|
||||||
MLX5_SET(modify_vhca_state_in, in, vhca_state_field_select.arm_change_event, 1);
|
MLX5_SET(modify_vhca_state_in, in, vhca_state_field_select.arm_change_event, 1);
|
||||||
|
|
||||||
return mlx5_cmd_modify_vhca_state(dev, function_id, ecpu, in, sizeof(in));
|
return mlx5_cmd_modify_vhca_state(dev, function_id, in, sizeof(in));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -73,7 +72,7 @@ mlx5_vhca_event_notify(struct mlx5_core_dev *dev, struct mlx5_vhca_state_event *
|
||||||
u32 out[MLX5_ST_SZ_DW(query_vhca_state_out)] = {};
|
u32 out[MLX5_ST_SZ_DW(query_vhca_state_out)] = {};
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = mlx5_cmd_query_vhca_state(dev, event->function_id, event->ecpu, out, sizeof(out));
|
err = mlx5_cmd_query_vhca_state(dev, event->function_id, out, sizeof(out));
|
||||||
if (err)
|
if (err)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -82,7 +81,7 @@ mlx5_vhca_event_notify(struct mlx5_core_dev *dev, struct mlx5_vhca_state_event *
|
||||||
event->new_vhca_state = MLX5_GET(query_vhca_state_out, out,
|
event->new_vhca_state = MLX5_GET(query_vhca_state_out, out,
|
||||||
vhca_state_context.vhca_state);
|
vhca_state_context.vhca_state);
|
||||||
|
|
||||||
mlx5_vhca_event_arm(dev, event->function_id, event->ecpu);
|
mlx5_vhca_event_arm(dev, event->function_id);
|
||||||
|
|
||||||
blocking_notifier_call_chain(&dev->priv.vhca_state_notifier->n_head, 0, event);
|
blocking_notifier_call_chain(&dev->priv.vhca_state_notifier->n_head, 0, event);
|
||||||
}
|
}
|
||||||
|
@ -94,6 +93,7 @@ static void mlx5_vhca_state_work_handler(struct work_struct *_work)
|
||||||
struct mlx5_core_dev *dev = notifier->dev;
|
struct mlx5_core_dev *dev = notifier->dev;
|
||||||
|
|
||||||
mlx5_vhca_event_notify(dev, &work->event);
|
mlx5_vhca_event_notify(dev, &work->event);
|
||||||
|
kfree(work);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@ -110,7 +110,6 @@ mlx5_vhca_state_change_notifier(struct notifier_block *nb, unsigned long type, v
|
||||||
INIT_WORK(&work->work, &mlx5_vhca_state_work_handler);
|
INIT_WORK(&work->work, &mlx5_vhca_state_work_handler);
|
||||||
work->notifier = notifier;
|
work->notifier = notifier;
|
||||||
work->event.function_id = be16_to_cpu(eqe->data.vhca_state.function_id);
|
work->event.function_id = be16_to_cpu(eqe->data.vhca_state.function_id);
|
||||||
work->event.ecpu = be16_to_cpu(eqe->data.vhca_state.ec_function);
|
|
||||||
mlx5_events_work_enqueue(notifier->dev, &work->work);
|
mlx5_events_work_enqueue(notifier->dev, &work->work);
|
||||||
return NOTIFY_OK;
|
return NOTIFY_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,6 @@ struct mlx5_vhca_state_event {
|
||||||
u16 function_id;
|
u16 function_id;
|
||||||
u16 sw_function_id;
|
u16 sw_function_id;
|
||||||
u8 new_vhca_state;
|
u8 new_vhca_state;
|
||||||
bool ecpu;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline bool mlx5_vhca_event_supported(const struct mlx5_core_dev *dev)
|
static inline bool mlx5_vhca_event_supported(const struct mlx5_core_dev *dev)
|
||||||
|
@ -25,10 +24,10 @@ void mlx5_vhca_event_start(struct mlx5_core_dev *dev);
|
||||||
void mlx5_vhca_event_stop(struct mlx5_core_dev *dev);
|
void mlx5_vhca_event_stop(struct mlx5_core_dev *dev);
|
||||||
int mlx5_vhca_event_notifier_register(struct mlx5_core_dev *dev, struct notifier_block *nb);
|
int mlx5_vhca_event_notifier_register(struct mlx5_core_dev *dev, struct notifier_block *nb);
|
||||||
void mlx5_vhca_event_notifier_unregister(struct mlx5_core_dev *dev, struct notifier_block *nb);
|
void mlx5_vhca_event_notifier_unregister(struct mlx5_core_dev *dev, struct notifier_block *nb);
|
||||||
int mlx5_modify_vhca_sw_id(struct mlx5_core_dev *dev, u16 function_id, bool ecpu, u32 sw_fn_id);
|
int mlx5_modify_vhca_sw_id(struct mlx5_core_dev *dev, u16 function_id, u32 sw_fn_id);
|
||||||
int mlx5_vhca_event_arm(struct mlx5_core_dev *dev, u16 function_id, bool ecpu);
|
int mlx5_vhca_event_arm(struct mlx5_core_dev *dev, u16 function_id);
|
||||||
int mlx5_cmd_query_vhca_state(struct mlx5_core_dev *dev, u16 function_id,
|
int mlx5_cmd_query_vhca_state(struct mlx5_core_dev *dev, u16 function_id,
|
||||||
bool ecpu, u32 *out, u32 outlen);
|
u32 *out, u32 outlen);
|
||||||
#else
|
#else
|
||||||
|
|
||||||
static inline void mlx5_vhca_state_cap_handle(struct mlx5_core_dev *dev, void *set_hca_cap)
|
static inline void mlx5_vhca_state_cap_handle(struct mlx5_core_dev *dev, void *set_hca_cap)
|
||||||
|
|
|
@ -169,6 +169,7 @@ static struct mlx5dr_qp *dr_create_rc_qp(struct mlx5_core_dev *mdev,
|
||||||
MLX5_SET(qpc, qpc, log_rq_size, ilog2(dr_qp->rq.wqe_cnt));
|
MLX5_SET(qpc, qpc, log_rq_size, ilog2(dr_qp->rq.wqe_cnt));
|
||||||
MLX5_SET(qpc, qpc, rq_type, MLX5_NON_ZERO_RQ);
|
MLX5_SET(qpc, qpc, rq_type, MLX5_NON_ZERO_RQ);
|
||||||
MLX5_SET(qpc, qpc, log_sq_size, ilog2(dr_qp->sq.wqe_cnt));
|
MLX5_SET(qpc, qpc, log_sq_size, ilog2(dr_qp->sq.wqe_cnt));
|
||||||
|
MLX5_SET(qpc, qpc, ts_format, mlx5_get_qp_default_ts(mdev));
|
||||||
MLX5_SET64(qpc, qpc, dbr_addr, dr_qp->wq_ctrl.db.dma);
|
MLX5_SET64(qpc, qpc, dbr_addr, dr_qp->wq_ctrl.db.dma);
|
||||||
if (MLX5_CAP_GEN(mdev, cqe_version) == 1)
|
if (MLX5_CAP_GEN(mdev, cqe_version) == 1)
|
||||||
MLX5_SET(qpc, qpc, user_index, 0xFFFFFF);
|
MLX5_SET(qpc, qpc, user_index, 0xFFFFFF);
|
||||||
|
|
|
@ -264,8 +264,8 @@ static void dr_ste_v1_set_miss_addr(u8 *hw_ste_p, u64 miss_addr)
|
||||||
static u64 dr_ste_v1_get_miss_addr(u8 *hw_ste_p)
|
static u64 dr_ste_v1_get_miss_addr(u8 *hw_ste_p)
|
||||||
{
|
{
|
||||||
u64 index =
|
u64 index =
|
||||||
(MLX5_GET(ste_match_bwc_v1, hw_ste_p, miss_address_31_6) |
|
((u64)MLX5_GET(ste_match_bwc_v1, hw_ste_p, miss_address_31_6) |
|
||||||
MLX5_GET(ste_match_bwc_v1, hw_ste_p, miss_address_39_32) << 26);
|
((u64)MLX5_GET(ste_match_bwc_v1, hw_ste_p, miss_address_39_32)) << 26);
|
||||||
|
|
||||||
return index << 6;
|
return index << 6;
|
||||||
}
|
}
|
||||||
|
|
|
@ -327,8 +327,14 @@ int nfp_compile_flow_metadata(struct nfp_app *app,
|
||||||
goto err_free_ctx_entry;
|
goto err_free_ctx_entry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Do net allocate a mask-id for pre_tun_rules. These flows are used to
|
||||||
|
* configure the pre_tun table and are never actually send to the
|
||||||
|
* firmware as an add-flow message. This causes the mask-id allocation
|
||||||
|
* on the firmware to get out of sync if allocated here.
|
||||||
|
*/
|
||||||
new_mask_id = 0;
|
new_mask_id = 0;
|
||||||
if (!nfp_check_mask_add(app, nfp_flow->mask_data,
|
if (!nfp_flow->pre_tun_rule.dev &&
|
||||||
|
!nfp_check_mask_add(app, nfp_flow->mask_data,
|
||||||
nfp_flow->meta.mask_len,
|
nfp_flow->meta.mask_len,
|
||||||
&nfp_flow->meta.flags, &new_mask_id)) {
|
&nfp_flow->meta.flags, &new_mask_id)) {
|
||||||
NL_SET_ERR_MSG_MOD(extack, "invalid entry: cannot allocate a new mask id");
|
NL_SET_ERR_MSG_MOD(extack, "invalid entry: cannot allocate a new mask id");
|
||||||
|
@ -359,7 +365,8 @@ int nfp_compile_flow_metadata(struct nfp_app *app,
|
||||||
goto err_remove_mask;
|
goto err_remove_mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!nfp_check_mask_remove(app, nfp_flow->mask_data,
|
if (!nfp_flow->pre_tun_rule.dev &&
|
||||||
|
!nfp_check_mask_remove(app, nfp_flow->mask_data,
|
||||||
nfp_flow->meta.mask_len,
|
nfp_flow->meta.mask_len,
|
||||||
NULL, &new_mask_id)) {
|
NULL, &new_mask_id)) {
|
||||||
NL_SET_ERR_MSG_MOD(extack, "invalid entry: cannot release mask id");
|
NL_SET_ERR_MSG_MOD(extack, "invalid entry: cannot release mask id");
|
||||||
|
@ -374,8 +381,10 @@ int nfp_compile_flow_metadata(struct nfp_app *app,
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_remove_mask:
|
err_remove_mask:
|
||||||
nfp_check_mask_remove(app, nfp_flow->mask_data, nfp_flow->meta.mask_len,
|
if (!nfp_flow->pre_tun_rule.dev)
|
||||||
NULL, &new_mask_id);
|
nfp_check_mask_remove(app, nfp_flow->mask_data,
|
||||||
|
nfp_flow->meta.mask_len,
|
||||||
|
NULL, &new_mask_id);
|
||||||
err_remove_rhash:
|
err_remove_rhash:
|
||||||
WARN_ON_ONCE(rhashtable_remove_fast(&priv->stats_ctx_table,
|
WARN_ON_ONCE(rhashtable_remove_fast(&priv->stats_ctx_table,
|
||||||
&ctx_entry->ht_node,
|
&ctx_entry->ht_node,
|
||||||
|
@ -406,9 +415,10 @@ int nfp_modify_flow_metadata(struct nfp_app *app,
|
||||||
|
|
||||||
__nfp_modify_flow_metadata(priv, nfp_flow);
|
__nfp_modify_flow_metadata(priv, nfp_flow);
|
||||||
|
|
||||||
nfp_check_mask_remove(app, nfp_flow->mask_data,
|
if (!nfp_flow->pre_tun_rule.dev)
|
||||||
nfp_flow->meta.mask_len, &nfp_flow->meta.flags,
|
nfp_check_mask_remove(app, nfp_flow->mask_data,
|
||||||
&new_mask_id);
|
nfp_flow->meta.mask_len, &nfp_flow->meta.flags,
|
||||||
|
&new_mask_id);
|
||||||
|
|
||||||
/* Update flow payload with mask ids. */
|
/* Update flow payload with mask ids. */
|
||||||
nfp_flow->unmasked_data[NFP_FL_MASK_ID_LOCATION] = new_mask_id;
|
nfp_flow->unmasked_data[NFP_FL_MASK_ID_LOCATION] = new_mask_id;
|
||||||
|
|
|
@ -1142,6 +1142,12 @@ nfp_flower_validate_pre_tun_rule(struct nfp_app *app,
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!(key_layer & NFP_FLOWER_LAYER_IPV4) &&
|
||||||
|
!(key_layer & NFP_FLOWER_LAYER_IPV6)) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack, "unsupported pre-tunnel rule: match on ipv4/ipv6 eth_type must be present");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
/* Skip fields known to exist. */
|
/* Skip fields known to exist. */
|
||||||
mask += sizeof(struct nfp_flower_meta_tci);
|
mask += sizeof(struct nfp_flower_meta_tci);
|
||||||
ext += sizeof(struct nfp_flower_meta_tci);
|
ext += sizeof(struct nfp_flower_meta_tci);
|
||||||
|
@ -1152,6 +1158,13 @@ nfp_flower_validate_pre_tun_rule(struct nfp_app *app,
|
||||||
mask += sizeof(struct nfp_flower_in_port);
|
mask += sizeof(struct nfp_flower_in_port);
|
||||||
ext += sizeof(struct nfp_flower_in_port);
|
ext += sizeof(struct nfp_flower_in_port);
|
||||||
|
|
||||||
|
/* Ensure destination MAC address matches pre_tun_dev. */
|
||||||
|
mac = (struct nfp_flower_mac_mpls *)ext;
|
||||||
|
if (memcmp(&mac->mac_dst[0], flow->pre_tun_rule.dev->dev_addr, 6)) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack, "unsupported pre-tunnel rule: dest MAC must match output dev MAC");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
/* Ensure destination MAC address is fully matched. */
|
/* Ensure destination MAC address is fully matched. */
|
||||||
mac = (struct nfp_flower_mac_mpls *)mask;
|
mac = (struct nfp_flower_mac_mpls *)mask;
|
||||||
if (!is_broadcast_ether_addr(&mac->mac_dst[0])) {
|
if (!is_broadcast_ether_addr(&mac->mac_dst[0])) {
|
||||||
|
@ -1159,6 +1172,11 @@ nfp_flower_validate_pre_tun_rule(struct nfp_app *app,
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mac->mpls_lse) {
|
||||||
|
NL_SET_ERR_MSG_MOD(extack, "unsupported pre-tunnel rule: MPLS not supported");
|
||||||
|
return -EOPNOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
mask += sizeof(struct nfp_flower_mac_mpls);
|
mask += sizeof(struct nfp_flower_mac_mpls);
|
||||||
ext += sizeof(struct nfp_flower_mac_mpls);
|
ext += sizeof(struct nfp_flower_mac_mpls);
|
||||||
if (key_layer & NFP_FLOWER_LAYER_IPV4 ||
|
if (key_layer & NFP_FLOWER_LAYER_IPV4 ||
|
||||||
|
|
|
@ -16,8 +16,9 @@
|
||||||
#define NFP_FL_MAX_ROUTES 32
|
#define NFP_FL_MAX_ROUTES 32
|
||||||
|
|
||||||
#define NFP_TUN_PRE_TUN_RULE_LIMIT 32
|
#define NFP_TUN_PRE_TUN_RULE_LIMIT 32
|
||||||
#define NFP_TUN_PRE_TUN_RULE_DEL 0x1
|
#define NFP_TUN_PRE_TUN_RULE_DEL BIT(0)
|
||||||
#define NFP_TUN_PRE_TUN_IDX_BIT 0x8
|
#define NFP_TUN_PRE_TUN_IDX_BIT BIT(3)
|
||||||
|
#define NFP_TUN_PRE_TUN_IPV6_BIT BIT(7)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* struct nfp_tun_pre_run_rule - rule matched before decap
|
* struct nfp_tun_pre_run_rule - rule matched before decap
|
||||||
|
@ -1268,6 +1269,7 @@ int nfp_flower_xmit_pre_tun_flow(struct nfp_app *app,
|
||||||
{
|
{
|
||||||
struct nfp_flower_priv *app_priv = app->priv;
|
struct nfp_flower_priv *app_priv = app->priv;
|
||||||
struct nfp_tun_offloaded_mac *mac_entry;
|
struct nfp_tun_offloaded_mac *mac_entry;
|
||||||
|
struct nfp_flower_meta_tci *key_meta;
|
||||||
struct nfp_tun_pre_tun_rule payload;
|
struct nfp_tun_pre_tun_rule payload;
|
||||||
struct net_device *internal_dev;
|
struct net_device *internal_dev;
|
||||||
int err;
|
int err;
|
||||||
|
@ -1290,6 +1292,15 @@ int nfp_flower_xmit_pre_tun_flow(struct nfp_app *app,
|
||||||
if (!mac_entry)
|
if (!mac_entry)
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
|
/* Set/clear IPV6 bit. cpu_to_be16() swap will lead to MSB being
|
||||||
|
* set/clear for port_idx.
|
||||||
|
*/
|
||||||
|
key_meta = (struct nfp_flower_meta_tci *)flow->unmasked_data;
|
||||||
|
if (key_meta->nfp_flow_key_layer & NFP_FLOWER_LAYER_IPV6)
|
||||||
|
mac_entry->index |= NFP_TUN_PRE_TUN_IPV6_BIT;
|
||||||
|
else
|
||||||
|
mac_entry->index &= ~NFP_TUN_PRE_TUN_IPV6_BIT;
|
||||||
|
|
||||||
payload.port_idx = cpu_to_be16(mac_entry->index);
|
payload.port_idx = cpu_to_be16(mac_entry->index);
|
||||||
|
|
||||||
/* Copy mac id and vlan to flow - dev may not exist at delete time. */
|
/* Copy mac id and vlan to flow - dev may not exist at delete time. */
|
||||||
|
|
|
@ -1079,15 +1079,17 @@ static int ionic_tx_descs_needed(struct ionic_queue *q, struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
int sg_elems = q->lif->qtype_info[IONIC_QTYPE_TXQ].max_sg_elems;
|
int sg_elems = q->lif->qtype_info[IONIC_QTYPE_TXQ].max_sg_elems;
|
||||||
struct ionic_tx_stats *stats = q_to_tx_stats(q);
|
struct ionic_tx_stats *stats = q_to_tx_stats(q);
|
||||||
|
int ndescs;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
/* If TSO, need roundup(skb->len/mss) descs */
|
/* Each desc is mss long max, so a descriptor for each gso_seg */
|
||||||
if (skb_is_gso(skb))
|
if (skb_is_gso(skb))
|
||||||
return (skb->len / skb_shinfo(skb)->gso_size) + 1;
|
ndescs = skb_shinfo(skb)->gso_segs;
|
||||||
|
else
|
||||||
|
ndescs = 1;
|
||||||
|
|
||||||
/* If non-TSO, just need 1 desc and nr_frags sg elems */
|
|
||||||
if (skb_shinfo(skb)->nr_frags <= sg_elems)
|
if (skb_shinfo(skb)->nr_frags <= sg_elems)
|
||||||
return 1;
|
return ndescs;
|
||||||
|
|
||||||
/* Too many frags, so linearize */
|
/* Too many frags, so linearize */
|
||||||
err = skb_linearize(skb);
|
err = skb_linearize(skb);
|
||||||
|
@ -1096,8 +1098,7 @@ static int ionic_tx_descs_needed(struct ionic_queue *q, struct sk_buff *skb)
|
||||||
|
|
||||||
stats->linearize++;
|
stats->linearize++;
|
||||||
|
|
||||||
/* Need 1 desc and zero sg elems */
|
return ndescs;
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ionic_maybe_stop_tx(struct ionic_queue *q, int ndescs)
|
static int ionic_maybe_stop_tx(struct ionic_queue *q, int ndescs)
|
||||||
|
|
|
@ -1425,6 +1425,7 @@ void qlcnic_83xx_get_minidump_template(struct qlcnic_adapter *adapter)
|
||||||
|
|
||||||
if (fw_dump->tmpl_hdr == NULL || current_version > prev_version) {
|
if (fw_dump->tmpl_hdr == NULL || current_version > prev_version) {
|
||||||
vfree(fw_dump->tmpl_hdr);
|
vfree(fw_dump->tmpl_hdr);
|
||||||
|
fw_dump->tmpl_hdr = NULL;
|
||||||
|
|
||||||
if (qlcnic_83xx_md_check_extended_dump_capability(adapter))
|
if (qlcnic_83xx_md_check_extended_dump_capability(adapter))
|
||||||
extended = !qlcnic_83xx_extend_md_capab(adapter);
|
extended = !qlcnic_83xx_extend_md_capab(adapter);
|
||||||
|
@ -1443,6 +1444,8 @@ void qlcnic_83xx_get_minidump_template(struct qlcnic_adapter *adapter)
|
||||||
struct qlcnic_83xx_dump_template_hdr *hdr;
|
struct qlcnic_83xx_dump_template_hdr *hdr;
|
||||||
|
|
||||||
hdr = fw_dump->tmpl_hdr;
|
hdr = fw_dump->tmpl_hdr;
|
||||||
|
if (!hdr)
|
||||||
|
return;
|
||||||
hdr->drv_cap_mask = 0x1f;
|
hdr->drv_cap_mask = 0x1f;
|
||||||
fw_dump->cap_mask = 0x1f;
|
fw_dump->cap_mask = 0x1f;
|
||||||
dev_info(&pdev->dev,
|
dev_info(&pdev->dev,
|
||||||
|
|
|
@ -4646,6 +4646,9 @@ static void rtl8169_down(struct rtl8169_private *tp)
|
||||||
|
|
||||||
rtl8169_update_counters(tp);
|
rtl8169_update_counters(tp);
|
||||||
|
|
||||||
|
pci_clear_master(tp->pci_dev);
|
||||||
|
rtl_pci_commit(tp);
|
||||||
|
|
||||||
rtl8169_cleanup(tp, true);
|
rtl8169_cleanup(tp, true);
|
||||||
|
|
||||||
rtl_prepare_power_down(tp);
|
rtl_prepare_power_down(tp);
|
||||||
|
@ -4653,6 +4656,7 @@ static void rtl8169_down(struct rtl8169_private *tp)
|
||||||
|
|
||||||
static void rtl8169_up(struct rtl8169_private *tp)
|
static void rtl8169_up(struct rtl8169_private *tp)
|
||||||
{
|
{
|
||||||
|
pci_set_master(tp->pci_dev);
|
||||||
phy_resume(tp->phydev);
|
phy_resume(tp->phydev);
|
||||||
rtl8169_init_phy(tp);
|
rtl8169_init_phy(tp);
|
||||||
napi_enable(&tp->napi);
|
napi_enable(&tp->napi);
|
||||||
|
@ -5307,8 +5311,6 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
|
||||||
|
|
||||||
rtl_hw_reset(tp);
|
rtl_hw_reset(tp);
|
||||||
|
|
||||||
pci_set_master(pdev);
|
|
||||||
|
|
||||||
rc = rtl_alloc_irq(tp);
|
rc = rtl_alloc_irq(tp);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
dev_err(&pdev->dev, "Can't allocate interrupt\n");
|
dev_err(&pdev->dev, "Can't allocate interrupt\n");
|
||||||
|
|
|
@ -1715,14 +1715,17 @@ static int netsec_netdev_init(struct net_device *ndev)
|
||||||
goto err1;
|
goto err1;
|
||||||
|
|
||||||
/* set phy power down */
|
/* set phy power down */
|
||||||
data = netsec_phy_read(priv->mii_bus, priv->phy_addr, MII_BMCR) |
|
data = netsec_phy_read(priv->mii_bus, priv->phy_addr, MII_BMCR);
|
||||||
BMCR_PDOWN;
|
netsec_phy_write(priv->mii_bus, priv->phy_addr, MII_BMCR,
|
||||||
netsec_phy_write(priv->mii_bus, priv->phy_addr, MII_BMCR, data);
|
data | BMCR_PDOWN);
|
||||||
|
|
||||||
ret = netsec_reset_hardware(priv, true);
|
ret = netsec_reset_hardware(priv, true);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err2;
|
goto err2;
|
||||||
|
|
||||||
|
/* Restore phy power state */
|
||||||
|
netsec_phy_write(priv->mii_bus, priv->phy_addr, MII_BMCR, data);
|
||||||
|
|
||||||
spin_lock_init(&priv->desc_ring[NETSEC_RING_TX].lock);
|
spin_lock_init(&priv->desc_ring[NETSEC_RING_TX].lock);
|
||||||
spin_lock_init(&priv->desc_ring[NETSEC_RING_RX].lock);
|
spin_lock_init(&priv->desc_ring[NETSEC_RING_RX].lock);
|
||||||
|
|
||||||
|
|
|
@ -1214,6 +1214,8 @@ static int sun8i_dwmac_probe(struct platform_device *pdev)
|
||||||
plat_dat->init = sun8i_dwmac_init;
|
plat_dat->init = sun8i_dwmac_init;
|
||||||
plat_dat->exit = sun8i_dwmac_exit;
|
plat_dat->exit = sun8i_dwmac_exit;
|
||||||
plat_dat->setup = sun8i_dwmac_setup;
|
plat_dat->setup = sun8i_dwmac_setup;
|
||||||
|
plat_dat->tx_fifo_size = 4096;
|
||||||
|
plat_dat->rx_fifo_size = 16384;
|
||||||
|
|
||||||
ret = sun8i_dwmac_set_syscon(&pdev->dev, plat_dat);
|
ret = sun8i_dwmac_set_syscon(&pdev->dev, plat_dat);
|
||||||
if (ret)
|
if (ret)
|
||||||
|
|
|
@ -1880,7 +1880,7 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
if (IS_ERR(lp->regs)) {
|
if (IS_ERR(lp->regs)) {
|
||||||
dev_err(&pdev->dev, "could not map Axi Ethernet regs.\n");
|
dev_err(&pdev->dev, "could not map Axi Ethernet regs.\n");
|
||||||
ret = PTR_ERR(lp->regs);
|
ret = PTR_ERR(lp->regs);
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
lp->regs_start = ethres->start;
|
lp->regs_start = ethres->start;
|
||||||
|
|
||||||
|
@ -1958,18 +1958,18 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ret = of_get_phy_mode(pdev->dev.of_node, &lp->phy_mode);
|
ret = of_get_phy_mode(pdev->dev.of_node, &lp->phy_mode);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
if (lp->switch_x_sgmii && lp->phy_mode != PHY_INTERFACE_MODE_SGMII &&
|
if (lp->switch_x_sgmii && lp->phy_mode != PHY_INTERFACE_MODE_SGMII &&
|
||||||
lp->phy_mode != PHY_INTERFACE_MODE_1000BASEX) {
|
lp->phy_mode != PHY_INTERFACE_MODE_1000BASEX) {
|
||||||
dev_err(&pdev->dev, "xlnx,switch-x-sgmii only supported with SGMII or 1000BaseX\n");
|
dev_err(&pdev->dev, "xlnx,switch-x-sgmii only supported with SGMII or 1000BaseX\n");
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find the DMA node, map the DMA registers, and decode the DMA IRQs */
|
/* Find the DMA node, map the DMA registers, and decode the DMA IRQs */
|
||||||
|
@ -1982,7 +1982,7 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
dev_err(&pdev->dev,
|
dev_err(&pdev->dev,
|
||||||
"unable to get DMA resource\n");
|
"unable to get DMA resource\n");
|
||||||
of_node_put(np);
|
of_node_put(np);
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
lp->dma_regs = devm_ioremap_resource(&pdev->dev,
|
lp->dma_regs = devm_ioremap_resource(&pdev->dev,
|
||||||
&dmares);
|
&dmares);
|
||||||
|
@ -2002,12 +2002,12 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
if (IS_ERR(lp->dma_regs)) {
|
if (IS_ERR(lp->dma_regs)) {
|
||||||
dev_err(&pdev->dev, "could not map DMA regs\n");
|
dev_err(&pdev->dev, "could not map DMA regs\n");
|
||||||
ret = PTR_ERR(lp->dma_regs);
|
ret = PTR_ERR(lp->dma_regs);
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
if ((lp->rx_irq <= 0) || (lp->tx_irq <= 0)) {
|
if ((lp->rx_irq <= 0) || (lp->tx_irq <= 0)) {
|
||||||
dev_err(&pdev->dev, "could not determine irqs\n");
|
dev_err(&pdev->dev, "could not determine irqs\n");
|
||||||
ret = -ENOMEM;
|
ret = -ENOMEM;
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Autodetect the need for 64-bit DMA pointers.
|
/* Autodetect the need for 64-bit DMA pointers.
|
||||||
|
@ -2037,7 +2037,7 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(addr_width));
|
ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(addr_width));
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(&pdev->dev, "No suitable DMA available\n");
|
dev_err(&pdev->dev, "No suitable DMA available\n");
|
||||||
goto free_netdev;
|
goto cleanup_clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check for Ethernet core IRQ (optional) */
|
/* Check for Ethernet core IRQ (optional) */
|
||||||
|
@ -2068,12 +2068,12 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
if (!lp->phy_node) {
|
if (!lp->phy_node) {
|
||||||
dev_err(&pdev->dev, "phy-handle required for 1000BaseX/SGMII\n");
|
dev_err(&pdev->dev, "phy-handle required for 1000BaseX/SGMII\n");
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto free_netdev;
|
goto cleanup_mdio;
|
||||||
}
|
}
|
||||||
lp->pcs_phy = of_mdio_find_device(lp->phy_node);
|
lp->pcs_phy = of_mdio_find_device(lp->phy_node);
|
||||||
if (!lp->pcs_phy) {
|
if (!lp->pcs_phy) {
|
||||||
ret = -EPROBE_DEFER;
|
ret = -EPROBE_DEFER;
|
||||||
goto free_netdev;
|
goto cleanup_mdio;
|
||||||
}
|
}
|
||||||
lp->phylink_config.pcs_poll = true;
|
lp->phylink_config.pcs_poll = true;
|
||||||
}
|
}
|
||||||
|
@ -2087,17 +2087,30 @@ static int axienet_probe(struct platform_device *pdev)
|
||||||
if (IS_ERR(lp->phylink)) {
|
if (IS_ERR(lp->phylink)) {
|
||||||
ret = PTR_ERR(lp->phylink);
|
ret = PTR_ERR(lp->phylink);
|
||||||
dev_err(&pdev->dev, "phylink_create error (%i)\n", ret);
|
dev_err(&pdev->dev, "phylink_create error (%i)\n", ret);
|
||||||
goto free_netdev;
|
goto cleanup_mdio;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = register_netdev(lp->ndev);
|
ret = register_netdev(lp->ndev);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(lp->dev, "register_netdev() error (%i)\n", ret);
|
dev_err(lp->dev, "register_netdev() error (%i)\n", ret);
|
||||||
goto free_netdev;
|
goto cleanup_phylink;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
cleanup_phylink:
|
||||||
|
phylink_destroy(lp->phylink);
|
||||||
|
|
||||||
|
cleanup_mdio:
|
||||||
|
if (lp->pcs_phy)
|
||||||
|
put_device(&lp->pcs_phy->dev);
|
||||||
|
if (lp->mii_bus)
|
||||||
|
axienet_mdio_teardown(lp);
|
||||||
|
of_node_put(lp->phy_node);
|
||||||
|
|
||||||
|
cleanup_clk:
|
||||||
|
clk_disable_unprepare(lp->clk);
|
||||||
|
|
||||||
free_netdev:
|
free_netdev:
|
||||||
free_netdev(ndev);
|
free_netdev(ndev);
|
||||||
|
|
||||||
|
|
|
@ -175,21 +175,23 @@ bool ipa_cmd_table_valid(struct ipa *ipa, const struct ipa_mem *mem,
|
||||||
: field_max(IP_FLTRT_FLAGS_NHASH_ADDR_FMASK);
|
: field_max(IP_FLTRT_FLAGS_NHASH_ADDR_FMASK);
|
||||||
if (mem->offset > offset_max ||
|
if (mem->offset > offset_max ||
|
||||||
ipa->mem_offset > offset_max - mem->offset) {
|
ipa->mem_offset > offset_max - mem->offset) {
|
||||||
dev_err(dev, "IPv%c %s%s table region offset too large "
|
dev_err(dev, "IPv%c %s%s table region offset too large\n",
|
||||||
"(0x%04x + 0x%04x > 0x%04x)\n",
|
ipv6 ? '6' : '4', hashed ? "hashed " : "",
|
||||||
ipv6 ? '6' : '4', hashed ? "hashed " : "",
|
route ? "route" : "filter");
|
||||||
route ? "route" : "filter",
|
dev_err(dev, " (0x%04x + 0x%04x > 0x%04x)\n",
|
||||||
ipa->mem_offset, mem->offset, offset_max);
|
ipa->mem_offset, mem->offset, offset_max);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mem->offset > ipa->mem_size ||
|
if (mem->offset > ipa->mem_size ||
|
||||||
mem->size > ipa->mem_size - mem->offset) {
|
mem->size > ipa->mem_size - mem->offset) {
|
||||||
dev_err(dev, "IPv%c %s%s table region out of range "
|
dev_err(dev, "IPv%c %s%s table region out of range\n",
|
||||||
"(0x%04x + 0x%04x > 0x%04x)\n",
|
ipv6 ? '6' : '4', hashed ? "hashed " : "",
|
||||||
ipv6 ? '6' : '4', hashed ? "hashed " : "",
|
route ? "route" : "filter");
|
||||||
route ? "route" : "filter",
|
dev_err(dev, " (0x%04x + 0x%04x > 0x%04x)\n",
|
||||||
mem->offset, mem->size, ipa->mem_size);
|
mem->offset, mem->size, ipa->mem_size);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,22 +207,36 @@ static bool ipa_cmd_header_valid(struct ipa *ipa)
|
||||||
u32 size_max;
|
u32 size_max;
|
||||||
u32 size;
|
u32 size;
|
||||||
|
|
||||||
|
/* In ipa_cmd_hdr_init_local_add() we record the offset and size
|
||||||
|
* of the header table memory area. Make sure the offset and size
|
||||||
|
* fit in the fields that need to hold them, and that the entire
|
||||||
|
* range is within the overall IPA memory range.
|
||||||
|
*/
|
||||||
offset_max = field_max(HDR_INIT_LOCAL_FLAGS_HDR_ADDR_FMASK);
|
offset_max = field_max(HDR_INIT_LOCAL_FLAGS_HDR_ADDR_FMASK);
|
||||||
if (mem->offset > offset_max ||
|
if (mem->offset > offset_max ||
|
||||||
ipa->mem_offset > offset_max - mem->offset) {
|
ipa->mem_offset > offset_max - mem->offset) {
|
||||||
dev_err(dev, "header table region offset too large "
|
dev_err(dev, "header table region offset too large\n");
|
||||||
"(0x%04x + 0x%04x > 0x%04x)\n",
|
dev_err(dev, " (0x%04x + 0x%04x > 0x%04x)\n",
|
||||||
ipa->mem_offset + mem->offset, offset_max);
|
ipa->mem_offset, mem->offset, offset_max);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_max = field_max(HDR_INIT_LOCAL_FLAGS_TABLE_SIZE_FMASK);
|
size_max = field_max(HDR_INIT_LOCAL_FLAGS_TABLE_SIZE_FMASK);
|
||||||
size = ipa->mem[IPA_MEM_MODEM_HEADER].size;
|
size = ipa->mem[IPA_MEM_MODEM_HEADER].size;
|
||||||
size += ipa->mem[IPA_MEM_AP_HEADER].size;
|
size += ipa->mem[IPA_MEM_AP_HEADER].size;
|
||||||
if (mem->offset > ipa->mem_size || size > ipa->mem_size - mem->offset) {
|
|
||||||
dev_err(dev, "header table region out of range "
|
if (size > size_max) {
|
||||||
"(0x%04x + 0x%04x > 0x%04x)\n",
|
dev_err(dev, "header table region size too large\n");
|
||||||
mem->offset, size, ipa->mem_size);
|
dev_err(dev, " (0x%04x > 0x%08x)\n", size, size_max);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (size > ipa->mem_size || mem->offset > ipa->mem_size - size) {
|
||||||
|
dev_err(dev, "header table region out of range\n");
|
||||||
|
dev_err(dev, " (0x%04x + 0x%04x > 0x%04x)\n",
|
||||||
|
mem->offset, size, ipa->mem_size);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -249,6 +249,7 @@ static const struct qmi_msg_handler ipa_server_msg_handlers[] = {
|
||||||
.decoded_size = IPA_QMI_DRIVER_INIT_COMPLETE_REQ_SZ,
|
.decoded_size = IPA_QMI_DRIVER_INIT_COMPLETE_REQ_SZ,
|
||||||
.fn = ipa_server_driver_init_complete,
|
.fn = ipa_server_driver_init_complete,
|
||||||
},
|
},
|
||||||
|
{ },
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Handle an INIT_DRIVER response message from the modem. */
|
/* Handle an INIT_DRIVER response message from the modem. */
|
||||||
|
@ -269,6 +270,7 @@ static const struct qmi_msg_handler ipa_client_msg_handlers[] = {
|
||||||
.decoded_size = IPA_QMI_INIT_DRIVER_RSP_SZ,
|
.decoded_size = IPA_QMI_INIT_DRIVER_RSP_SZ,
|
||||||
.fn = ipa_client_init_driver,
|
.fn = ipa_client_init_driver,
|
||||||
},
|
},
|
||||||
|
{ },
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Return a pointer to an init modem driver request structure, which contains
|
/* Return a pointer to an init modem driver request structure, which contains
|
||||||
|
|
|
@ -342,6 +342,10 @@ static int bcm54xx_config_init(struct phy_device *phydev)
|
||||||
bcm54xx_adjust_rxrefclk(phydev);
|
bcm54xx_adjust_rxrefclk(phydev);
|
||||||
|
|
||||||
switch (BRCM_PHY_MODEL(phydev)) {
|
switch (BRCM_PHY_MODEL(phydev)) {
|
||||||
|
case PHY_ID_BCM50610:
|
||||||
|
case PHY_ID_BCM50610M:
|
||||||
|
err = bcm54xx_config_clock_delay(phydev);
|
||||||
|
break;
|
||||||
case PHY_ID_BCM54210E:
|
case PHY_ID_BCM54210E:
|
||||||
err = bcm54210e_config_init(phydev);
|
err = bcm54210e_config_init(phydev);
|
||||||
break;
|
break;
|
||||||
|
@ -399,6 +403,11 @@ static int bcm54xx_resume(struct phy_device *phydev)
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
/* Upon exiting power down, the PHY remains in an internal reset state
|
||||||
|
* for 40us
|
||||||
|
*/
|
||||||
|
fsleep(40);
|
||||||
|
|
||||||
return bcm54xx_config_init(phydev);
|
return bcm54xx_config_init(phydev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -476,7 +476,7 @@ static void phylink_major_config(struct phylink *pl, bool restart,
|
||||||
err = pl->mac_ops->mac_finish(pl->config, pl->cur_link_an_mode,
|
err = pl->mac_ops->mac_finish(pl->config, pl->cur_link_an_mode,
|
||||||
state->interface);
|
state->interface);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
phylink_err(pl, "mac_prepare failed: %pe\n",
|
phylink_err(pl, "mac_finish failed: %pe\n",
|
||||||
ERR_PTR(err));
|
ERR_PTR(err));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -387,6 +387,8 @@ static int usbpn_probe(struct usb_interface *intf, const struct usb_device_id *i
|
||||||
|
|
||||||
err = register_netdev(dev);
|
err = register_netdev(dev);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
/* Set disconnected flag so that disconnect() returns early. */
|
||||||
|
pnd->disconnected = 1;
|
||||||
usb_driver_release_interface(&usbpn_driver, data_intf);
|
usb_driver_release_interface(&usbpn_driver, data_intf);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
|
@ -6553,7 +6553,10 @@ static int rtl_ops_init(struct r8152 *tp)
|
||||||
ops->in_nway = rtl8153_in_nway;
|
ops->in_nway = rtl8153_in_nway;
|
||||||
ops->hw_phy_cfg = r8153_hw_phy_cfg;
|
ops->hw_phy_cfg = r8153_hw_phy_cfg;
|
||||||
ops->autosuspend_en = rtl8153_runtime_enable;
|
ops->autosuspend_en = rtl8153_runtime_enable;
|
||||||
tp->rx_buf_sz = 32 * 1024;
|
if (tp->udev->speed < USB_SPEED_SUPER)
|
||||||
|
tp->rx_buf_sz = 16 * 1024;
|
||||||
|
else
|
||||||
|
tp->rx_buf_sz = 32 * 1024;
|
||||||
tp->eee_en = true;
|
tp->eee_en = true;
|
||||||
tp->eee_adv = MDIO_EEE_1000T | MDIO_EEE_100TX;
|
tp->eee_adv = MDIO_EEE_1000T | MDIO_EEE_100TX;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -302,8 +302,7 @@ static netdev_tx_t veth_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||||
if (rxq < rcv->real_num_rx_queues) {
|
if (rxq < rcv->real_num_rx_queues) {
|
||||||
rq = &rcv_priv->rq[rxq];
|
rq = &rcv_priv->rq[rxq];
|
||||||
rcv_xdp = rcu_access_pointer(rq->xdp_prog);
|
rcv_xdp = rcu_access_pointer(rq->xdp_prog);
|
||||||
if (rcv_xdp)
|
skb_record_rx_queue(skb, rxq);
|
||||||
skb_record_rx_queue(skb, rxq);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
skb_tx_timestamp(skb);
|
skb_tx_timestamp(skb);
|
||||||
|
|
|
@ -23,6 +23,8 @@
|
||||||
|
|
||||||
struct x25_state {
|
struct x25_state {
|
||||||
x25_hdlc_proto settings;
|
x25_hdlc_proto settings;
|
||||||
|
bool up;
|
||||||
|
spinlock_t up_lock; /* Protects "up" */
|
||||||
};
|
};
|
||||||
|
|
||||||
static int x25_ioctl(struct net_device *dev, struct ifreq *ifr);
|
static int x25_ioctl(struct net_device *dev, struct ifreq *ifr);
|
||||||
|
@ -104,6 +106,8 @@ static void x25_data_transmit(struct net_device *dev, struct sk_buff *skb)
|
||||||
|
|
||||||
static netdev_tx_t x25_xmit(struct sk_buff *skb, struct net_device *dev)
|
static netdev_tx_t x25_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||||
{
|
{
|
||||||
|
hdlc_device *hdlc = dev_to_hdlc(dev);
|
||||||
|
struct x25_state *x25st = state(hdlc);
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
/* There should be a pseudo header of 1 byte added by upper layers.
|
/* There should be a pseudo header of 1 byte added by upper layers.
|
||||||
|
@ -114,11 +118,19 @@ static netdev_tx_t x25_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||||
return NETDEV_TX_OK;
|
return NETDEV_TX_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
spin_lock_bh(&x25st->up_lock);
|
||||||
|
if (!x25st->up) {
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
|
kfree_skb(skb);
|
||||||
|
return NETDEV_TX_OK;
|
||||||
|
}
|
||||||
|
|
||||||
switch (skb->data[0]) {
|
switch (skb->data[0]) {
|
||||||
case X25_IFACE_DATA: /* Data to be transmitted */
|
case X25_IFACE_DATA: /* Data to be transmitted */
|
||||||
skb_pull(skb, 1);
|
skb_pull(skb, 1);
|
||||||
if ((result = lapb_data_request(dev, skb)) != LAPB_OK)
|
if ((result = lapb_data_request(dev, skb)) != LAPB_OK)
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
return NETDEV_TX_OK;
|
return NETDEV_TX_OK;
|
||||||
|
|
||||||
case X25_IFACE_CONNECT:
|
case X25_IFACE_CONNECT:
|
||||||
|
@ -147,6 +159,7 @@ static netdev_tx_t x25_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
return NETDEV_TX_OK;
|
return NETDEV_TX_OK;
|
||||||
}
|
}
|
||||||
|
@ -164,6 +177,7 @@ static int x25_open(struct net_device *dev)
|
||||||
.data_transmit = x25_data_transmit,
|
.data_transmit = x25_data_transmit,
|
||||||
};
|
};
|
||||||
hdlc_device *hdlc = dev_to_hdlc(dev);
|
hdlc_device *hdlc = dev_to_hdlc(dev);
|
||||||
|
struct x25_state *x25st = state(hdlc);
|
||||||
struct lapb_parms_struct params;
|
struct lapb_parms_struct params;
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
|
@ -190,6 +204,10 @@ static int x25_open(struct net_device *dev)
|
||||||
if (result != LAPB_OK)
|
if (result != LAPB_OK)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
spin_lock_bh(&x25st->up_lock);
|
||||||
|
x25st->up = true;
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,6 +215,13 @@ static int x25_open(struct net_device *dev)
|
||||||
|
|
||||||
static void x25_close(struct net_device *dev)
|
static void x25_close(struct net_device *dev)
|
||||||
{
|
{
|
||||||
|
hdlc_device *hdlc = dev_to_hdlc(dev);
|
||||||
|
struct x25_state *x25st = state(hdlc);
|
||||||
|
|
||||||
|
spin_lock_bh(&x25st->up_lock);
|
||||||
|
x25st->up = false;
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
|
|
||||||
lapb_unregister(dev);
|
lapb_unregister(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,15 +230,28 @@ static void x25_close(struct net_device *dev)
|
||||||
static int x25_rx(struct sk_buff *skb)
|
static int x25_rx(struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct net_device *dev = skb->dev;
|
struct net_device *dev = skb->dev;
|
||||||
|
hdlc_device *hdlc = dev_to_hdlc(dev);
|
||||||
|
struct x25_state *x25st = state(hdlc);
|
||||||
|
|
||||||
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) {
|
if ((skb = skb_share_check(skb, GFP_ATOMIC)) == NULL) {
|
||||||
dev->stats.rx_dropped++;
|
dev->stats.rx_dropped++;
|
||||||
return NET_RX_DROP;
|
return NET_RX_DROP;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lapb_data_received(dev, skb) == LAPB_OK)
|
spin_lock_bh(&x25st->up_lock);
|
||||||
return NET_RX_SUCCESS;
|
if (!x25st->up) {
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
|
kfree_skb(skb);
|
||||||
|
dev->stats.rx_dropped++;
|
||||||
|
return NET_RX_DROP;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (lapb_data_received(dev, skb) == LAPB_OK) {
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
|
return NET_RX_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
spin_unlock_bh(&x25st->up_lock);
|
||||||
dev->stats.rx_errors++;
|
dev->stats.rx_errors++;
|
||||||
dev_kfree_skb_any(skb);
|
dev_kfree_skb_any(skb);
|
||||||
return NET_RX_DROP;
|
return NET_RX_DROP;
|
||||||
|
@ -298,6 +336,8 @@ static int x25_ioctl(struct net_device *dev, struct ifreq *ifr)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
memcpy(&state(hdlc)->settings, &new_settings, size);
|
memcpy(&state(hdlc)->settings, &new_settings, size);
|
||||||
|
state(hdlc)->up = false;
|
||||||
|
spin_lock_init(&state(hdlc)->up_lock);
|
||||||
|
|
||||||
/* There's no header_ops so hard_header_len should be 0. */
|
/* There's no header_ops so hard_header_len should be 0. */
|
||||||
dev->hard_header_len = 0;
|
dev->hard_header_len = 0;
|
||||||
|
|
|
@ -189,15 +189,16 @@ int ptp_qoriq_adjfine(struct ptp_clock_info *ptp, long scaled_ppm)
|
||||||
tmr_add = ptp_qoriq->tmr_add;
|
tmr_add = ptp_qoriq->tmr_add;
|
||||||
adj = tmr_add;
|
adj = tmr_add;
|
||||||
|
|
||||||
/* calculate diff as adj*(scaled_ppm/65536)/1000000
|
/*
|
||||||
* and round() to the nearest integer
|
* Calculate diff and round() to the nearest integer
|
||||||
|
*
|
||||||
|
* diff = adj * (ppb / 1000000000)
|
||||||
|
* = adj * scaled_ppm / 65536000000
|
||||||
*/
|
*/
|
||||||
adj *= scaled_ppm;
|
diff = mul_u64_u64_div_u64(adj, scaled_ppm, 32768000000);
|
||||||
diff = div_u64(adj, 8000000);
|
diff = DIV64_U64_ROUND_UP(diff, 2);
|
||||||
diff = (diff >> 13) + ((diff >> 12) & 1);
|
|
||||||
|
|
||||||
tmr_add = neg_adj ? tmr_add - diff : tmr_add + diff;
|
tmr_add = neg_adj ? tmr_add - diff : tmr_add + diff;
|
||||||
|
|
||||||
ptp_qoriq->write(®s->ctrl_regs->tmr_add, tmr_add);
|
ptp_qoriq->write(®s->ctrl_regs->tmr_add, tmr_add);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include <linux/capability.h>
|
#include <linux/capability.h>
|
||||||
#include <linux/sched/mm.h>
|
#include <linux/sched/mm.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
|
#include <linux/percpu-refcount.h>
|
||||||
|
|
||||||
struct bpf_verifier_env;
|
struct bpf_verifier_env;
|
||||||
struct bpf_verifier_log;
|
struct bpf_verifier_log;
|
||||||
|
@ -556,7 +557,8 @@ struct bpf_tramp_progs {
|
||||||
* fentry = a set of program to run before calling original function
|
* fentry = a set of program to run before calling original function
|
||||||
* fexit = a set of program to run after original function
|
* fexit = a set of program to run after original function
|
||||||
*/
|
*/
|
||||||
int arch_prepare_bpf_trampoline(void *image, void *image_end,
|
struct bpf_tramp_image;
|
||||||
|
int arch_prepare_bpf_trampoline(struct bpf_tramp_image *tr, void *image, void *image_end,
|
||||||
const struct btf_func_model *m, u32 flags,
|
const struct btf_func_model *m, u32 flags,
|
||||||
struct bpf_tramp_progs *tprogs,
|
struct bpf_tramp_progs *tprogs,
|
||||||
void *orig_call);
|
void *orig_call);
|
||||||
|
@ -565,6 +567,8 @@ u64 notrace __bpf_prog_enter(struct bpf_prog *prog);
|
||||||
void notrace __bpf_prog_exit(struct bpf_prog *prog, u64 start);
|
void notrace __bpf_prog_exit(struct bpf_prog *prog, u64 start);
|
||||||
u64 notrace __bpf_prog_enter_sleepable(struct bpf_prog *prog);
|
u64 notrace __bpf_prog_enter_sleepable(struct bpf_prog *prog);
|
||||||
void notrace __bpf_prog_exit_sleepable(struct bpf_prog *prog, u64 start);
|
void notrace __bpf_prog_exit_sleepable(struct bpf_prog *prog, u64 start);
|
||||||
|
void notrace __bpf_tramp_enter(struct bpf_tramp_image *tr);
|
||||||
|
void notrace __bpf_tramp_exit(struct bpf_tramp_image *tr);
|
||||||
|
|
||||||
struct bpf_ksym {
|
struct bpf_ksym {
|
||||||
unsigned long start;
|
unsigned long start;
|
||||||
|
@ -583,6 +587,18 @@ enum bpf_tramp_prog_type {
|
||||||
BPF_TRAMP_REPLACE, /* more than MAX */
|
BPF_TRAMP_REPLACE, /* more than MAX */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct bpf_tramp_image {
|
||||||
|
void *image;
|
||||||
|
struct bpf_ksym ksym;
|
||||||
|
struct percpu_ref pcref;
|
||||||
|
void *ip_after_call;
|
||||||
|
void *ip_epilogue;
|
||||||
|
union {
|
||||||
|
struct rcu_head rcu;
|
||||||
|
struct work_struct work;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
struct bpf_trampoline {
|
struct bpf_trampoline {
|
||||||
/* hlist for trampoline_table */
|
/* hlist for trampoline_table */
|
||||||
struct hlist_node hlist;
|
struct hlist_node hlist;
|
||||||
|
@ -605,9 +621,8 @@ struct bpf_trampoline {
|
||||||
/* Number of attached programs. A counter per kind. */
|
/* Number of attached programs. A counter per kind. */
|
||||||
int progs_cnt[BPF_TRAMP_MAX];
|
int progs_cnt[BPF_TRAMP_MAX];
|
||||||
/* Executable image of trampoline */
|
/* Executable image of trampoline */
|
||||||
void *image;
|
struct bpf_tramp_image *cur_image;
|
||||||
u64 selector;
|
u64 selector;
|
||||||
struct bpf_ksym ksym;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct bpf_attach_target_info {
|
struct bpf_attach_target_info {
|
||||||
|
@ -691,6 +706,8 @@ void bpf_image_ksym_add(void *data, struct bpf_ksym *ksym);
|
||||||
void bpf_image_ksym_del(struct bpf_ksym *ksym);
|
void bpf_image_ksym_del(struct bpf_ksym *ksym);
|
||||||
void bpf_ksym_add(struct bpf_ksym *ksym);
|
void bpf_ksym_add(struct bpf_ksym *ksym);
|
||||||
void bpf_ksym_del(struct bpf_ksym *ksym);
|
void bpf_ksym_del(struct bpf_ksym *ksym);
|
||||||
|
int bpf_jit_charge_modmem(u32 pages);
|
||||||
|
void bpf_jit_uncharge_modmem(u32 pages);
|
||||||
#else
|
#else
|
||||||
static inline int bpf_trampoline_link_prog(struct bpf_prog *prog,
|
static inline int bpf_trampoline_link_prog(struct bpf_prog *prog,
|
||||||
struct bpf_trampoline *tr)
|
struct bpf_trampoline *tr)
|
||||||
|
@ -787,7 +804,6 @@ struct bpf_prog_aux {
|
||||||
bool func_proto_unreliable;
|
bool func_proto_unreliable;
|
||||||
bool sleepable;
|
bool sleepable;
|
||||||
bool tail_call_reachable;
|
bool tail_call_reachable;
|
||||||
enum bpf_tramp_prog_type trampoline_prog_type;
|
|
||||||
struct hlist_node tramp_hlist;
|
struct hlist_node tramp_hlist;
|
||||||
/* BTF_KIND_FUNC_PROTO for valid attach_btf_id */
|
/* BTF_KIND_FUNC_PROTO for valid attach_btf_id */
|
||||||
const struct btf_type *attach_func_proto;
|
const struct btf_type *attach_func_proto;
|
||||||
|
@ -1093,7 +1109,7 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array,
|
||||||
_ret; \
|
_ret; \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define __BPF_PROG_RUN_ARRAY(array, ctx, func, check_non_null) \
|
#define __BPF_PROG_RUN_ARRAY(array, ctx, func, check_non_null, set_cg_storage) \
|
||||||
({ \
|
({ \
|
||||||
struct bpf_prog_array_item *_item; \
|
struct bpf_prog_array_item *_item; \
|
||||||
struct bpf_prog *_prog; \
|
struct bpf_prog *_prog; \
|
||||||
|
@ -1106,7 +1122,8 @@ int bpf_prog_array_copy(struct bpf_prog_array *old_array,
|
||||||
goto _out; \
|
goto _out; \
|
||||||
_item = &_array->items[0]; \
|
_item = &_array->items[0]; \
|
||||||
while ((_prog = READ_ONCE(_item->prog))) { \
|
while ((_prog = READ_ONCE(_item->prog))) { \
|
||||||
bpf_cgroup_storage_set(_item->cgroup_storage); \
|
if (set_cg_storage) \
|
||||||
|
bpf_cgroup_storage_set(_item->cgroup_storage); \
|
||||||
_ret &= func(_prog, ctx); \
|
_ret &= func(_prog, ctx); \
|
||||||
_item++; \
|
_item++; \
|
||||||
} \
|
} \
|
||||||
|
@ -1153,10 +1170,10 @@ _out: \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define BPF_PROG_RUN_ARRAY(array, ctx, func) \
|
#define BPF_PROG_RUN_ARRAY(array, ctx, func) \
|
||||||
__BPF_PROG_RUN_ARRAY(array, ctx, func, false)
|
__BPF_PROG_RUN_ARRAY(array, ctx, func, false, true)
|
||||||
|
|
||||||
#define BPF_PROG_RUN_ARRAY_CHECK(array, ctx, func) \
|
#define BPF_PROG_RUN_ARRAY_CHECK(array, ctx, func) \
|
||||||
__BPF_PROG_RUN_ARRAY(array, ctx, func, true)
|
__BPF_PROG_RUN_ARRAY(array, ctx, func, true, false)
|
||||||
|
|
||||||
#ifdef CONFIG_BPF_SYSCALL
|
#ifdef CONFIG_BPF_SYSCALL
|
||||||
DECLARE_PER_CPU(int, bpf_prog_active);
|
DECLARE_PER_CPU(int, bpf_prog_active);
|
||||||
|
|
|
@ -43,13 +43,14 @@ static inline void macvlan_count_rx(const struct macvlan_dev *vlan,
|
||||||
if (likely(success)) {
|
if (likely(success)) {
|
||||||
struct vlan_pcpu_stats *pcpu_stats;
|
struct vlan_pcpu_stats *pcpu_stats;
|
||||||
|
|
||||||
pcpu_stats = this_cpu_ptr(vlan->pcpu_stats);
|
pcpu_stats = get_cpu_ptr(vlan->pcpu_stats);
|
||||||
u64_stats_update_begin(&pcpu_stats->syncp);
|
u64_stats_update_begin(&pcpu_stats->syncp);
|
||||||
pcpu_stats->rx_packets++;
|
pcpu_stats->rx_packets++;
|
||||||
pcpu_stats->rx_bytes += len;
|
pcpu_stats->rx_bytes += len;
|
||||||
if (multicast)
|
if (multicast)
|
||||||
pcpu_stats->rx_multicast++;
|
pcpu_stats->rx_multicast++;
|
||||||
u64_stats_update_end(&pcpu_stats->syncp);
|
u64_stats_update_end(&pcpu_stats->syncp);
|
||||||
|
put_cpu_ptr(vlan->pcpu_stats);
|
||||||
} else {
|
} else {
|
||||||
this_cpu_inc(vlan->pcpu_stats->rx_errors);
|
this_cpu_inc(vlan->pcpu_stats->rx_errors);
|
||||||
}
|
}
|
||||||
|
|
|
@ -547,4 +547,11 @@ static inline const char *mlx5_qp_state_str(int state)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int mlx5_get_qp_default_ts(struct mlx5_core_dev *dev)
|
||||||
|
{
|
||||||
|
return !MLX5_CAP_ROCE(dev, qp_ts_format) ?
|
||||||
|
MLX5_QPC_TIMESTAMP_FORMAT_FREE_RUNNING :
|
||||||
|
MLX5_QPC_TIMESTAMP_FORMAT_DEFAULT;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* MLX5_QP_H */
|
#endif /* MLX5_QP_H */
|
||||||
|
|
|
@ -360,6 +360,7 @@ enum {
|
||||||
NAPI_STATE_IN_BUSY_POLL, /* sk_busy_loop() owns this NAPI */
|
NAPI_STATE_IN_BUSY_POLL, /* sk_busy_loop() owns this NAPI */
|
||||||
NAPI_STATE_PREFER_BUSY_POLL, /* prefer busy-polling over softirq processing*/
|
NAPI_STATE_PREFER_BUSY_POLL, /* prefer busy-polling over softirq processing*/
|
||||||
NAPI_STATE_THREADED, /* The poll is performed inside its own thread*/
|
NAPI_STATE_THREADED, /* The poll is performed inside its own thread*/
|
||||||
|
NAPI_STATE_SCHED_THREADED, /* Napi is currently scheduled in threaded mode */
|
||||||
};
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -372,6 +373,7 @@ enum {
|
||||||
NAPIF_STATE_IN_BUSY_POLL = BIT(NAPI_STATE_IN_BUSY_POLL),
|
NAPIF_STATE_IN_BUSY_POLL = BIT(NAPI_STATE_IN_BUSY_POLL),
|
||||||
NAPIF_STATE_PREFER_BUSY_POLL = BIT(NAPI_STATE_PREFER_BUSY_POLL),
|
NAPIF_STATE_PREFER_BUSY_POLL = BIT(NAPI_STATE_PREFER_BUSY_POLL),
|
||||||
NAPIF_STATE_THREADED = BIT(NAPI_STATE_THREADED),
|
NAPIF_STATE_THREADED = BIT(NAPI_STATE_THREADED),
|
||||||
|
NAPIF_STATE_SCHED_THREADED = BIT(NAPI_STATE_SCHED_THREADED),
|
||||||
};
|
};
|
||||||
|
|
||||||
enum gro_result {
|
enum gro_result {
|
||||||
|
|
|
@ -227,7 +227,7 @@ struct xt_table {
|
||||||
unsigned int valid_hooks;
|
unsigned int valid_hooks;
|
||||||
|
|
||||||
/* Man behind the curtain... */
|
/* Man behind the curtain... */
|
||||||
struct xt_table_info __rcu *private;
|
struct xt_table_info *private;
|
||||||
|
|
||||||
/* Set this to THIS_MODULE if you are a module, otherwise NULL */
|
/* Set this to THIS_MODULE if you are a module, otherwise NULL */
|
||||||
struct module *me;
|
struct module *me;
|
||||||
|
@ -376,7 +376,7 @@ static inline unsigned int xt_write_recseq_begin(void)
|
||||||
* since addend is most likely 1
|
* since addend is most likely 1
|
||||||
*/
|
*/
|
||||||
__this_cpu_add(xt_recseq.sequence, addend);
|
__this_cpu_add(xt_recseq.sequence, addend);
|
||||||
smp_wmb();
|
smp_mb();
|
||||||
|
|
||||||
return addend;
|
return addend;
|
||||||
}
|
}
|
||||||
|
@ -448,9 +448,6 @@ xt_get_per_cpu_counter(struct xt_counters *cnt, unsigned int cpu)
|
||||||
|
|
||||||
struct nf_hook_ops *xt_hook_ops_alloc(const struct xt_table *, nf_hookfn *);
|
struct nf_hook_ops *xt_hook_ops_alloc(const struct xt_table *, nf_hookfn *);
|
||||||
|
|
||||||
struct xt_table_info
|
|
||||||
*xt_table_get_private_protected(const struct xt_table *table);
|
|
||||||
|
|
||||||
#ifdef CONFIG_COMPAT
|
#ifdef CONFIG_COMPAT
|
||||||
#include <net/compat.h>
|
#include <net/compat.h>
|
||||||
|
|
||||||
|
|
|
@ -285,6 +285,7 @@ struct nf_bridge_info {
|
||||||
struct tc_skb_ext {
|
struct tc_skb_ext {
|
||||||
__u32 chain;
|
__u32 chain;
|
||||||
__u16 mru;
|
__u16 mru;
|
||||||
|
bool post_ct;
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue