get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

GET /api/patches/28067/?format=api
HTTP 200 OK
Allow: GET, PUT, PATCH, HEAD, OPTIONS
Content-Type: application/json
Vary: Accept

{
    "id": 28067,
    "url": "https://patches.dpdk.org/api/patches/28067/?format=api",
    "web_url": "https://patches.dpdk.org/project/dpdk/patch/1504032378-5483-1-git-send-email-pbhagavatula@caviumnetworks.com/",
    "project": {
        "id": 1,
        "url": "https://patches.dpdk.org/api/projects/1/?format=api",
        "name": "DPDK",
        "link_name": "dpdk",
        "list_id": "dev.dpdk.org",
        "list_email": "dev@dpdk.org",
        "web_url": "http://core.dpdk.org",
        "scm_url": "git://dpdk.org/dpdk",
        "webscm_url": "http://git.dpdk.org/dpdk",
        "list_archive_url": "https://inbox.dpdk.org/dev",
        "list_archive_url_format": "https://inbox.dpdk.org/dev/{}",
        "commit_url_format": ""
    },
    "msgid": "<1504032378-5483-1-git-send-email-pbhagavatula@caviumnetworks.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1504032378-5483-1-git-send-email-pbhagavatula@caviumnetworks.com",
    "date": "2017-08-29T18:46:17",
    "name": "[dpdk-dev,1/2] eal: introduce integer divide through reciprocal",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "ad8ee094309934e81356c2e710d34541aa670e67",
    "submitter": {
        "id": 768,
        "url": "https://patches.dpdk.org/api/people/768/?format=api",
        "name": "Pavan Nikhilesh",
        "email": "pbhagavatula@caviumnetworks.com"
    },
    "delegate": null,
    "mbox": "https://patches.dpdk.org/project/dpdk/patch/1504032378-5483-1-git-send-email-pbhagavatula@caviumnetworks.com/mbox/",
    "series": [],
    "comments": "https://patches.dpdk.org/api/patches/28067/comments/",
    "check": "fail",
    "checks": "https://patches.dpdk.org/api/patches/28067/checks/",
    "tags": {},
    "related": [],
    "headers": {
        "Return-Path": "<dev-bounces@dpdk.org>",
        "X-Original-To": "patchwork@dpdk.org",
        "Delivered-To": "patchwork@dpdk.org",
        "Received": [
            "from [92.243.14.124] (localhost [IPv6:::1])\n\tby dpdk.org (Postfix) with ESMTP id 53B5211D4;\n\tTue, 29 Aug 2017 20:47:06 +0200 (CEST)",
            "from NAM02-SN1-obe.outbound.protection.outlook.com\n\t(mail-sn1nam02on0047.outbound.protection.outlook.com [104.47.36.47])\n\tby dpdk.org (Postfix) with ESMTP id D329AFFA\n\tfor <dev@dpdk.org>; Tue, 29 Aug 2017 20:47:04 +0200 (CEST)",
            "from localhost.localdomain (103.16.71.100) by\n\tDM5PR07MB3467.namprd07.prod.outlook.com (10.164.153.22) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id\n\t15.1.1385.9; Tue, 29 Aug 2017 18:47:01 +0000"
        ],
        "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/relaxed;\n\td=CAVIUMNETWORKS.onmicrosoft.com; s=selector1-cavium-com;\n\th=From:Date:Subject:Message-ID:Content-Type:MIME-Version;\n\tbh=U3/PIT6sLQYClFncDQU2khDTXm2Y5Ab7JOBeBA2tl/o=;\n\tb=gJyfVDH4TyCBe8IZLJ6wJN2NVsoCq/SH90uxSno3f8035AeeC35MPYZNPX8Scg2dGcOJxG8zW7GptbTIyqbvqKJn/Z+/CGZ1kXJa3yys4kQ5+QbBxa2+CiTL4hZWg8fqPRcegRk7+eOQTrpHHXCVboHVAKAiWFzQ4H+Wz8KwSUY=",
        "Authentication-Results": "spf=none (sender IP is )\n\tsmtp.mailfrom=Pavan.Bhagavatula@cavium.com; ",
        "From": "Pavan Nikhilesh <pbhagavatula@caviumnetworks.com>",
        "To": "dev@dpdk.org",
        "Cc": "cristian.dumitrescu@intel.com, stephen@networkplumber.org,\n\tPavan Nikhilesh <pbhagavatula@caviumnetworks.com>",
        "Date": "Wed, 30 Aug 2017 00:16:17 +0530",
        "Message-Id": "<1504032378-5483-1-git-send-email-pbhagavatula@caviumnetworks.com>",
        "X-Mailer": "git-send-email 2.7.4",
        "MIME-Version": "1.0",
        "Content-Type": "text/plain",
        "X-Originating-IP": "[103.16.71.100]",
        "X-ClientProxiedBy": "SG2PR06CA0166.apcprd06.prod.outlook.com (10.175.208.20) To\n\tDM5PR07MB3467.namprd07.prod.outlook.com (10.164.153.22)",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "afcc1d1f-4807-4061-b4ce-08d4ef0e570a",
        "X-Microsoft-Antispam": "UriScan:; BCL:0; PCL:0;\n\tRULEID:(300000500095)(300135000095)(300000501095)(300135300095)(300000502095)(300135100095)(22001)(2017030254152)(300000503095)(300135400095)(201703131423075)(201703031133081)(201702281549075)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095);\n\tSRVR:DM5PR07MB3467; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; DM5PR07MB3467;\n\t3:NmwnmdzUXRRTlXgZ+F3LqpShKiusVnKqsqOWGLmjgKsd1s2mvAD4LO9T7EivQDJdobGwgLosv8PB5q4pV7MiKfvLDUC/1Ruw0nHNfjudJhCkeWkEiw9c8ZqThD7R8NVQTniehaxCEg6CndNFKw93LQnC7itBWAzZ4R2GhwJcSzpBXK9W32yMTPKjznFvw/yj7ZEpMMeW0NzzFRiVLRXc9sbJw4xsgUXZgvgSVdk4hfgbWwc7cxpz8mZI8Fun8l9J;\n\t25:oeUMow2qPJN4flbUgBpT/22DVf9RWbb4NWrbC+nTpDyLz8/YUE8nn4cFlRtPWlw1IuU/OKDFtbzHwikut5WLUrXZ3/vqjBK9Bkbh7Opqpf9K1tiMCBw2mN7wPYjOPDCz9dRamiS7L2o8JCk42nz9RqaA8try0NZbRKrHjvNEhao5/3lGVxuFjn5v1m2FogStO/98YGt7QMxa/Bz6V4LusqsjOPwbtxywGa5CW2mHLOCoAOBirG6p/SB3WOqk/fPjDodwEYr8i1dRe0Ju5bsUA2+3+/fGRu3ZQgCw5izIRwgVdUm5tyKSZM8yMnkEZJBb8UpVGEOkQasmt5bJNsLxeQ==;\n\t31:IemPasT2exCDi7b2J+78qVNYNDxbe30adqVLosJW/J2JR/6x3Af2Jne5sjtI/QxENmgvShOdBMTq4NPmfK/Ou1hBzcOLTMbwJcBe6Kj+jIwCcdNHhy6NayrTosZApAq6OcM5P76m+WvKkqvvbPfd9mvgyvKUinH8iT364b3RzC53RAT9+ZlU+C09GS8yKhoQW13kdbgSireTHYyXnN2D5F2FYJZXQawTnVhp2WxhSnQ=",
            "1; DM5PR07MB3467;\n\t20:ZHnJiGTE/flx3qKaHcD2yi+rQCdCOmt+gLJgEMsuktO0Jad3Ed0tl2dlKZIAeIGVe0f4GVCfb0gurK+emhHmE7jvqx/52b1GQSuKOSlbKYGz5/VK7FMCU7UVu46Bd9tPQ0KhQNxsGY1VVbHeI/e5PgftHAhoo22e7NlzllaF4qqpqxaOPTadz+fPaYXB1CmexW3RT5OKX31v6MWTWg1xu34YyPLN8biBROweAuWVa0rHa4fzjkIXeF/S/8+MXfUI328mURo4jNu6AkdLB9S+ZQzPTdciEa7HL/sC8+XJP9UKyF7+9TUgsZaqflHNSkerwvyybupbU6zvxW78z5OmkfkccVx+6WjP9Wvx7OaT8zFeEyhCqjihQWZFC/ne6Qfmnv8uZS71ymc1wnxLqpTX1eGcfTKef/l+h45pi0lkhhFmeMA7XMnAwZAnLM1ePGCUTtXM+yPC5ihfvxTVWudkR7eUGnMlwsEBW8Fj53OejYhBcG36FUl2JWRHNFMH44Mt36pxPn/XrzIZ8xzNqwA/tiM+T8at7LgizFA0xEzev2jUWPlJMzniiTJeRJCwpnsy8eH3dBPOm0QNEDolHE/TRF+K7gWzjOdEwg0lIYFe0UI=;\n\t4:hQwoSQ3xKJJJMA6kH+j+d2n/aBJCQL/4DxTKGTltirxZ/wBhiLOWU+dJPecxHruLZM3+9ROX79SN5sWJOxgDxkOT5TsAMClFVYDcLBW1TzkK9YrhHfWVzxzRPhyiuCeVKzytgbVrS/w6/a4X5FW+EuJh5z1WCejNePtmHNXRYXYVgpaGhGitlkWRHZWL47tRu9xhrGf92wt9FzOl2CmZ1OVRAMQoKAXlAO70HCrYF+ZcLsOVBLx/Nwt38bJPQP3PRhwA7zjM4m78quvAoK9bS9YXUrHT5WTS/6DG44TMBsY=",
            "=?us-ascii?Q?1; DM5PR07MB3467;\n\t23:vNEps71JDvf6qhwzVcZQ5BbP5qx7e3jfWyPAMs070?=\n\tCX0bKHosIeg8kQd2nOcBe3nAJhLWsB4B36qhzQXkdtVyzAqNspomche047emDnYZhyfOBsozLVOIOVAGBc/tcANxGKsldx2xlZqsAAQuaq7An44Ai7pKxC/hrl5qbuU+u+E0vowP2l5+AGJIZV799MPYLncYXznx0u3L40OrvV+WHjJYNyW75zPys+GSXu041mlZ9dPP1JxxjyHDrA1foWWL9SJduJ8P6sD/YymHCqknS4/RC9LMPpHk92XSn1DAbv82cROBaRh50zHIGUCDarwfp9SVTec7KMWkhanNwYc/1Xe8CV23sUUCsoN9afwIntb6uSzqgUw3jd7bSS5UREwAUuhYUhQxRDbsXlbS80jP6HOyZaaiz0xXMBiqUJ+uL/psrs1DfDPajYvzJOR8oB9FqDVm4Oio86SzY8CvN7qG5CzWbgU50sOswJqZDKWcLz9iFnhuX82lPig9zCIfz3xoa/9IkuMC0tWWnOsnwqK73YQe2O9DPtnDPCcNSbh+CiRGHEEgv3b6exlJxG1tM9X80zQ5wqQ0yKqtOCYbOLfGkiqrhumc8QoHbJ9JctgmekRJjC/JNs+w6Gmm2tPK3b52MGQmIy+DijYY+Z5QyO4vdykh07tnYNG9kTakSLZp9ZYZOIw6i6lHIYVDEc7bJ3kDhjbWiaUatoRj6rYTZ5HDaKc4Hb3GDoZjDhGVKdfyqZlkYLEpAWo4/tehBMWhMZtQD6RL4IiBR+SqVD8bUU4Pbey7HYWa4mzSVfrsBHDlE0HiDUOe0zQ47baCk94OQBT/Hv/hbwecVje+e9lR4eGYNz2vtgtkq5jLMlDIGW2S+C4yTchg3WyHaRKYZZsIScVHLKKa3+eRce6eSvJzJM15U79lW/HVHfgnI2IyYFIws4IbSnsCXMmSulrcVO19iEAbRPmctcTgUdymIIxzyz6Kx47jzFz2tyeoY+qrkWGQ5izBKyLbrl305oLOts583FNB01YiSHXNTleBTsrsCpNzX6dMfNVRfFam6tL/9LegwwgNd1Ewq7xc2c6pI0d0+RR/StEYCIyVaESvUbdY91O/wSpwyGRwt2aEyZQvucxFaush+OvIacrpahBM5Z5r3KwTpJIt/tyBYxs1wG8CkYVRg==",
            "1; DM5PR07MB3467;\n\t6:8cI4gUTfH6VrzFDA+yEXtPP3DTZa5ReIRiwAwLvSJF1Sqtq3gIdiGOI4oSyEjpAQ0vb3qgAjViwOCk8DSzXGuIYKDfNMGtcWsC/1GVl1Xy+o0eLmOVZeTJCTpmaOBIrhoO0o0/WqznXSPolxFl++1v+sjDPPTktP9j81Pc88jbIkgkAyJOZmZ8W+tSexlcAisDaP+apfcw1myLbgPM6MBOnGVLRVWS/3VXJeMxZZgBNULYkiDBB6m9/+bJphAwzg212ASEZ6yIG9E8PTUOtElvCmedp/cTGbd8nrGMlBE10MuBHtjCTAPPWiZVMeCqDvJp2bDFEyftKrHndhUsQKdA==;\n\t5:5MHOLeDc+wybA52vb39JwZdM9eyh6X+1jhFZEDs61ncjbJoAP06fbv0ndABpoYIvdm4DPIDBDfidVvo59Ntp8WQGfyE9l1sH8V6aK0Mon3/7zCjxr4SUxHnmscJMHIN/HY4YGKrdyErunMvyJ/Qd8A==;\n\t24:/P3q+tuZXbhnLLfGh0P0s6cvlHS7S3Y1wed6byAe3Qn0cyWzGp3Lh8aoaM4OOT+l00hI2AvCPgcM6X5k1hufSzRN4B036zzbwRvHUcBPC9Q=;\n\t7:9stBWuBHmbYSdqtqoIhcvFiIT2wrYQniZfpopKTUwqVlTdvNAMigO1o32sA8jd5xGVVMQwdQ8kpaeOoxH2tNlQpJj6GDAkOxKdgdcAzmtDP0KywT545qOebo8YAhy+h+N00qQV+uz8jah+ci2uWvolI2LuYM6Z6cbV29aYCzL0kCGvOKx7vE5ORxuD68d4QexMscwFm7hj5Ls6ULIi3Sj9HnItV+fam/FeJrO7+4cs0="
        ],
        "X-MS-TrafficTypeDiagnostic": "DM5PR07MB3467:",
        "X-Exchange-Antispam-Report-Test": "UriScan:(278428928389397);",
        "X-Microsoft-Antispam-PRVS": "<DM5PR07MB3467BCD620DD48B3295D72EB809F0@DM5PR07MB3467.namprd07.prod.outlook.com>",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(601004)(2401047)(5005006)(8121501046)(93006095)(3002001)(100000703101)(100105400095)(10201501046)(6041248)(20161123558100)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123560025)(20161123555025)(20161123562025)(20161123564025)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095);\n\tSRVR:DM5PR07MB3467; BCL:0; PCL:0;\n\tRULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095);\n\tSRVR:DM5PR07MB3467; ",
        "X-Forefront-PRVS": "0414DF926F",
        "X-Forefront-Antispam-Report": "SFV:NSPM;\n\tSFS:(10009020)(7370300001)(4630300001)(6069001)(6009001)(189002)(199003)(6506006)(6486002)(6512007)(305945005)(7736002)(6116002)(101416001)(7350300001)(3846002)(2906002)(6916009)(42882006)(6666003)(42186005)(50986999)(5660300001)(25786009)(110136004)(2361001)(2351001)(33646002)(68736007)(478600001)(72206003)(107886003)(36756003)(106356001)(105586002)(47776003)(189998001)(53936002)(97736004)(8676002)(48376002)(4326008)(81156014)(81166006)(50226002)(50466002)(5003940100001)(66066001)(42262002);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:DM5PR07MB3467; H:localhost.localdomain;\n\tFPR:; \n\tSPF:None; PTR:InfoNoRecords; MX:1; A:1; LANG:en; ",
        "Received-SPF": "None (protection.outlook.com: cavium.com does not designate\n\tpermitted sender hosts)",
        "SpamDiagnosticOutput": "1:99",
        "SpamDiagnosticMetadata": "NSPM",
        "X-OriginatorOrg": "caviumnetworks.com",
        "X-MS-Exchange-CrossTenant-OriginalArrivalTime": "29 Aug 2017 18:47:01.7326\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DM5PR07MB3467",
        "Subject": "[dpdk-dev] [PATCH 1/2] eal: introduce integer divide through\n\treciprocal",
        "X-BeenThere": "dev@dpdk.org",
        "X-Mailman-Version": "2.1.15",
        "Precedence": "list",
        "List-Id": "DPDK patches and discussions <dev.dpdk.org>",
        "List-Unsubscribe": "<http://dpdk.org/ml/options/dev>,\n\t<mailto:dev-request@dpdk.org?subject=unsubscribe>",
        "List-Archive": "<http://dpdk.org/ml/archives/dev/>",
        "List-Post": "<mailto:dev@dpdk.org>",
        "List-Help": "<mailto:dev-request@dpdk.org?subject=help>",
        "List-Subscribe": "<http://dpdk.org/ml/listinfo/dev>,\n\t<mailto:dev-request@dpdk.org?subject=subscribe>",
        "Errors-To": "dev-bounces@dpdk.org",
        "Sender": "\"dev\" <dev-bounces@dpdk.org>"
    },
    "content": "In some use cases of integer division, denominator remains constant and\nnumerator varies. It is possible to optimize division for such specific\nscenarios.\n\nThe librte_sched uses rte_reciprocal to optimize division so, moving it to\neal/common would allow other libraries and applications to use it.\n\nSigned-off-by: Pavan Nikhilesh <pbhagavatula@caviumnetworks.com>\n---\n lib/librte_eal/bsdapp/eal/Makefile                               | 1 +\n lib/librte_eal/bsdapp/eal/rte_eal_version.map                    | 7 +++++++\n lib/librte_eal/common/Makefile                                   | 1 +\n lib/{librte_sched => librte_eal/common/include}/rte_reciprocal.h | 6 ++++--\n lib/{librte_sched => librte_eal/common}/rte_reciprocal.c         | 6 ++++--\n lib/librte_eal/linuxapp/eal/Makefile                             | 1 +\n lib/librte_eal/linuxapp/eal/rte_eal_version.map                  | 7 +++++++\n lib/librte_sched/Makefile                                        | 2 --\n lib/librte_sched/rte_sched.c                                     | 2 +-\n 9 files changed, 26 insertions(+), 7 deletions(-)\n rename lib/{librte_sched => librte_eal/common/include}/rte_reciprocal.h (87%)\n rename lib/{librte_sched => librte_eal/common}/rte_reciprocal.c (96%)",
    "diff": "diff --git a/lib/librte_eal/bsdapp/eal/Makefile b/lib/librte_eal/bsdapp/eal/Makefile\nindex 005019e..56f9804 100644\n--- a/lib/librte_eal/bsdapp/eal/Makefile\n+++ b/lib/librte_eal/bsdapp/eal/Makefile\n@@ -88,6 +88,7 @@ SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += malloc_elem.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += malloc_heap.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += rte_keepalive.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += rte_service.c\n+SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += rte_reciprocal.c\n \n # from arch dir\n SRCS-$(CONFIG_RTE_EXEC_ENV_BSDAPP) += rte_cpuflags.c\ndiff --git a/lib/librte_eal/bsdapp/eal/rte_eal_version.map b/lib/librte_eal/bsdapp/eal/rte_eal_version.map\nindex 79e7d31..00d5f60 100644\n--- a/lib/librte_eal/bsdapp/eal/rte_eal_version.map\n+++ b/lib/librte_eal/bsdapp/eal/rte_eal_version.map\n@@ -238,3 +238,10 @@ EXPERIMENTAL {\n \trte_service_unregister;\n \n } DPDK_17.08;\n+\n+DPDK_17.11 {\n+\tglobal:\n+\n+\trte_reciprocal_value;\n+\n+} DPDK_17.11;\ndiff --git a/lib/librte_eal/common/Makefile b/lib/librte_eal/common/Makefile\nindex e8fd67a..a680b2d 100644\n--- a/lib/librte_eal/common/Makefile\n+++ b/lib/librte_eal/common/Makefile\n@@ -42,6 +42,7 @@ INC += rte_hexdump.h rte_devargs.h rte_bus.h rte_dev.h rte_vdev.h\n INC += rte_pci_dev_feature_defs.h rte_pci_dev_features.h\n INC += rte_malloc.h rte_keepalive.h rte_time.h\n INC += rte_service.h rte_service_component.h\n+INC += rte_reciprocal.h\n \n GENERIC_INC := rte_atomic.h rte_byteorder.h rte_cycles.h rte_prefetch.h\n GENERIC_INC += rte_spinlock.h rte_memcpy.h rte_cpuflags.h rte_rwlock.h\ndiff --git a/lib/librte_sched/rte_reciprocal.h b/lib/librte_eal/common/include/rte_reciprocal.h\nsimilarity index 87%\nrename from lib/librte_sched/rte_reciprocal.h\nrename to lib/librte_eal/common/include/rte_reciprocal.h\nindex 5e21f09..b6d752f 100644\n--- a/lib/librte_sched/rte_reciprocal.h\n+++ b/lib/librte_eal/common/include/rte_reciprocal.h\n@@ -29,13 +29,15 @@ struct rte_reciprocal {\n \tuint8_t sh1, sh2;\n };\n \n-static inline uint32_t rte_reciprocal_divide(uint32_t a, struct rte_reciprocal R)\n+static inline uint32_t\n+rte_reciprocal_divide(uint32_t a, struct rte_reciprocal R)\n {\n \tuint32_t t = (uint32_t)(((uint64_t)a * R.m) >> 32);\n \n \treturn (t + ((a - t) >> R.sh1)) >> R.sh2;\n }\n \n-struct rte_reciprocal rte_reciprocal_value(uint32_t d);\n+struct rte_reciprocal\n+rte_reciprocal_value(uint32_t d);\n \n #endif /* _RTE_RECIPROCAL_H_ */\ndiff --git a/lib/librte_sched/rte_reciprocal.c b/lib/librte_eal/common/rte_reciprocal.c\nsimilarity index 96%\nrename from lib/librte_sched/rte_reciprocal.c\nrename to lib/librte_eal/common/rte_reciprocal.c\nindex 652f023..7ab99b4 100644\n--- a/lib/librte_sched/rte_reciprocal.c\n+++ b/lib/librte_eal/common/rte_reciprocal.c\n@@ -41,7 +41,8 @@\n /* find largest set bit.\n  * portable and slow but does not matter for this usage.\n  */\n-static inline int fls(uint32_t x)\n+static inline int\n+fls(uint32_t x)\n {\n \tint b;\n \n@@ -53,7 +54,8 @@ static inline int fls(uint32_t x)\n \treturn 0;\n }\n \n-struct rte_reciprocal rte_reciprocal_value(uint32_t d)\n+struct rte_reciprocal\n+rte_reciprocal_value(uint32_t d)\n {\n \tstruct rte_reciprocal R;\n \tuint64_t m;\ndiff --git a/lib/librte_eal/linuxapp/eal/Makefile b/lib/librte_eal/linuxapp/eal/Makefile\nindex 90bca4d..98f3b8e 100644\n--- a/lib/librte_eal/linuxapp/eal/Makefile\n+++ b/lib/librte_eal/linuxapp/eal/Makefile\n@@ -100,6 +100,7 @@ SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += malloc_elem.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += malloc_heap.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += rte_keepalive.c\n SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += rte_service.c\n+SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += rte_reciprocal.c\n \n # from arch dir\n SRCS-$(CONFIG_RTE_EXEC_ENV_LINUXAPP) += rte_cpuflags.c\ndiff --git a/lib/librte_eal/linuxapp/eal/rte_eal_version.map b/lib/librte_eal/linuxapp/eal/rte_eal_version.map\nindex 468c706..ac68fb3 100644\n--- a/lib/librte_eal/linuxapp/eal/rte_eal_version.map\n+++ b/lib/librte_eal/linuxapp/eal/rte_eal_version.map\n@@ -243,3 +243,10 @@ EXPERIMENTAL {\n \trte_service_unregister;\n \n } DPDK_17.08;\n+\n+DPDK_17.11 {\n+\tglobal:\n+\n+\trte_reciprocal_value;\n+\n+} DPDK_17.11;\ndiff --git a/lib/librte_sched/Makefile b/lib/librte_sched/Makefile\nindex 18274e7..569656b 100644\n--- a/lib/librte_sched/Makefile\n+++ b/lib/librte_sched/Makefile\n@@ -52,10 +52,8 @@ LIBABIVER := 1\n # all source are stored in SRCS-y\n #\n SRCS-$(CONFIG_RTE_LIBRTE_SCHED) += rte_sched.c rte_red.c rte_approx.c\n-SRCS-$(CONFIG_RTE_LIBRTE_SCHED) += rte_reciprocal.c\n \n # install includes\n SYMLINK-$(CONFIG_RTE_LIBRTE_SCHED)-include := rte_sched.h rte_bitmap.h rte_sched_common.h rte_red.h rte_approx.h\n-SYMLINK-$(CONFIG_RTE_LIBRTE_SCHED)-include += rte_reciprocal.h\n \n include $(RTE_SDK)/mk/rte.lib.mk\ndiff --git a/lib/librte_sched/rte_sched.c b/lib/librte_sched/rte_sched.c\nindex b7cba11..3b8ccaa 100644\n--- a/lib/librte_sched/rte_sched.c\n+++ b/lib/librte_sched/rte_sched.c\n@@ -42,12 +42,12 @@\n #include <rte_prefetch.h>\n #include <rte_branch_prediction.h>\n #include <rte_mbuf.h>\n+#include <rte_reciprocal.h>\n \n #include \"rte_sched.h\"\n #include \"rte_bitmap.h\"\n #include \"rte_sched_common.h\"\n #include \"rte_approx.h\"\n-#include \"rte_reciprocal.h\"\n \n #ifdef __INTEL_COMPILER\n #pragma warning(disable:2259) /* conversion may lose significant bits */\n",
    "prefixes": [
        "dpdk-dev",
        "1/2"
    ]
}