From patchwork Wed Apr 17 17:49:39 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ivan Khoronzhuk X-Patchwork-Id: 162406 Delivered-To: patch@linaro.org Received: by 2002:a02:c6d8:0:0:0:0:0 with SMTP id r24csp5787461jan; Wed, 17 Apr 2019 10:50:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqwg/m9RRRKOP6gZnynBZF28X6lE3FL/21HB87meGnvC8y1VmQ0l+mgTjuJOuvYiCUKVYt5g X-Received: by 2002:a62:8381:: with SMTP id h123mr91682675pfe.226.1555523411385; Wed, 17 Apr 2019 10:50:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555523411; cv=none; d=google.com; s=arc-20160816; b=zYweRIP7PusX3HZke5pSsNfRfLQngJ+qKT6sc/nuDB8au/4n8B1P0jfc2i9dg3ghN2 jYwtaV1T4UgH3hgSum9p4OMVJaHUIKjr+0VwQcA0Vtbv0QBK6FFkBQRPcqneG4ySkeej PEndg3T/jgrUUxs1kHW5E4EpspPL9k2h+7aX/a0k/f2QFICXOGV9xzeJexkGep+Gbvag EhBhzweeSV5J1/FTrBe0PkiwNBQF1bkEWR3d/p47RfQsjssXh1G62izONKBdEwBKUnwa D/T89ap8U6nzoCPEn6jN4N6fNQB9KK34fz+EXHr8CY4jiSPzRZP+j6zPxZ6e53jTFjxE hWOg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=hHpxRlsiI7GvZSM+HkyKQPu0rObcw/POqpTIQVI3tSA=; b=AxGlBt0aFQqbEUUf+7ufsWXE6iwffOQWAYidaUDavmlfArZd0IViYNMSNyR0wTyPyS 3BGMW3VINb8yNOvgStBbycD6/xbazYEaHbM3bcvW9mqqH9dqzDvifYh6qZ3zgNP7HMK/ VeXxuOn9b4Thz4Ro8APeiz3eN4mMxEgjsxrrODzEeXNfSdiR09owZ+UbmJ6GIwprLFP3 0qmWGKxefDw36RQnh2tW37/nAHPgGWf5skpa6e6oLBDr93mtfnrIPuGbBzkeFk3x0+M3 VtnlxapuF1TLGMsxXkU7BVdFeCLow4NFtPZNOz+F3x1EMQL6L/qBcr+YrEbzbmwowZT3 tAGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=zdILDgDt; spf=pass (google.com: best guess record for domain of netdev-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=netdev-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f13si53032132pfh.37.2019.04.17.10.50.11; Wed, 17 Apr 2019 10:50:11 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of netdev-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=zdILDgDt; spf=pass (google.com: best guess record for domain of netdev-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=netdev-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733166AbfDQRuK (ORCPT + 9 others); Wed, 17 Apr 2019 13:50:10 -0400 Received: from mail-lf1-f67.google.com ([209.85.167.67]:33929 "EHLO mail-lf1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733146AbfDQRuI (ORCPT ); Wed, 17 Apr 2019 13:50:08 -0400 Received: by mail-lf1-f67.google.com with SMTP id h5so16606248lfm.1 for ; Wed, 17 Apr 2019 10:50:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id; bh=hHpxRlsiI7GvZSM+HkyKQPu0rObcw/POqpTIQVI3tSA=; b=zdILDgDtdu3OIxwYRtN2PyPe9WxxvQu1KOtzg7eDwEvm49Z0o+2lnaNEt6ePNo+m2P yBFjM6da6vX3QnQsNjic0Hy9FjlWfcXSLo2b5ezAZ+qTrR1qBPTKj/KFPthwGiHOaPJj ZCuXA44G0qe10XhjxYfusyxE/4KloUCw2md/Tbs+40RSejCYp1/qKE4YoN0MRm0z6OZM JyRFCLFqPQWu/6UYj4cqlyzEx+FdeNvDl6u8OXLe74OVYxd7JOEGRLncU3LpjBhHBI/A kG0ulgqeBpsds+pPUwuFimDaYXlK+ssK9o9BjCoI2i68WD+BeghHf2hpTYO5xaW+hGr0 UUbg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=hHpxRlsiI7GvZSM+HkyKQPu0rObcw/POqpTIQVI3tSA=; b=OtqRnpI8y5tiJvyg1FiQ3Qr+vDkZCkA844aTiTeX0VnLxOJZxWAHSqcSjVWePjzqCk FVy9lb0rZqljw95+ySYOWXx53w8IgtH2TdtBm+3Svqtl95Lhpc/vXkWBadmgR7HSeYYU aEJJ6WHMrEZJAFhFDdumLPyHfTOg1iH/ZmP7l9zbUsGShJu1c7e/nJh+20/thn5cP/3q 8imU0hvZinHk6AP1fP+z44lqhuQEDoPl5SSnRIInmSjGB8ps7VXF8bBzQpeMEUkVyY8P eenZUHYBhZwVRe5nVCgu45eUmda2ZcUiNS2r4IKmttaRfAIn9Lkj+yQERnoFsNPgimGv z08Q== X-Gm-Message-State: APjAAAXZtKn8qcqYLijq65iQVerk2/tUpTv1jk3PbvVTJ6TI4R7ZOHQk AC9FP27XW5pB/KNOaYQGWh4nhQ== X-Received: by 2002:ac2:554a:: with SMTP id l10mr15734978lfk.45.1555523406673; Wed, 17 Apr 2019 10:50:06 -0700 (PDT) Received: from localhost.localdomain (59-201-94-178.pool.ukrtel.net. [178.94.201.59]) by smtp.gmail.com with ESMTPSA id f4sm11197173ljg.37.2019.04.17.10.50.05 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 17 Apr 2019 10:50:06 -0700 (PDT) From: Ivan Khoronzhuk To: grygorii.strashko@ti.com Cc: linux-omap@vger.kernel.org, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, ilias.apalodimas@linaro.org, hawk@kernel.org, xdp-newbies@vger.kernel.org, ast@kernel.org, aniel@iogearbox.net, jakub.kicinski@netronome.com, john.fastabend@gmail.com, Ivan Khoronzhuk Subject: [RFC PATCH 0/3] net: ethernet: ti: cpsw: Add XDP support Date: Wed, 17 Apr 2019 20:49:39 +0300 Message-Id: <20190417174942.11811-1-ivan.khoronzhuk@linaro.org> X-Mailer: git-send-email 2.17.1 Sender: netdev-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: netdev@vger.kernel.org This patchset is RFC adding XDP support for TI cpsw driver that is based on page_pool allocator. It was verified with af_xdp sockets and on xdp drop. For XDP redirect to another interface it's under verification, still not sure about all cases that should be verified. Also regular tests with iperf2 were done in order to verify impact on regular netstack performance, compared with base commit from net-next/master: 432bc230700f86801cffa5e159e05dea6229f722 It was verified with following configs enabled: CONFIG_JIT=y CONFIG_BPFILTER=y CONFIG_BPF_SYSCALL=y CONFIG_XDP_SOCKETS=y CONFIG_BPF_EVENTS=y CONFIG_HAVE_EBPF_JIT=y CONFIG_BPF_JIT=y CONFIG_CGROUP_BPF=y iperf2 UDP RX summary (packet size / Mbps): +--------------------------------------------------------------+ | pkt_size/rate | 1024 | 1500 | 1470 | 64 | 128 | 512 | 256 | |---------------+------+------+------+------+------+-----+-----| | base commit | 561 | 470 | 796 | 35 | 70.1 | 281 | 140 | |---------------+------+------+------+------+------+-----+-----| | XDP patched | 563 | 455 | 808 | 35 | 70.2 | 282 | 141 | +--------------------------------------------------------------+ iperf2 UDP TX summary (packet size / Mbps): +--------------------------------------------------------------+ | pkt_size/rate | 1024 | 1500 | 1470 | 64 | 128 | 512 | 256 | |---------------+------+------+------+------+------+-----+-----| | base commit | 555 | 666 | 736 | 34.5 | 70.3 | 281 | 140 | |---------------+------+------+------+------+------+-----+-----| | XDP patched | 558 | 696 | 759 | 35.2 | 69.2 | 279 | 140 | +--------------------------------------------------------------+ iperf2 TCP summary (window size / Mbps): +------------------------------------------------------------+ | window size/rate | 16 | 32 | 64 | 128 | 8 | 256 | |------------------+------+------+------+------+------+------| | base commit | 753 | 887 | 931 | 932 | 676 | 932 | |------------------+------+------+------+------+------+------| | XDP patched | 823 | 888 | 932 | 933 | 669 | 933 | +------------------------------------------------------------+ For af_xdp socket type verification several generic changes should be added that can be seen here (rough fixes, for samples related seems like last version of samples is more integrated with libbpf api, so should be rebased, witch I will send as RFC separately): https://github.com/ikhorn/af_xdp_stuff/tree/af_xdp_armv7 Ivan Khoronzhuk (3): net: ethernet: ti: davinci_cpdma: add dma mapped submit net: ethernet: ti: davinci_cpdma: return handler status net: ethernet: ti: cpsw: add XDP support drivers/net/ethernet/ti/Kconfig | 1 + drivers/net/ethernet/ti/cpsw.c | 552 +++++++++++++++++++++--- drivers/net/ethernet/ti/davinci_cpdma.c | 117 +++-- drivers/net/ethernet/ti/davinci_cpdma.h | 6 +- drivers/net/ethernet/ti/davinci_emac.c | 18 +- 5 files changed, 591 insertions(+), 103 deletions(-) -- 2.17.1