From patchwork Wed Oct 14 12:31:27 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stuart Haslam X-Patchwork-Id: 54917 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-lb0-f197.google.com (mail-lb0-f197.google.com [209.85.217.197]) by patches.linaro.org (Postfix) with ESMTPS id 8122A23012 for ; Wed, 14 Oct 2015 12:34:22 +0000 (UTC) Received: by lbwr8 with SMTP id r8sf25174602lbw.0 for ; Wed, 14 Oct 2015 05:34:21 -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=42BoNI6jE07abRRKWzVJu48sMbdzOBiBz5abpZYtTyA=; b=Vs68fZZA2j1CMtiX4E2pkoOAK5/tN8ufHWmbtOA6+9WXhkz4Je6ZWcQLe73gKeSyLL /Vl7tiYl9IqHHKcjCCrNfCbcqjKBggCb47tO85ZGzKu7ya81DTTi1mljMlQl9wJzZ8hX LdUQTce6olnrHpLbETFCPekK6lLLlR/3vZCYToFSXuxKvvUrzZAcuFUXkzzxQTtwZ3z7 +JXPYyNnOsvleYU+9ylEeHUrnU4jW8TvhqUKW2KT970Yv1Zcd5XQtGTEfSc1gLOdEvPR rNnuCDrYLZfKBdhhg4SLOYNd7aRg0hiDtNSvMFZXK3fm7TDyMa+pXeZ6YzJ7ibVhCoXV THZg== X-Gm-Message-State: ALoCoQmiEJbIBc2O/985Elr5na4jZUZfXvNMLhkDGMnarxy/mHM3gsiRDLXrgA1jEiX3SyMybHkG X-Received: by 10.180.106.197 with SMTP id gw5mr815798wib.7.1444826061480; Wed, 14 Oct 2015 05:34:21 -0700 (PDT) X-BeenThere: patchwork-forward@linaro.org Received: by 10.25.87.139 with SMTP id l133ls31749lfb.34.gmail; Wed, 14 Oct 2015 05:34:21 -0700 (PDT) X-Received: by 10.112.125.231 with SMTP id mt7mr1436808lbb.87.1444826061319; Wed, 14 Oct 2015 05:34:21 -0700 (PDT) Received: from mail-lb0-f175.google.com (mail-lb0-f175.google.com. [209.85.217.175]) by mx.google.com with ESMTPS id 33si4698686lfu.47.2015.10.14.05.34.21 for (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 14 Oct 2015 05:34:21 -0700 (PDT) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.175 as permitted sender) client-ip=209.85.217.175; Received: by lbbpp2 with SMTP id pp2so15782964lbb.0 for ; Wed, 14 Oct 2015 05:34:21 -0700 (PDT) X-Received: by 10.112.64.72 with SMTP id m8mr1432163lbs.41.1444826061182; Wed, 14 Oct 2015 05:34:21 -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.59.35 with SMTP id w3csp2705438lbq; Wed, 14 Oct 2015 05:34:20 -0700 (PDT) X-Received: by 10.140.235.16 with SMTP id g16mr3809953qhc.33.1444826060120; Wed, 14 Oct 2015 05:34:20 -0700 (PDT) Received: from lists.linaro.org (lists.linaro.org. [54.225.227.206]) by mx.google.com with ESMTP id f32si7629651qki.4.2015.10.14.05.34.19; Wed, 14 Oct 2015 05:34:20 -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 BCB4861A20; Wed, 14 Oct 2015 12:34:19 +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 4580561B7D; Wed, 14 Oct 2015 12:32:09 +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 EA50961A20; Wed, 14 Oct 2015 12:31:45 +0000 (UTC) Received: from mail-wi0-f175.google.com (mail-wi0-f175.google.com [209.85.212.175]) by lists.linaro.org (Postfix) with ESMTPS id 233C061A42 for ; Wed, 14 Oct 2015 12:31:44 +0000 (UTC) Received: by wijq8 with SMTP id q8so79466471wij.0 for ; Wed, 14 Oct 2015 05:31:43 -0700 (PDT) X-Received: by 10.194.6.106 with SMTP id z10mr3839274wjz.104.1444825901505; Wed, 14 Oct 2015 05:31:41 -0700 (PDT) Received: from e106441.emea.arm.com ([2001:41d0:a:3cb4::abcd]) by smtp.gmail.com with ESMTPSA id ly4sm9789462wjb.4.2015.10.14.05.31.40 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 14 Oct 2015 05:31:40 -0700 (PDT) From: Stuart Haslam To: lng-odp@lists.linaro.org Date: Wed, 14 Oct 2015 13:31:27 +0100 Message-Id: <1444825888-29381-5-git-send-email-stuart.haslam@linaro.org> X-Mailer: git-send-email 2.1.1 In-Reply-To: <1444825888-29381-1-git-send-email-stuart.haslam@linaro.org> References: <1444825888-29381-1-git-send-email-stuart.haslam@linaro.org> X-Topics: patch Subject: [lng-odp] [PATCHv3 4/5] 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.175 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 702e5d0..69d016e 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); printf("testing mac for %s\n", iface_name[0]); @@ -588,9 +609,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); @@ -616,7 +637,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); } @@ -655,7 +676,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); @@ -674,7 +695,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); } @@ -880,6 +901,8 @@ odp_testinfo_t pktio_suite_unsegmented[] = { ODP_TEST_INFO(pktio_test_poll_multi), ODP_TEST_INFO(pktio_test_sched_queue), ODP_TEST_INFO(pktio_test_sched_multi), + ODP_TEST_INFO(pktio_test_recv), + ODP_TEST_INFO(pktio_test_recv_multi), ODP_TEST_INFO(pktio_test_jumbo), ODP_TEST_INFO(pktio_test_mtu), ODP_TEST_INFO(pktio_test_promisc), @@ -894,6 +917,8 @@ odp_testinfo_t pktio_suite_segmented[] = { ODP_TEST_INFO(pktio_test_poll_multi), ODP_TEST_INFO(pktio_test_sched_queue), ODP_TEST_INFO(pktio_test_sched_multi), + ODP_TEST_INFO(pktio_test_recv), + ODP_TEST_INFO(pktio_test_recv_multi), ODP_TEST_INFO(pktio_test_jumbo), ODP_TEST_INFO_NULL }; diff --git a/test/validation/pktio/pktio.h b/test/validation/pktio/pktio.h index 2928dbe..f22ff25 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);