From patchwork Mon Oct 19 19:21:59 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bill Fischofer X-Patchwork-Id: 55250 Return-Path: X-Original-To: linaro@patches.linaro.org Delivered-To: linaro@patches.linaro.org Received: from mail-lf0-f69.google.com (mail-lf0-f69.google.com [209.85.215.69]) by patches.linaro.org (Postfix) with ESMTPS id 3DA2F22EA2 for ; Mon, 19 Oct 2015 19:24:09 +0000 (UTC) Received: by lffv3 with SMTP id v3sf45658545lff.1 for ; Mon, 19 Oct 2015 12:24:08 -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:cc: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=NCoq9pH1nsgMaQzgrhXc+UUi8RCdEjycSdcyXABA53o=; b=kUUdNuxSy2vsI4ioydlkEHECO89vMPi1TahtCT/2VY7Cw85pd3RKNO5XWm3IQjs6tG /FwSXbX1Rvx2IRH+6IC02eytEabSGVb+GhpvbvVCnv+FL7oj0xbVra3X3V3UbjJAek8Z lK73C5QKFVGWIvK1tjEIvzuE9ma31YKrCddu6VC6iPpa4pO/hbS1GZkroTX0wxXb4ca1 4TBLAXIhf0jkU3vsiQZQTsYoPZDR7x2dab876xY7EKeXPXS5CFeVK1IgORNabXCIkruv 6LdiPBcQ7NDfS05YoWCebC3LXL/IWs9MsBq8eqI+n+sp+GQ6QDWQWPynjqr2xKJAtCt+ YWeg== X-Gm-Message-State: ALoCoQnlmrMhg9G9O3/9p79cjpP3NCuyrYzjgbR1LCQzsT169Dk+f8ytNMxoY5zC0An02aoTuGNg X-Received: by 10.112.136.99 with SMTP id pz3mr7076442lbb.11.1445282648179; Mon, 19 Oct 2015 12:24:08 -0700 (PDT) X-BeenThere: patchwork-forward@linaro.org Received: by 10.25.146.9 with SMTP id u9ls618378lfd.63.gmail; Mon, 19 Oct 2015 12:24:08 -0700 (PDT) X-Received: by 10.25.148.204 with SMTP id w195mr759653lfd.77.1445282647996; Mon, 19 Oct 2015 12:24:07 -0700 (PDT) Received: from mail-lb0-f182.google.com (mail-lb0-f182.google.com. [209.85.217.182]) by mx.google.com with ESMTPS id j6si24010781lbs.87.2015.10.19.12.24.07 for (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 19 Oct 2015 12:24:07 -0700 (PDT) Received-SPF: pass (google.com: domain of patch+caf_=patchwork-forward=linaro.org@linaro.org designates 209.85.217.182 as permitted sender) client-ip=209.85.217.182; Received: by lbcao8 with SMTP id ao8so152888657lbc.3 for ; Mon, 19 Oct 2015 12:24:07 -0700 (PDT) X-Received: by 10.112.17.34 with SMTP id l2mr15564351lbd.117.1445282647792; Mon, 19 Oct 2015 12:24:07 -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 w3csp1659278lbq; Mon, 19 Oct 2015 12:24:06 -0700 (PDT) X-Received: by 10.55.31.232 with SMTP id n101mr38046702qkh.107.1445282646797; Mon, 19 Oct 2015 12:24:06 -0700 (PDT) Received: from lists.linaro.org (lists.linaro.org. [54.225.227.206]) by mx.google.com with ESMTP id g106si31554791qgd.63.2015.10.19.12.23.54; Mon, 19 Oct 2015 12:24:06 -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 7315461CEB; Mon, 19 Oct 2015 19:23:54 +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 D5D3F61C82; Mon, 19 Oct 2015 19:22:22 +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 037E061CCA; Mon, 19 Oct 2015 19:22:14 +0000 (UTC) Received: from mail-ob0-f182.google.com (mail-ob0-f182.google.com [209.85.214.182]) by lists.linaro.org (Postfix) with ESMTPS id 18B1861B21 for ; Mon, 19 Oct 2015 19:22:10 +0000 (UTC) Received: by obbzf10 with SMTP id zf10so147593895obb.2 for ; Mon, 19 Oct 2015 12:22:09 -0700 (PDT) X-Received: by 10.60.140.228 with SMTP id rj4mr19564190oeb.15.1445282529615; Mon, 19 Oct 2015 12:22:09 -0700 (PDT) Received: from Ubuntu15.localdomain (cpe-66-68-129-43.austin.res.rr.com. [66.68.129.43]) by smtp.gmail.com with ESMTPSA id s19sm15479739oet.7.2015.10.19.12.22.08 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 19 Oct 2015 12:22:09 -0700 (PDT) From: Bill Fischofer To: lng-odp@lists.linaro.org Date: Mon, 19 Oct 2015 14:21:59 -0500 Message-Id: <1445282520-28940-4-git-send-email-bill.fischofer@linaro.org> X-Mailer: git-send-email 2.1.4 In-Reply-To: <1445282520-28940-1-git-send-email-bill.fischofer@linaro.org> References: <1445282520-28940-1-git-send-email-bill.fischofer@linaro.org> X-Topics: patch Cc: Barry Spinney Subject: [lng-odp] [API-NEXT PATCHv3 3/4] linux-generic: tm: add tm to build 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: bill.fischofer@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.182 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 From: Barry Spinney This commit causes the traffic_mgr to become part of the ODP linux-generic build. Signed-off-by: Barry Spinney Signed-off-by: Bill Fischofer --- platform/linux-generic/Makefile.am | 12 +++++++ platform/linux-generic/include/odp_internal.h | 2 ++ platform/linux-generic/odp_init.c | 5 +++ platform/linux-generic/odp_packet_flags.c | 45 +++++++++++++++++++++++++++ 4 files changed, 64 insertions(+) diff --git a/platform/linux-generic/Makefile.am b/platform/linux-generic/Makefile.am index 85c976d..115ac1c 100644 --- a/platform/linux-generic/Makefile.am +++ b/platform/linux-generic/Makefile.am @@ -49,6 +49,7 @@ odpinclude_HEADERS = \ $(srcdir)/include/odp/ticketlock.h \ $(srcdir)/include/odp/time.h \ $(srcdir)/include/odp/timer.h \ + $(srcdir)/include/odp/traffic_mngr.h \ $(srcdir)/include/odp/version.h odpplatincludedir= $(includedir)/odp/plat @@ -75,6 +76,7 @@ odpplatinclude_HEADERS = \ $(srcdir)/include/odp/plat/thrmask_types.h \ $(srcdir)/include/odp/plat/ticketlock_types.h \ $(srcdir)/include/odp/plat/timer_types.h \ + $(srcdir)/include/odp/plat/traffic_mngr_types.h \ $(srcdir)/include/odp/plat/version_types.h odpapiincludedir= $(includedir)/odp/api @@ -116,6 +118,7 @@ odpapiinclude_HEADERS = \ $(top_srcdir)/include/odp/api/ticketlock.h \ $(top_srcdir)/include/odp/api/time.h \ $(top_srcdir)/include/odp/api/timer.h \ + $(top_srcdir)/include/odp/api/traffic_mngr.h \ $(top_srcdir)/include/odp/api/version.h noinst_HEADERS = \ @@ -131,16 +134,20 @@ noinst_HEADERS = \ ${srcdir}/include/odp_debug_internal.h \ ${srcdir}/include/odp_forward_typedefs_internal.h \ ${srcdir}/include/odp_internal.h \ + ${srcdir}/include/odp_name_table_internal.h \ ${srcdir}/include/odp_packet_internal.h \ ${srcdir}/include/odp_packet_io_internal.h \ ${srcdir}/include/odp_packet_io_queue.h \ ${srcdir}/include/odp_packet_netmap.h \ ${srcdir}/include/odp_packet_socket.h \ + ${srcdir}/include/odp_pkt_queue_internal.h \ ${srcdir}/include/odp_pool_internal.h \ ${srcdir}/include/odp_queue_internal.h \ ${srcdir}/include/odp_schedule_internal.h \ + ${srcdir}/include/odp_sorted_list_internal.h \ ${srcdir}/include/odp_spin_internal.h \ ${srcdir}/include/odp_timer_internal.h \ + ${srcdir}/include/odp_timer_wheel_internal.h \ ${srcdir}/include/odp_cpu_internal.h \ ${srcdir}/Makefile.inc @@ -156,6 +163,7 @@ __LIB__libodp_la_SOURCES = \ odp_event.c \ odp_init.c \ odp_impl.c \ + odp_name_table.c \ odp_packet.c \ odp_packet_flags.c \ odp_packet_io.c \ @@ -164,12 +172,14 @@ __LIB__libodp_la_SOURCES = \ pktio/netmap.c \ pktio/socket.c \ pktio/socket_mmap.c \ + odp_pkt_queue.c \ odp_pool.c \ odp_queue.c \ odp_rwlock.c \ odp_rwlock_recursive.c \ odp_schedule.c \ odp_shared_memory.c \ + odp_sorted_list.c \ odp_spinlock.c \ odp_spinlock_recursive.c \ odp_system_info.c \ @@ -178,6 +188,8 @@ __LIB__libodp_la_SOURCES = \ odp_ticketlock.c \ odp_time.c \ odp_timer.c \ + odp_timer_wheel.c \ + odp_traffic_mngr.c \ odp_version.c \ odp_weak.c \ arch/@ARCH@/odp_cpu_cycles.c diff --git a/platform/linux-generic/include/odp_internal.h b/platform/linux-generic/include/odp_internal.h index 8a1a219..a852c5b 100644 --- a/platform/linux-generic/include/odp_internal.h +++ b/platform/linux-generic/include/odp_internal.h @@ -78,6 +78,8 @@ int odp_schedule_term_local(void); int odp_timer_init_global(void); int odp_timer_disarm_all(void); +int odp_tm_init_global(void); + void _odp_flush_caches(void); #ifdef __cplusplus diff --git a/platform/linux-generic/odp_init.c b/platform/linux-generic/odp_init.c index 48d9b20..c4de602 100644 --- a/platform/linux-generic/odp_init.c +++ b/platform/linux-generic/odp_init.c @@ -71,6 +71,11 @@ int odp_init_global(const odp_init_t *params, return -1; } + if (odp_tm_init_global()) { + ODP_ERR("ODP traffic manager init failed\n"); + return -1; + } + return 0; } diff --git a/platform/linux-generic/odp_packet_flags.c b/platform/linux-generic/odp_packet_flags.c index ea308f7..bb6eeaf 100644 --- a/platform/linux-generic/odp_packet_flags.c +++ b/platform/linux-generic/odp_packet_flags.c @@ -123,6 +123,51 @@ int odp_packet_has_flow_hash(odp_packet_t pkt) return pkt_hdr->has_hash; } +odp_pkt_color_t odp_packet_color(odp_packet_t pkt) +{ + retflag(pkt, input_flags.color); +} + +void odp_packet_color_set(odp_packet_t pkt, odp_pkt_color_t color) +{ + odp_packet_hdr_t *pkt_hdr = odp_packet_hdr(pkt); + + if (pkt_hdr->input_flags.unparsed) + _odp_packet_parse(pkt_hdr); + + pkt_hdr->input_flags.color = color; +} + +odp_bool_t odp_packet_drop_eligible(odp_packet_t pkt) +{ + odp_packet_hdr_t *pkt_hdr = odp_packet_hdr(pkt); + + if (pkt_hdr->input_flags.unparsed) + _odp_packet_parse(pkt_hdr); + + return !pkt_hdr->input_flags.nodrop; +} + +void odp_packet_drop_eligible_set(odp_packet_t pkt, odp_bool_t drop) +{ + setflag(pkt, input_flags.nodrop, !drop); +} + +int8_t odp_packet_shaper_len_adjust(odp_packet_t pkt) +{ + retflag(pkt, output_flags.shaper_len_adj); +} + +void odp_packet_shaper_len_adjust_set(odp_packet_t pkt, int8_t adj) +{ + odp_packet_hdr_t *pkt_hdr = odp_packet_hdr(pkt); + + if (pkt_hdr->input_flags.unparsed) + _odp_packet_parse(pkt_hdr); + + pkt_hdr->output_flags.shaper_len_adj = adj; +} + /* Set Input Flags */ void odp_packet_has_l2_set(odp_packet_t pkt, int val)