lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Thu, 27 Sep 2018 09:31:50 -0700 From: Eric Dumazet <edumazet@...gle.com> To: "David S . Miller" <davem@...emloft.net> Cc: netdev <netdev@...r.kernel.org>, Eric Dumazet <edumazet@...gle.com>, Michael Chan <michael.chan@...adcom.com>, Aviad Krawczyk <aviad.krawczyk@...wei.com>, Song Liu <songliubraving@...com>, Douglas Miller <dougmill@...ux.vnet.ibm.com>, Yisen Zhuang <yisen.zhuang@...wei.com>, "Michael S . Tsirkin" <mst@...hat.com>, Jason Wang <jasowang@...hat.com>, Harish Patil <harish.patil@...ium.com>, Manish Chopra <manish.chopra@...ium.com>, Netanel Belgazal <netanel@...zon.com>, Solarflare linux maintainers <linux-net-drivers@...arflare.com>, Thomas Falcon <tlfalcon@...ux.vnet.ibm.com> Subject: [PATCH net 00/11] netpoll: second round of fixes. As diagnosed by Song Liu, ndo_poll_controller() can be very dangerous on loaded hosts, since the cpu calling ndo_poll_controller() might steal all NAPI contexts (for all RX/TX queues of the NIC). This capture, showing one ksoftirqd eating all cycles can last for unlimited amount of time, since one cpu is generally not able to drain all the queues under load. It seems that all networking drivers that do use NAPI for their TX completions, should not provide a ndo_poll_controller() : Most NAPI drivers have netpoll support already handled in core networking stack, since netpoll_poll_dev() uses poll_napi(dev) to iterate through registered NAPI contexts for a device. First patch is a fix in poll_one_napi(). Then following patches take care of ten drivers. Eric Dumazet (11): netpoll: do not test NAPI_STATE_SCHED in poll_one_napi() hinic: remove ndo_poll_controller ehea: remove ndo_poll_controller net: hns: remove ndo_poll_controller virtio_net: remove ndo_poll_controller qlcnic: remove ndo_poll_controller qlogic: netxen: remove ndo_poll_controller net: ena: remove ndo_poll_controller sfc: remove ndo_poll_controller sfc-falcon: remove ndo_poll_controller ibmvnic: remove ndo_poll_controller drivers/net/ethernet/amazon/ena/ena_netdev.c | 22 --------- drivers/net/ethernet/hisilicon/hns/hns_enet.c | 18 -------- .../net/ethernet/huawei/hinic/hinic_main.c | 20 --------- drivers/net/ethernet/ibm/ehea/ehea_main.c | 14 ------ drivers/net/ethernet/ibm/ibmvnic.c | 16 ------- .../ethernet/qlogic/netxen/netxen_nic_main.c | 23 ---------- .../net/ethernet/qlogic/qlcnic/qlcnic_main.c | 45 ------------------- drivers/net/ethernet/sfc/efx.c | 26 ----------- drivers/net/ethernet/sfc/falcon/efx.c | 26 ----------- drivers/net/virtio_net.c | 14 ------ net/core/netpoll.c | 20 +-------- 11 files changed, 1 insertion(+), 243 deletions(-) -- 2.19.0.605.g01d371f741-goog
Powered by blists - more mailing lists