From patchwork Fri Oct 23 09:16:51 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Stuart Haslam X-Patchwork-Id: 55470 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-wi0-f197.google.com (mail-wi0-f197.google.com [209.85.212.197]) by patches.linaro.org (Postfix) with ESMTPS id 55EDB20581 for ; Fri, 23 Oct 2015 09:20:05 +0000 (UTC) Received: by wikv3 with SMTP id v3sf8218831wik.1 for ; Fri, 23 Oct 2015 02:20:04 -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=iU9/YeyfwUqluLm14UmVW3L6LaLhGwNqezCcqsxdj/0=; b=looGGf0ECaywHyHJIQ0R53KLN7BGfy4s3T7tlnL9gaUlt9LbtU17H1uuugZk8oMSsQ o+Nu/PR1mAQVf1KYgyCk7LU/hkpMUJaz/9UXEzERVYTEKNfZiCW3jYaL6fcOE1IKDHXY t1ob0cvp7Lyuv2GrAbEeJEzVz6kp/Lgmhfk9O3v26abohC5zsDdj9eHPDSS174n0tC0g fl0tlGK45R6bb98z7m6d6RtVQcL9OTFTlqGns1Y0HZqjFxHkcMzH96Yw53x2Tw04vAcY TIzWgGOHbLeFEIa4dkdrdh+a/pCJT7+zgirtSQ+F+L4i8WulzteoVijY+NAVmG7suCKl DUkg== X-Gm-Message-State: ALoCoQllZIC2niUm6n33SBBxTodZJfZruaeGRHm5q4OXR1f9sSz0PQUU6GtYopWTPKt+xLTmSnNg X-Received: by 10.112.136.99 with SMTP id pz3mr4709969lbb.11.1445592004646; Fri, 23 Oct 2015 02:20:04 -0700 (PDT) X-BeenThere: patchwork-forward@linaro.org Received: by 10.25.210.68 with SMTP id j65ls365094lfg.86.gmail; Fri, 23 Oct 2015 02:20:04 -0700 (PDT) X-Received: by 10.25.16.92 with SMTP id f89mr6840211lfi.1.1445592004505; Fri, 23 Oct 2015 02:20:04 -0700 (PDT) Received: from mail-lf0-x22c.google.com (mail-lf0-x22c.google.com. [2a00:1450:4010:c07::22c]) by mx.google.com with ESMTPS id d5si12122826lbi.126.2015.10.23.02.20.04 for (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 23 Oct 2015 02:20:04 -0700 (PDT) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 2a00:1450:4010:c07::22c as permitted sender) client-ip=2a00:1450:4010:c07::22c; Received: by lffz202 with SMTP id z202so76710454lff.3 for ; Fri, 23 Oct 2015 02:20:04 -0700 (PDT) X-Received: by 10.25.158.211 with SMTP id h202mr383528lfe.29.1445592004322; Fri, 23 Oct 2015 02:20:04 -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 w3csp1093868lbq; Fri, 23 Oct 2015 02:20:02 -0700 (PDT) X-Received: by 10.140.152.68 with SMTP id 65mr24715970qhy.16.1445592002245; Fri, 23 Oct 2015 02:20:02 -0700 (PDT) Received: from lists.linaro.org (lists.linaro.org. [54.225.227.206]) by mx.google.com with ESMTP id 136si17677993qhc.39.2015.10.23.02.20.01; Fri, 23 Oct 2015 02:20:02 -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 CF4AC62C86; Fri, 23 Oct 2015 09:20:01 +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.5 required=5.0 tests=BAYES_00,DKIM_SIGNED, RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, T_DKIM_INVALID, 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 ACF1762C98; Fri, 23 Oct 2015 09:17:29 +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 514C662C94; Fri, 23 Oct 2015 09:17:21 +0000 (UTC) Received: from mail-wi0-f179.google.com (mail-wi0-f179.google.com [209.85.212.179]) by lists.linaro.org (Postfix) with ESMTPS id C6B0362C7A for ; Fri, 23 Oct 2015 09:17:16 +0000 (UTC) Received: by wicll6 with SMTP id ll6so22656782wic.1 for ; Fri, 23 Oct 2015 02:17:16 -0700 (PDT) X-Received: by 10.180.231.42 with SMTP id td10mr3217477wic.19.1445591836082; Fri, 23 Oct 2015 02:17:16 -0700 (PDT) Received: from e106441.emea.arm.com ([2001:41d0:a:3cb4::abcd]) by smtp.gmail.com with ESMTPSA id jt9sm6422177wjc.24.2015.10.23.02.17.15 (version=TLSv1/SSLv3 cipher=OTHER); Fri, 23 Oct 2015 02:17:15 -0700 (PDT) From: Stuart Haslam To: lng-odp@lists.linaro.org Date: Fri, 23 Oct 2015 10:16:51 +0100 Message-Id: <1445591812-10857-5-git-send-email-stuart.haslam@linaro.org> X-Mailer: git-send-email 2.1.1 In-Reply-To: <1445591812-10857-1-git-send-email-stuart.haslam@linaro.org> References: <1445591812-10857-1-git-send-email-stuart.haslam@linaro.org> X-Topics: patch Subject: [lng-odp] [PATCHv4 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-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 2a00:1450:4010:c07::22c as permitted sender) smtp.mailfrom=patch+caf_=patchwork-forward=linaro.org@linaro.org; dkim=neutral (body hash did not verify) header.i=@linaro_org.20150623.gappssmtp.com 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 | 101 ++++++++++++++++++++++++++---------------- test/validation/pktio/pktio.h | 2 + 2 files changed, 65 insertions(+), 38 deletions(-) diff --git a/test/validation/pktio/pktio.c b/test/validation/pktio/pktio.c index 14c1f5e..5fe8293 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) odp_pktio_param_init(&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) @@ -521,7 +542,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); CU_ASSERT_FATAL(pktio != ODP_PKTIO_INVALID); mtu = odp_pktio_mtu(pktio); @@ -537,7 +558,7 @@ 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); CU_ASSERT_FATAL(pktio != ODP_PKTIO_INVALID); ret = odp_pktio_promisc_mode_set(pktio, 1); @@ -565,7 +586,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); CU_ASSERT_FATAL(pktio != ODP_PKTIO_INVALID); printf("testing mac for %s\n", iface_name[0]); @@ -593,7 +614,7 @@ 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_FATAL(pktio != ODP_PKTIO_INVALID); CU_ASSERT(create_inq(pktio, ODP_QUEUE_TYPE_POLL) == 0); inq = odp_pktio_inq_getdef(pktio); @@ -621,7 +642,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_FATAL(pktio != ODP_PKTIO_INVALID); CU_ASSERT(odp_pktio_close(pktio) == 0); } @@ -660,7 +681,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_FATAL(pktio != ODP_PKTIO_INVALID); CU_ASSERT(create_inq(pktio, ODP_QUEUE_TYPE_POLL) == 0); @@ -679,7 +700,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_FATAL(pktio[i] != ODP_PKTIO_INVALID); create_inq(pktio[i], ODP_QUEUE_TYPE_SCHED); } @@ -885,6 +906,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), @@ -899,6 +922,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);