get:
Show a patch.

patch:
Update a patch.

put:
Update a patch.

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

{
    "id": 28404,
    "url": "http://patches.dpdk.org/api/patches/28404/?format=api",
    "web_url": "http://patches.dpdk.org/project/dpdk/patch/1504693294-2100-1-git-send-email-pbhagavatula@caviumnetworks.com/",
    "project": {
        "id": 1,
        "url": "http://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": "<1504693294-2100-1-git-send-email-pbhagavatula@caviumnetworks.com>",
    "list_archive_url": "https://inbox.dpdk.org/dev/1504693294-2100-1-git-send-email-pbhagavatula@caviumnetworks.com",
    "date": "2017-09-06T10:21:32",
    "name": "[dpdk-dev,v6,1/3] eal: introduce integer divide through reciprocal",
    "commit_ref": null,
    "pull_url": null,
    "state": "superseded",
    "archived": true,
    "hash": "3255648d591332fbaa72f0b5c067a3f806dc327b",
    "submitter": {
        "id": 768,
        "url": "http://patches.dpdk.org/api/people/768/?format=api",
        "name": "Pavan Nikhilesh",
        "email": "pbhagavatula@caviumnetworks.com"
    },
    "delegate": {
        "id": 1,
        "url": "http://patches.dpdk.org/api/users/1/?format=api",
        "username": "tmonjalo",
        "first_name": "Thomas",
        "last_name": "Monjalon",
        "email": "thomas@monjalon.net"
    },
    "mbox": "http://patches.dpdk.org/project/dpdk/patch/1504693294-2100-1-git-send-email-pbhagavatula@caviumnetworks.com/mbox/",
    "series": [],
    "comments": "http://patches.dpdk.org/api/patches/28404/comments/",
    "check": "success",
    "checks": "http://patches.dpdk.org/api/patches/28404/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 5EE8F108F;\n\tWed,  6 Sep 2017 12:22:42 +0200 (CEST)",
            "from NAM01-BY2-obe.outbound.protection.outlook.com\n\t(mail-by2nam01on0062.outbound.protection.outlook.com [104.47.34.62])\n\tby dpdk.org (Postfix) with ESMTP id AF48FFE5\n\tfor <dev@dpdk.org>; Wed,  6 Sep 2017 12:22:40 +0200 (CEST)",
            "from PBHAGAVATULA-LT.caveonetworks.com (111.93.218.67) by\n\tDM5PR07MB3465.namprd07.prod.outlook.com (10.164.153.20) with\n\tMicrosoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id\n\t15.20.13.10; Wed, 6 Sep 2017 10:22:35 +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=LtxeG0DQycFL7Ym9zaE7KJjFdXw4JEvA/CMk9X6wEMQ=;\n\tb=CZ9xGCXY9QYjScwr3LMqDBum0k/lNyuo+qlIavJ0zJwx0cU/Y+YqChdW0gCpCvDWsg+i5OzgIWdCvsUE+zIBZd9N3qjy7MnRvSp9sDl7RFVx1N1Oj81kuVmK3d0BUOoCmYQIFqJaf+9m3VDzEBjghpxeJnfG3usg1qwWsqNWIps=",
        "Authentication-Results": "spf=none (sender IP is )\n\tsmtp.mailfrom=Pavan.Bhagavatula@cavium.com; ",
        "From": "Pavan Nikhilesh <pbhagavatula@caviumnetworks.com>",
        "To": "cristian.dumitrescu@intel.com,\n\tstephen@networkplumber.org",
        "Cc": "dev@dpdk.org,\n\tPavan Bhagavatula <pbhagavatula@caviumnetworks.com>",
        "Date": "Wed,  6 Sep 2017 15:51:32 +0530",
        "Message-Id": "<1504693294-2100-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": "[111.93.218.67]",
        "X-ClientProxiedBy": "MA1PR01CA0105.INDPRD01.PROD.OUTLOOK.COM (10.174.56.149) To\n\tDM5PR07MB3465.namprd07.prod.outlook.com (10.164.153.20)",
        "X-MS-PublicTrafficType": "Email",
        "X-MS-Office365-Filtering-Correlation-Id": "e409a488-6be6-43c6-b9e0-08d4f511329c",
        "X-Microsoft-Antispam": "UriScan:; BCL:0; PCL:0;\n\tRULEID:(300000500095)(300135000095)(300000501095)(300135300095)(300000502095)(300135100095)(22001)(2017030254152)(300000503095)(300135400095)(2017052603199)(201703131423075)(201703031133081)(201702281549075)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095);\n\tSRVR:DM5PR07MB3465; ",
        "X-Microsoft-Exchange-Diagnostics": [
            "1; DM5PR07MB3465;\n\t3:1dQ0K1gXwcCU0vW76MBkvcrS8iIHjqc6JDcOKWcz1Z8BmNQo76pYkeBm8pArveey/lJdd5/k7xr443V2D27CfulocVM8emeZ1YIAXmedp/P1l+xYaXTEVxfWkTVv89Dk8fbdFnI2uPDmF3ZvxFwN+J3yd8tnTua5uRHk0lUysuU0q9H0ixGy3L/pO5PL+OjmXDPchF1nVJKnhV4Gddtlc0f+skIGvOLhZlpzmSWmfp4HrJj8jVMB0S1La+c1YClr;\n\t25:wYvvFOWZudItABujkx/vMV79h4vGPPrHydQGE/JnKQdHTIght2/vMllnkMXLafMaw12+WB3LJLqIA4/amuUA/cMb8zJ3yugJyewMduRYUA9lCeCNOmta6ee1g8Rzu0mgV8C4jzb0Y6dmonw3OX9DCjwWPkLEnbeYpUJm0qbSJFLVOxpidQobmFnL+gxdGw/QtCCi6o75/+7wrUncVmjXjboGypaL6h8gAsMSyv830C4bQ+RURH29KtoT4ECshMOAuvAFl7hzldScHb1zHWbXt4zg13Q6JwnrfPJYBxVNEtxB+kuwilZpT9V+y9uEFKFGJLajAFlqLp8cgjDBPzrPgg==;\n\t31:kSMdNDznD1FHZuMDEECybLnrgqBy52p04PD5iOtKcoxJkCJPqd8awLC7LJmsV7LOrtLS3zAnBcnGc/prtQZkbuc6e/XthQSK1HiQcH+fpQTNNCgfZS9qZOev4Vv+E51cRrIaHbdEPJrZjEGsbKtW3w2eJ0A4pylyFhQa04w2dVuKKxr2/Ypp//INCqtIH9yM6Nk6+TlulQtfZCAN3iA4UQOqUe2Nl+6KNH82EPo4qOk=",
            "1; DM5PR07MB3465;\n\t20:b2NqJRVaojnc+S92+oj3POZO41/wjseKhn4v3i4bn0QZKbEItijaseITfrfqKmMF1f1hYyXf/lH5bUt4IpXhrvHD3atHq1+2/rE3vbB4gnvgs2O3j1K+JnOBFO8fy/H/Z+ivXIYxchPUL3SoUkvKKZ5vyX1lUfOikbPFHqKZDEka/t15kgxBzqb5/R1YXhIZGNRzseJD0FYdKzoFEoQrmMnHiBvawfQ56OWJENk5dlGIFHEfjM3u9tdLiQlVfr/I97pPF1f2wuzSls0phL4bfCD8tTUloSYUCsA89aOzI939NySY4Duvz12W6Znz6p3YFtZYskAL9MyBuk9PZ8yugd91878qJ7AHfyPnIKN8do/iR/fi/dp1iZtyOswAs/ALtwB6PlIHWsm970bJkDvEa923Mqz/zZ3zM/B/W2G+8u9GR8cwf2FJWmRMpbCnsZbWyFJZtcXXS4i7FhVdWKdnPxYjtPISUNramWx1Wc4oA2VsIPmFrpyOtLlGnULE141FkBZjovMgpFWQVpd1nQDVrw+UUAQnWVkXpNjDRGxXjcNABdcp5UI3Ou+yNkwMsnrG1M7HpSpT3S7q4pcANij8MoLH2cpJ7AoSEGx3ovFVOIo=",
            "1; DM5PR07MB3465;\n\t4:fH/x08yYHwP/uhSf9Y5AO40R0EhPElW3gXj2Nx1ehMo3WUhYRdk9uBp2DcO7zEKefM1P8yNd2+VSybFbZ27T7icu4EqHQfbb3IcjDpQTtt/2bXqYIQw4Mhfofz9KeilfyWZtc0Uljk6592tW/0OPfKxbgNR9EMGDoh79UMvpQKahLDODYHwum341PnUPphE9QldaP8tVQpbBpkEqh3vwaJXP0oGhrqJ9j3gvvWhaftj5AQzQW4Q9NP25H0i9QcyZ74TT04vkIUziKETI/qFnsEsTQMPZrVocxrpXXlni2g9YQNn7YjRhkNVeJOPx3qYxcDbVoa2nIOOXZ26Oy8Cm4w==",
            "=?us-ascii?Q?1; DM5PR07MB3465;\n\t23:1y5tYrDPu8udnMAy4/slVe8BCkI+f5ppCHIrKUovV?=\n\tK5z1PQLqKllzn0UkZk2aNSNEmFenQo7lHI+4N7dwDxIYIhFcspgX1UDl/HSMIAvdriMEd8zwMR/TPDniQ+ZhpDv09U86R4dFDCBjuQ2BZwUeZPQ1tuqBUxLZgz7ab7XmBGk19SH88vsw6xKXUlrqBMC8UH4btyZE/vBxdHp0uGQoMySUobKGLYnQ7ubj9A369N+Dt7XzP/Ybsv35BQa5L8vIYWRztCFHQhdS5+jnDG7yJ2bsfsBTtqHvL0F3tUemV2GQfF9K9ANzLMxZLfqlokn1kV2NvWpDPT0LrO4HaTW2zyt5Wtfk/b6EfaoN4gu9NaKDE3unkXuMp+I7qVKypIUZI7tYZMk11DQDgvFPnZ2U2Vi/GCtMZs/58e9VugUGLhAKc4xQIFAd3kLsuu5LEHXS+vI3gvX7Kd2qKBOVMUVgTaIDtgOhqKodFOkDoSJoJ6+GxVXaSt9k4OiYWlpxUfRmN2VEtVLl86vM0feBa9IOZUKpC0TJxvH6ATW3hoGDMaxJ2g6N+A2YiL20bFQseN2f7NlaIripJwzD+LZSBM0vRPuU8HsORfaSh1jQSE+nMeDAivQqjJ7wZIblee0U+ayXBwiwL6tQueMrKEIbk0Q7W8HmUIiidIqCt9cAp+8p7wWyaVKjQydqHesjTSb0tvpB2Gy1ThS18xvm0dvENiGW1TuLh4WaBkLRJVY8Qf6OGDPv0PEdowmppbNUQq5LjCCVBOs529OF0Kk6N7d2QIWjhf3T46y/pR4fbFEV1WZ6xohVKkhYpWMx3QdMkcqxuA1AhJc4iDQ7mzGO5ToC1I2/lsAE9cavpeMe8/DuMaBpMmEbX4elXkqfL0k28S/L7L+rxICxl3d8zKqK948Y+SXpTYDDB2wzdf6zcMhWxrrYMts9GHK4WedM5O9xm+z77n/kMxSNG6OhtyN+FXn/7i9eMRZ7Xsq+MuzB62BoR6SpcG4S7JC6x/JesxwkyIyVPTrDUiP+i7s6kgRNFclJK2oIgj1AFw2L7eCCgQ+WgcYjWY6QWc6a7d73NWGyGSSfAtRWJRofZFfJgOX902lljHAqA==",
            "1; DM5PR07MB3465;\n\t6:EuJtwGTtZpBVPgbjIqtQikLBhJU9tzErcFVzs7UPk3XU49x33kx+GAQ5MKzUady+WY1eCD0PMoCqlhONeKKPPEtd4RtDRdQYCZQDJ/9XjfXeErTcMMDisli20cIbzZc1FZ6aDYj1MvOQu5wzbGdKDA2oHPqhY5rGEAdwxwllmRiy0Phs4f9yqWXtoMJjByom7qhX7Djg19yI7zf6iJ6oGmaZWUWKAanEXVLG+xB4EQIh7TUIEpYj/npqJC+kqB2T9v339n/UEXii+5UUnDD+rXlZeWrwLD1C0PCzOrbFs9SCY1pIBnUIV9Ln2bvMDLQzQjbB+qOW25R6NKB6uHPgIQ==;\n\t5:+iIv7T1V1sv7kuRNVWzCv+ZMCzQ/rdurRwLiIjy3pGu/IOX7XCwHvQ8o33Jw0amEt8RJHOlE1HtJnjeiXSj2Y9fDzc2SwukDTUAa0YDnjL7rAjwBxHAPgzma4Z/x3n2GSkEQ7ZR1yZg41tWsq5xdsWkCXWbMAs3Rz6EZXuyYU98=;\n\t24:+dgNwNXszfi8UUV5k/gUDQy+ydc/XwtL0UwbTGaGkzmp5cdlxCLJdYVi1FY/hboQGFnAoYchLXInG4Ly+oblCANKKNk4/7nNP1FvpXUl4B8=;\n\t7://+ryXLM7I2QqSY7FZSFKOs/s9cDF6/xzNdPxomYWmcSMwFUe5imsyvwk0e+MBcxnO9KnKkdI2X1p2rEf8oxOKz2AuuxBkfdJ3tOnDryM9ArwfmpLRWAM4lnmc7Eu8Lfx4r/qaF06ALbZkt+VJHNQU0PFZtGxrkwNlKdOy6H82HEVKX1jT4z/EqzyieEsRT3ZOt+EDKoaEnE/LjcisuWdLjjajfeVSkPo3+6CLgfiDk="
        ],
        "X-MS-TrafficTypeDiagnostic": "DM5PR07MB3465:",
        "X-Exchange-Antispam-Report-Test": "UriScan:(278428928389397)(228905959029699); ",
        "X-Microsoft-Antispam-PRVS": "<DM5PR07MB34650C38EF2B8AD8E81A5E4B80970@DM5PR07MB3465.namprd07.prod.outlook.com>",
        "X-Exchange-Antispam-Report-CFA-Test": "BCL:0; PCL:0;\n\tRULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(2401047)(8121501046)(5005006)(100000703101)(100105400095)(93006095)(3002001)(10201501046)(6041248)(20161123555025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123560025)(20161123564025)(20161123562025)(20161123558100)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095);\n\tSRVR:DM5PR07MB3465; BCL:0; PCL:0;\n\tRULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095);\n\tSRVR:DM5PR07MB3465; ",
        "X-Forefront-PRVS": "0422860ED4",
        "X-Forefront-Antispam-Report": "SFV:NSPM;\n\tSFS:(10009020)(6009001)(199003)(189002)(101416001)(5003940100001)(2906002)(25786009)(50986999)(189998001)(4326008)(5660300001)(33646002)(106356001)(8936002)(42186005)(3846002)(81156014)(6116002)(72206003)(53416004)(81166006)(8676002)(105586002)(42882006)(50226002)(6666003)(36756003)(48376002)(68736007)(5009440100003)(66066001)(7736002)(69596002)(50466002)(6512007)(478600001)(107886003)(110136004)(6486002)(6506006)(47776003)(97736004)(53936002)(305945005)(42262002);\n\tDIR:OUT; SFP:1101; SCL:1; SRVR:DM5PR07MB3465;\n\tH:PBHAGAVATULA-LT.caveonetworks.com; FPR:; SPF:None; PTR:InfoNoRecords;\n\tA:1; MX: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": "06 Sep 2017 10:22:35.5651\n\t(UTC)",
        "X-MS-Exchange-CrossTenant-FromEntityHeader": "Hosted",
        "X-MS-Exchange-CrossTenant-Id": "711e4ccf-2e9b-4bcf-a551-4094005b6194",
        "X-MS-Exchange-Transport-CrossTenantHeadersStamped": "DM5PR07MB3465",
        "Subject": "[dpdk-dev] [PATCH v6 1/3] 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": "From: Pavan Bhagavatula <pbhagavatula@caviumnetworks.com>\n\nIn 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>\nReviewed-by: Anatoly Burakov <anatoly.burakov@intel.com>\n---\n\nv6 changes:\n - remove cache alignment from rte_reciprocal_u{32/64}structures as they would\n be embedded in other structures.\n\nv5 changes:\n - fix test print strings\n\nv4 changes:\n - minor fix for test cases\n - fix u32 divisor generation\n\nv3 changes:\n - fix x86_32 compilation issue\n - fix improper licence in test\n\nv2 changes:\n - fix compilation issues with .map files\n - add test cases for correctness and performance\n - remove extra licence inclusion\n - fix coding style issues\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%)\n\n--\n2.7.4",
    "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 aac6fd7..90d7258 100644\n--- a/lib/librte_eal/bsdapp/eal/rte_eal_version.map\n+++ b/lib/librte_eal/bsdapp/eal/rte_eal_version.map\n@@ -237,3 +237,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.08;\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 3a8f154..2070cba 100644\n--- a/lib/librte_eal/linuxapp/eal/rte_eal_version.map\n+++ b/lib/librte_eal/linuxapp/eal/rte_eal_version.map\n@@ -242,3 +242,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.08;\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",
        "v6",
        "1/3"
    ]
}