From patchwork Fri Sep 4 09:55:46 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stuart Haslam X-Patchwork-Id: 53079 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-la0-f69.google.com (mail-la0-f69.google.com [209.85.215.69]) by patches.linaro.org (Postfix) with ESMTPS id A67852159E for ; Fri, 4 Sep 2015 10:01:19 +0000 (UTC) Received: by lagj9 with SMTP id j9sf5718260lag.0 for ; Fri, 04 Sep 2015 03:01:18 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:delivered-to:delivered-to:from:to:date :message-id:in-reply-to:references:subject:precedence:list-id :list-unsubscribe:list-archive:list-post:list-help:list-subscribe :mime-version:content-type:content-transfer-encoding:errors-to :sender:x-original-sender:x-original-authentication-results :mailing-list; bh=w7t5nce4+BPNat/fW4wqmDLopoG2y3rFLHMtB6wGp8E=; b=AaHqVjn+eZkQNQG0+v95XDojfC/ThjPCAjRvjAV2bUjJzRGwwiVQuW8WLgYfYn0R6e Y2PuNth67a16WqssE5xuMRWRqRc9PyC6AkQdmAPrg0wgZe5QNDlSqY6KfPTmyOC6xpo3 1524YzUB2Di7eHS6FdiXrEU7oSGAiOGUQFcuXfeNGZz/dmzJb3p5XC5Go0TBsntKUoXj foTQ4gKXkAAgA6aK4C1phdzuPkg0lczowvHbVzRb1XaFz26tZN1U4BbHt89l+AcbhhV5 d2mBsGSMHCoFHP5rHIU7LBQpiM1GNvOpNsQKxPWWmY76KPzVbH8ugwZQHr2sCXVRROHo 5g5w== X-Gm-Message-State: ALoCoQmETZA4k+JgrxYcAmx8q49U+WxR0T1E+4Bl4rAmENx2jOaMu4jFhlL0yVRbvndtAurOawxn X-Received: by 10.180.90.106 with SMTP id bv10mr851170wib.6.1441360878471; Fri, 04 Sep 2015 03:01:18 -0700 (PDT) X-BeenThere: patchwork-forward@linaro.org Received: by 10.152.120.198 with SMTP id le6ls278657lab.56.gmail; Fri, 04 Sep 2015 03:01:18 -0700 (PDT) X-Received: by 10.152.2.200 with SMTP id 8mr2832847law.115.1441360878298; Fri, 04 Sep 2015 03:01:18 -0700 (PDT) Received: from mail-lb0-f171.google.com (mail-lb0-f171.google.com. [209.85.217.171]) by mx.google.com with ESMTPS id l13si1824682laa.174.2015.09.04.03.01.18 for (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 04 Sep 2015 03:01:18 -0700 (PDT) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.171 as permitted sender) client-ip=209.85.217.171; Received: by lbcjc2 with SMTP id jc2so8389886lbc.0 for ; Fri, 04 Sep 2015 03:01:18 -0700 (PDT) X-Received: by 10.152.28.193 with SMTP id d1mr2889623lah.72.1441360877998; Fri, 04 Sep 2015 03:01:17 -0700 (PDT) X-Forwarded-To: patchwork-forward@linaro.org X-Forwarded-For: patch@linaro.org patchwork-forward@linaro.org Delivered-To: patch@linaro.org Received: by 10.112.164.42 with SMTP id yn10csp1840603lbb; Fri, 4 Sep 2015 03:01:16 -0700 (PDT) X-Received: by 10.140.131.134 with SMTP id 128mr4004090qhd.44.1441360876775; Fri, 04 Sep 2015 03:01:16 -0700 (PDT) Received: from lists.linaro.org (lists.linaro.org. [54.225.227.206]) by mx.google.com with ESMTP id s18si2256841qks.8.2015.09.04.03.01.15; Fri, 04 Sep 2015 03:01:16 -0700 (PDT) Received-SPF: pass (google.com: domain of lng-odp-bounces@lists.linaro.org designates 54.225.227.206 as permitted sender) client-ip=54.225.227.206; Received: by lists.linaro.org (Postfix, from userid 109) id A077161A32; Fri, 4 Sep 2015 10:01:15 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on ip-10-142-244-252 X-Spam-Level: X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, URIBL_BLOCKED autolearn=disabled version=3.4.0 Received: from [127.0.0.1] (localhost [127.0.0.1]) by lists.linaro.org (Postfix) with ESMTP id A694A61CFE; Fri, 4 Sep 2015 09:57:11 +0000 (UTC) X-Original-To: lng-odp@lists.linaro.org Delivered-To: lng-odp@lists.linaro.org Received: by lists.linaro.org (Postfix, from userid 109) id 4A2B861A30; Fri, 4 Sep 2015 09:56:58 +0000 (UTC) Received: from mail-wi0-f176.google.com (mail-wi0-f176.google.com [209.85.212.176]) by lists.linaro.org (Postfix) with ESMTPS id 87D7661A2A for ; Fri, 4 Sep 2015 09:56:24 +0000 (UTC) Received: by wicge5 with SMTP id ge5so11944040wic.0 for ; Fri, 04 Sep 2015 02:56:23 -0700 (PDT) X-Received: by 10.180.91.226 with SMTP id ch2mr5850277wib.68.1441360583797; Fri, 04 Sep 2015 02:56:23 -0700 (PDT) Received: from e106441.emea.arm.com ([2001:41d0:a:3cb4::abcd]) by smtp.gmail.com with ESMTPSA id vl1sm3083000wjc.0.2015.09.04.02.56.22 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 04 Sep 2015 02:56:23 -0700 (PDT) From: Stuart Haslam To: lng-odp@lists.linaro.org Date: Fri, 4 Sep 2015 10:55:46 +0100 Message-Id: <1441360547-18999-6-git-send-email-stuart.haslam@linaro.org> X-Mailer: git-send-email 2.1.1 In-Reply-To: <1441360547-18999-1-git-send-email-stuart.haslam@linaro.org> References: <1441360547-18999-1-git-send-email-stuart.haslam@linaro.org> X-Topics: patch Subject: [lng-odp] [PATCHv2 6/7] validation: pktio: add support for direct receive X-BeenThere: lng-odp@lists.linaro.org X-Mailman-Version: 2.1.16 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: , List-Help: , List-Subscribe: , MIME-Version: 1.0 Errors-To: lng-odp-bounces@lists.linaro.org Sender: "lng-odp" X-Removed-Original-Auth: Dkim didn't pass. X-Original-Sender: stuart.haslam@linaro.org X-Original-Authentication-Results: mx.google.com; spf=pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.171 as permitted sender) smtp.mailfrom=patch+caf_=patchwork-forward=linaro.org@linaro.org Mailing-list: list patchwork-forward@linaro.org; contact patchwork-forward+owners@linaro.org X-Google-Group-Id: 836684582541 Add a couple of tests for receiving packets directly via odp_pktio_recv(). Signed-off-by: Stuart Haslam --- test/validation/pktio/pktio.c | 103 ++++++++++++++++++++++++++---------------- test/validation/pktio/pktio.h | 2 + 2 files changed, 66 insertions(+), 39 deletions(-) diff --git a/test/validation/pktio/pktio.c b/test/validation/pktio/pktio.c index c74fab3..95c3c34 100644 --- a/test/validation/pktio/pktio.c +++ b/test/validation/pktio/pktio.c @@ -34,6 +34,7 @@ typedef struct { odp_pktio_t id; odp_queue_t outq; odp_queue_t inq; + odp_pktio_input_mode_t in_mode; } pktio_info_t; /** magic number and sequence at start of UDP payload */ @@ -250,7 +251,7 @@ static int default_pool_create(void) return 0; } -static odp_pktio_t create_pktio(int iface_idx, odp_queue_type_t q_type) +static odp_pktio_t create_pktio(int iface_idx, odp_pktio_input_mode_t mode) { odp_pktio_t pktio; odp_pktio_param_t pktio_param; @@ -258,10 +259,7 @@ static odp_pktio_t create_pktio(int iface_idx, odp_queue_type_t q_type) memset(&pktio_param, 0, sizeof(pktio_param)); - if (q_type == ODP_QUEUE_TYPE_POLL) - pktio_param.in_mode = ODP_PKTIN_MODE_POLL; - else - pktio_param.in_mode = ODP_PKTIN_MODE_SCHED; + pktio_param.in_mode = mode; pktio = odp_pktio_open(iface, pool[iface_idx], &pktio_param); if (pktio == ODP_PKTIO_INVALID) @@ -348,33 +346,41 @@ static odp_event_t queue_deq_wait_time(odp_queue_t queue, uint64_t ns) return ODP_EVENT_INVALID; } -static odp_packet_t wait_for_packet(odp_queue_t queue, +static odp_packet_t wait_for_packet(pktio_info_t *pktio_rx, uint32_t seq, uint64_t ns) { uint64_t start, now, diff; odp_event_t ev; - odp_packet_t pkt = ODP_PACKET_INVALID; + odp_packet_t pkt; uint64_t wait; start = odp_time_cycles(); wait = odp_schedule_wait_time(ns); do { - if (queue != ODP_QUEUE_INVALID && - odp_queue_type(queue) == ODP_QUEUE_TYPE_POLL) - ev = queue_deq_wait_time(queue, ns); - else - ev = odp_schedule(NULL, wait); - - if (ev != ODP_EVENT_INVALID) { - if (odp_event_type(ev) == ODP_EVENT_PACKET) { - pkt = odp_packet_from_event(ev); - if (pktio_pkt_seq(pkt) == seq) - return pkt; + pkt = ODP_PACKET_INVALID; + + if (pktio_rx->in_mode == ODP_PKTIN_MODE_RECV) { + odp_pktio_recv(pktio_rx->id, &pkt, 1); + } else { + if (pktio_rx->in_mode == ODP_PKTIN_MODE_POLL) + ev = queue_deq_wait_time(pktio_rx->inq, ns); + else + ev = odp_schedule(NULL, wait); + + if (ev != ODP_EVENT_INVALID) { + if (odp_event_type(ev) == ODP_EVENT_PACKET) + pkt = odp_packet_from_event(ev); + else + odp_event_free(ev); } + } - /* not interested in this event */ - odp_event_free(ev); + if (pkt != ODP_PACKET_INVALID) { + if (pktio_pkt_seq(pkt) == seq) + return pkt; + + odp_packet_free(pkt); } now = odp_time_cycles(); @@ -438,7 +444,7 @@ static void pktio_txrx_multi(pktio_info_t *pktio_a, pktio_info_t *pktio_b, /* and wait for them to arrive back */ for (i = 0; i < num_pkts; ++i) { - rx_pkt = wait_for_packet(pktio_b->inq, tx_seq[i], ODP_TIME_SEC); + rx_pkt = wait_for_packet(pktio_b, tx_seq[i], ODP_TIME_SEC); if (rx_pkt == ODP_PACKET_INVALID) break; @@ -450,7 +456,7 @@ static void pktio_txrx_multi(pktio_info_t *pktio_a, pktio_info_t *pktio_b, CU_ASSERT(i == num_pkts); } -static void test_txrx(odp_queue_type_t q_type, int num_pkts) +static void test_txrx(odp_pktio_input_mode_t in_mode, int num_pkts) { int ret, i, if_b; pktio_info_t pktios[MAX_NUM_IFACES]; @@ -461,17 +467,21 @@ static void test_txrx(odp_queue_type_t q_type, int num_pkts) io = &pktios[i]; io->name = iface_name[i]; - io->id = create_pktio(i, q_type); + io->id = create_pktio(i, in_mode); if (io->id == ODP_PKTIO_INVALID) { CU_FAIL("failed to open iface"); return; } - create_inq(io->id, q_type); io->outq = odp_pktio_outq_getdef(io->id); - if (q_type == ODP_QUEUE_TYPE_POLL) + io->in_mode = in_mode; + + if (in_mode == ODP_PKTIN_MODE_POLL) { + create_inq(io->id, ODP_QUEUE_TYPE_POLL); io->inq = odp_pktio_inq_getdef(io->id); - else + } else if (in_mode == ODP_PKTIN_MODE_SCHED) { + create_inq(io->id, ODP_QUEUE_TYPE_SCHED); io->inq = ODP_QUEUE_INVALID; + } ret = odp_pktio_start(io->id); CU_ASSERT(ret == 0); @@ -483,7 +493,8 @@ static void test_txrx(odp_queue_type_t q_type, int num_pkts) pktio_txrx_multi(&pktios[0], &pktios[if_b], num_pkts); for (i = 0; i < num_ifaces; ++i) { - destroy_inq(pktios[i].id); + if (in_mode != ODP_PKTIN_MODE_RECV) + destroy_inq(pktios[i].id); ret = odp_pktio_close(pktios[i].id); CU_ASSERT(ret == 0); } @@ -491,22 +502,32 @@ static void test_txrx(odp_queue_type_t q_type, int num_pkts) void pktio_test_poll_queue(void) { - test_txrx(ODP_QUEUE_TYPE_POLL, 1); + test_txrx(ODP_PKTIN_MODE_POLL, 1); } void pktio_test_poll_multi(void) { - test_txrx(ODP_QUEUE_TYPE_POLL, 4); + test_txrx(ODP_PKTIN_MODE_POLL, 4); } void pktio_test_sched_queue(void) { - test_txrx(ODP_QUEUE_TYPE_SCHED, 1); + test_txrx(ODP_PKTIN_MODE_SCHED, 1); } void pktio_test_sched_multi(void) { - test_txrx(ODP_QUEUE_TYPE_SCHED, 4); + test_txrx(ODP_PKTIN_MODE_SCHED, 4); +} + +void pktio_test_recv(void) +{ + test_txrx(ODP_PKTIN_MODE_RECV, 1); +} + +void pktio_test_recv_multi(void) +{ + test_txrx(ODP_PKTIN_MODE_RECV, 4); } void pktio_test_jumbo(void) @@ -520,7 +541,7 @@ void pktio_test_mtu(void) { int ret; int mtu; - odp_pktio_t pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + odp_pktio_t pktio = create_pktio(0, ODP_PKTIN_MODE_SCHED); mtu = odp_pktio_mtu(pktio); CU_ASSERT(mtu > 0); @@ -534,7 +555,7 @@ void pktio_test_mtu(void) void pktio_test_promisc(void) { int ret; - odp_pktio_t pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + odp_pktio_t pktio = create_pktio(0, ODP_PKTIN_MODE_SCHED); ret = odp_pktio_promisc_mode_set(pktio, 1); CU_ASSERT(0 == ret); @@ -561,7 +582,7 @@ void pktio_test_mac(void) int ret; odp_pktio_t pktio; - pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + pktio = create_pktio(0, ODP_PKTIN_MODE_SCHED); mac_len = odp_pktio_mac_addr(pktio, mac_addr, sizeof(mac_addr)); CU_ASSERT(ODPH_ETHADDR_LEN == mac_len); @@ -582,9 +603,9 @@ void pktio_test_inq_remdef(void) uint64_t wait; int i; - pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + pktio = create_pktio(0, ODP_PKTIN_MODE_SCHED); CU_ASSERT(pktio != ODP_PKTIO_INVALID); - CU_ASSERT(create_inq(pktio, ODP_QUEUE_TYPE_POLL) == 0); + CU_ASSERT(create_inq(pktio, ODP_QUEUE_TYPE_SCHED) == 0); inq = odp_pktio_inq_getdef(pktio); CU_ASSERT(inq != ODP_QUEUE_INVALID); CU_ASSERT(odp_pktio_inq_remdef(pktio) == 0); @@ -610,7 +631,7 @@ void pktio_test_open(void) /* test the sequence open->close->open->close() */ for (i = 0; i < 2; ++i) { - pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + pktio = create_pktio(0, ODP_PKTIN_MODE_SCHED); CU_ASSERT(pktio != ODP_PKTIO_INVALID); CU_ASSERT(odp_pktio_close(pktio) == 0); } @@ -649,7 +670,7 @@ void pktio_test_inq(void) { odp_pktio_t pktio; - pktio = create_pktio(0, ODP_QUEUE_TYPE_SCHED); + pktio = create_pktio(0, ODP_PKTIN_MODE_POLL); CU_ASSERT(pktio != ODP_PKTIO_INVALID); CU_ASSERT(create_inq(pktio, ODP_QUEUE_TYPE_POLL) == 0); @@ -668,7 +689,7 @@ static void pktio_test_start_stop(void) uint64_t wait = odp_schedule_wait_time(ODP_TIME_MSEC); for (i = 0; i < num_ifaces; i++) { - pktio[i] = create_pktio(i, ODP_QUEUE_TYPE_SCHED); + pktio[i] = create_pktio(i, ODP_PKTIN_MODE_SCHED); CU_ASSERT(pktio[i] != ODP_PKTIO_INVALID); create_inq(pktio[i], ODP_QUEUE_TYPE_SCHED); } @@ -873,6 +894,8 @@ CU_TestInfo pktio_suite_unsegmented[] = { _CU_TEST_INFO(pktio_test_poll_multi), _CU_TEST_INFO(pktio_test_sched_queue), _CU_TEST_INFO(pktio_test_sched_multi), + _CU_TEST_INFO(pktio_test_recv), + _CU_TEST_INFO(pktio_test_recv_multi), _CU_TEST_INFO(pktio_test_jumbo), _CU_TEST_INFO(pktio_test_mtu), _CU_TEST_INFO(pktio_test_promisc), @@ -887,6 +910,8 @@ CU_TestInfo pktio_suite_segmented[] = { _CU_TEST_INFO(pktio_test_poll_multi), _CU_TEST_INFO(pktio_test_sched_queue), _CU_TEST_INFO(pktio_test_sched_multi), + _CU_TEST_INFO(pktio_test_recv), + _CU_TEST_INFO(pktio_test_recv_multi), _CU_TEST_INFO(pktio_test_jumbo), CU_TEST_INFO_NULL }; diff --git a/test/validation/pktio/pktio.h b/test/validation/pktio/pktio.h index feaf7fb..a14287c 100644 --- a/test/validation/pktio/pktio.h +++ b/test/validation/pktio/pktio.h @@ -14,6 +14,8 @@ void pktio_test_poll_queue(void); void pktio_test_poll_multi(void); void pktio_test_sched_queue(void); void pktio_test_sched_multi(void); +void pktio_test_recv(void); +void pktio_test_recv_multi(void); void pktio_test_jumbo(void); void pktio_test_mtu(void); void pktio_test_promisc(void);