From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from NAM01-BN3-obe.outbound.protection.outlook.com (mail-bn3nam01on0067.outbound.protection.outlook.com [104.47.33.67]) by dpdk.org (Postfix) with ESMTP id DB05BFA33 for ; Sun, 4 Dec 2016 13:44:08 +0100 (CET) Received: from DM5PR03CA0016.namprd03.prod.outlook.com (10.175.104.26) by BY2PR0301MB0741.namprd03.prod.outlook.com (10.160.63.19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.747.13; Sun, 4 Dec 2016 12:44:07 +0000 Received: from BL2FFO11FD048.protection.gbl (2a01:111:f400:7c09::157) by DM5PR03CA0016.outlook.office365.com (2603:10b6:3:118::26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id 15.1.761.9 via Frontend Transport; Sun, 4 Dec 2016 12:44:06 +0000 Authentication-Results: spf=fail (sender IP is 192.88.168.50) smtp.mailfrom=nxp.com; nxp.com; dkim=none (message not signed) header.d=none;nxp.com; dmarc=fail action=none header.from=nxp.com;nxp.com; dkim=none (message not signed) header.d=none; Received-SPF: Fail (protection.outlook.com: domain of nxp.com does not designate 192.88.168.50 as permitted sender) receiver=protection.outlook.com; client-ip=192.88.168.50; helo=tx30smr01.am.freescale.net; Received: from tx30smr01.am.freescale.net (192.88.168.50) by BL2FFO11FD048.mail.protection.outlook.com (10.173.161.210) with Microsoft SMTP Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.734.4 via Frontend Transport; Sun, 4 Dec 2016 12:44:06 +0000 X-IncomingTopHeaderMarker: OriginalChecksum:; UpperCasedChecksum:; SizeAsReceived:708; Count:10 Received: from bf-netperf1.idc ([10.232.134.28]) by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id uB4ChXbE032240; Sun, 4 Dec 2016 05:44:04 -0700 From: Hemant Agrawal To: CC: , , , Hemant Agrawal Date: Sun, 4 Dec 2016 23:47:06 +0530 Message-ID: <1480875447-23680-12-git-send-email-hemant.agrawal@nxp.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1480875447-23680-1-git-send-email-hemant.agrawal@nxp.com> References: <1480875447-23680-1-git-send-email-hemant.agrawal@nxp.com> X-IncomingHeaderCount: 10 X-EOPAttributedMessage: 0 X-Matching-Connectors: 131253290467411348; (91ab9b29-cfa4-454e-5278-08d120cd25b8); () X-Forefront-Antispam-Report: CIP:192.88.168.50; IPV:NLI; CTRY:US; EFV:NLI; SFV:NSPM; SFS:(10009020)(6009001)(7916002)(2980300002)(1110001)(1109001)(336004)(339900001)(199003)(189002)(104016004)(50226002)(39380400001)(81156014)(76176999)(39400400001)(5003940100001)(189998001)(38730400001)(86362001)(36756003)(50986999)(39410400001)(47776003)(8936002)(8666005)(81166006)(8676002)(356003)(68736007)(110136003)(2351001)(305945005)(6916009)(33646002)(92566002)(2950100002)(97736004)(7846002)(106466001)(105606002)(5660300001)(50466002)(626004)(2906002)(77096006)(4326007)(85426001)(39450400002)(48376002)(7059030); DIR:OUT; SFP:1101; SCL:1; SRVR:BY2PR0301MB0741; H:tx30smr01.am.freescale.net; FPR:; SPF:Fail; PTR:InfoDomainNonexistent; A:1; MX:1; LANG:en; X-Microsoft-Exchange-Diagnostics: 1; BL2FFO11FD048; 1:fXx5b1scjEgBmIsrjl1HPfzU5KWucfj3WMzzVvPewCWE8HcNGtePr+gD3yUnxvZRrBLxYFw/jHjiNilpOZrzGagNSb4fqVGdqHVdbQBjljOYNEhexTCx5BEMnFPejbIxDNQDchbCPk41wURKKi6ZFEsj7JT6s4Pt1dQTjg7YUVXtNBOzt0wR/wlyooT5ZoYKhHKfnmEn+YoPzH75bliHtV43df/rxYwSkZH3puIKgrbU5eaUzB6vWx+0mHroWmzMMRZMtPw6/Q7XZL9FqzGWKL+9YyvSX9V7E5URr2Eaig+kCfdGFpM4S2G2y1lW4omcJ+1Rjui3H51KHwLtynb2+Af00RpZf/X5NYU46eM6V+0P7axKiXjck9t+PrO9H4eiK0Tkbg3Z2zkAbg8wdCNdd21y4k/ehYJuS/W7JbjnZaELmAkQA12KB8zV+BAV+N2WbHCYc0yglhP8RyzfFZJyW+oMOCt9WqaSpls/J7y9f8HqhTj9Z2xIxHS3C9Uw0D3ysJHS/SVz5Ro8Il6R7uoBb+TVsaZgGbMxtCJwceXpiEzK71OANx3xFMHuUBojh7RNGgfcimYLegPb5JR9FThPx35cZ8Aq0pAX14u3cDV1BScK0d6WTnno481AX/4WJEdb0P1RzEujfwyvO9Xs8DIkM3Qnr8jSelXr18N024R8uJBocczq+VyemufqNNlxPYo74vkN2QrsOH5LZ0uZTqqTS94W654Vfca1SgVLEuflmiELh3rvYhfZaEDlZmiugitrkCgGEsUfgHYpb2yQ99W8Tw== MIME-Version: 1.0 Content-Type: text/plain X-MS-Office365-Filtering-Correlation-Id: 874abdd0-13e4-4664-4594-08d41c433c60 X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001); SRVR:BY2PR0301MB0741; X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 3:a8P6BZb7Kv5DuBSONbIsQRuc5Cddi7b2kZHJol50342eWnI4Y5iP1IEezG7dDvpiJ8TTvcMEpu5tdy/bDaGS0TrWhuXRRxg0oXK+qxBHQ/s0x8AyPfx9BA8qABEENR6AeVAz3DBu52UvPrmjdgxPxlyopKZDdP9b68cthAdCPUF7TsI/fEJg4VjlprQlpJB32lHY9HpyPZ9aLdJBOYmC0r8qTQwyA9mAI1oU5jgGhTSghwRuVumP3NHp8JF2/Lr94mIkH0OwBcaFBzPdVvJWV5BBdAHL0sftvVO4spTfgJshnmJJwi0i8HoLxk1H2DSZPmh8H5HkFOueMaXzmF0xb2c07U6BKMVJNltx2offqx8imk9zHjFTUgmeljpwMwN4 X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 25:rT9VYhwhPVSRObDmR6taF4qeH8fAoNpHZtWp8my0gTzULXOAOpEoeYchma0mRdLtj+F7LVo+bK7QvzqQg9BaTt7pY9CBERNDO7n8/boHDhNB3piUGs7zXP7ROSX72Qg1uRpuYR8as8Ir/PgiZ2JSLFoDJk9Az543uKrJ7w10Qu0hfv3dewn5esu+fuufG8dbdPpnjBQBd/IfXKhXJGB0KNhWkAEjZShGOXE+xl5lXMD1ZdBZ4ZYXgTbzzRdZrpVlCraq9Sfw8zLWlrLtvot/suuS6yeSw9VB95Vq8fCalDv3mzr8C4F+t1YRj8gJQm5ARckVOoRhyUmYFPmkye9uifubzwKgUmPLmnNjCblMA5D9DKZJYMNf9o8ok66FWX7AtrI6LNvt3trut9RgPhv0moo9Vqv4S2YLB8kKvcBMRb9M/S4s+/WIfxgATByfYogyc7E1h4Zu0pf3nT3DW6WWkXp3qM95h/aIhJZMSJaewrU8XkVxA/p2MWcoMpI90rsg0UY+kD3DOajmE5MGtjFIoFp8PYmGqGsfxUxD9xVdFSdr8I8r+2h+tIsMhJU5H3br0wcOWcdaKjfOhKc3WY5tHFoCV6NkTY2MXAyxTce+njxGNilk1Te+FDe0L51N7K3p2o3lciqQkV7gc+iFPps+jK/JNuNKWaIfyVazAKwwJ6hekMqTia6Q3OSRQUHRu08UslAXETTe7qCBcoT21pvHUnJO9mv32PXX7Yg009Yt+a6Mp5C8xUYSNhvK0RQSqPhq4Gw70EYEQzkSxeIG1nU5/pvSTFH/pMavXtVP3tq4NzI= X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 31:3kKscZJQsXSFMJlW4loFRwUz3MCOK7meZFSJI0ut35tTvsVoW4P6eUFtXHsz9j8LcWH62GwfpiNK8QWnzKBjdfq7kzK9GuGchyZqy09NgtHrm4cyXUovaDNvdelbCRV1qNyWts7sencVTFf5sRGYorJrSjtIQCRSx3jo/fijFnrZs37+4IfUcXXZbTKdVdhPUKmPScCNKyBAQhirjnlv6uv9CpWYivXQdF8IMLmFpoLTLISOpmGOiSuE4LW92R16OL4WHe9V4ORRSJ3RWJOvzQ== X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:(185117386973197)(275809806118684)(21532816269658); X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0; RULEID:(6095060)(601004)(2401047)(13017025)(13015025)(13023025)(13024025)(13018025)(5005006)(8121501046)(3002001)(10201501046)(6055026)(6096035)(20161123561025)(20161123559025)(20161123556025)(20161123563025)(20161123565025); SRVR:BY2PR0301MB0741; BCL:0; PCL:0; RULEID:(400006); SRVR:BY2PR0301MB0741; X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 4:1ZJJBiMO3NuQt29rI/DsfAxIYwJx4etoS0PX7zOJBjgsn6sb7Sxk4S0Kh5c8IpGxz5rFg5WakHkvCK8VNekicWuTyT6WgbtpsVjj+AaHAhuhszvNGF1pg7SZR+bfJrSWWv5fvNSF5VLk/xPQYo9ICVjQmwecO0Byw4NALMM6dYiFObvZ4xljVEn8AAaCljbnVMVeHVuG0n+SEubkrnO9qO7iM7Vem+ym6XcpgCkuQctDNrPhWrU1J54Q4CtpLrvac4wdagQKm7IJ2jF+EOB8rD1Qjh2+NIpMjzZuaR4l2+f7BDQVfhC7Gt0K+nJKi5/Gx3LAmIv6jESIZ8Dn3CUM1b1eJ0IwQBZkSqqZw2kgkvpGGNTHJ/bSSDM7LGc682T/uFf58X1Pqt4w9GosQRuEiqkW7+/JgyT0wYfAoqkmNHPzMHguVzWZNCGAt408Al3iqVXrX0YktzFaIaKmu1vBxI2Hn5ZK2NOOwuob09yLPN+NhyS0cqec++9WiHbZu20e9DWoRSlU608+eBoC75ENZ4QJB9YBsHfX+0KVO2dIRBglx/6rnlkOfgQMMulAmgdGn3bZ0HqE8pD8N0YuzAa65qd6iYa6VQCHaLnPYyxvy9+362j2sJGAcYe4EYMAmI7bk3PZks2T2cxl9hW3WIgGwBGh0OHehhEL9R8dvjgh1Cr8gfg58a/TBAOR8p2P/wcOGnFtlk7ZU1IYwyniv7cyCfzN84U9vYmyiQEqa53boMIk8GqNy7YiYFbWp9VeN6xrJ/lxUy9cshHqp1+N60zsXCQwTQSpYdDO4p26w2Pe3zRqMEZeeLYEE3C2SKW4t/fg X-Forefront-PRVS: 014617085B X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; BY2PR0301MB0741; 23:BSOB1UM9my1qYjvalQZC6QGht3cZx3mlk19CKs8?= =?us-ascii?Q?U1kjGg96MFe+DkngGtK07piLqjDmr0EmPhJIsPTOwdzIl81gXfvVzLmKhSsc?= =?us-ascii?Q?o43X6gU0B0o8JD7XxwFPyXo7x47Lku7DD7UfIVW+Aj5bqQ0reyvc2NMCmkH0?= =?us-ascii?Q?eTXG/ujr3eZx97Uy11MItwcFFZ9zRkRiP+QLoV6e8TNfV1BT76tVt/RMsCyz?= =?us-ascii?Q?MFcD1FrG4zM6pf/OZ06/OpP85RKJ/4OeMmlAsQrHavhEXfF0aGvdTy+lP14Y?= =?us-ascii?Q?JV1fozAFOXqNq+8LrnOyBKvLPujCbA8ryhp2IZ1SPyK9JaaNCpb+XRUMi0pQ?= =?us-ascii?Q?SB+WVN9pmcJy+/wr8CvxOFoNsCfpi5uNqe0pCOepweXgs79Zop+GbIeHLOG6?= =?us-ascii?Q?ha1Z3uvYeVXyhIXN9iEeD1d1p2JPR02cRuNl0iC5BlAwboiZiCDzMTD3UqJ+?= =?us-ascii?Q?Lf/rUa7BnsijfCzpiOaI0g8k1blD8YFwcwj1+esXZPKg/L6eOKWqUpEblMTM?= =?us-ascii?Q?UiaQoMA75E+XnuOB7EIYXFNiXy6iOmJ1R/unhBLC/lvtSSWsl3glrme/PbhD?= =?us-ascii?Q?iJTpuWJ0FgrsVDyAyT3/rWJJDyYe3GIeFVr+maM5hsRHWqe4UN28buiuUvxZ?= =?us-ascii?Q?bwfqbUufLXmFQyf15fm7RiFiioHYS4cU5SFtps/xQDAeOL+6w3UlfaeIQ0Tf?= =?us-ascii?Q?qbnROQzHEBZhUlD3mp1uXt+zJPJ2Dqc2O4h1Uv7win0NAuMvwiipn5+3vh2q?= =?us-ascii?Q?0zquj5EiiexWu3CAxj/pNUQKFAeNHcqdU6KVqA6QHVfXxOTekZ68F2OsF+NH?= =?us-ascii?Q?8M0GWPyG0YGT63/0t/bwrJ5XKKWcC6cvjGHE8+AqxPjZiRMAuxwB3wapNbTq?= =?us-ascii?Q?xdaFnpf3cb+VToV0kJ+5tqa/MHPYczcYFDXrORcgUmygftkRVnWS0DD43OMU?= =?us-ascii?Q?g5215OLs+OQVj+qW0tQWocG1ikFjWWYYap/WdmdTMrj0Av00M6PcguB9TFMP?= =?us-ascii?Q?PI+kIW85975oWWeVbYTSnaz1bZkI8eMnUgs8witcS2jDTNCWzflKUDtCpNqm?= =?us-ascii?Q?4Jg7lauDia4C+kw5HoFfjuYbvAt2KSzm/jvHSrwWQfvMQuPZCVFskUNOSpIw?= =?us-ascii?Q?UhDzXvaZXAt1B5tfRhJd5r2O8Z3IuaL79Och7MgQcadsPlFfxM93BVXX2ZxF?= =?us-ascii?Q?uy/i+CGGOzn/zp+WmwN3YA6ccdsAxIppSZmRG?= X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 6:7JNPszidaLekqWV5ghZje9rQw/iKZUAWg587xpsS9pM4W2SbYxaGdxHpzF5nQ9eCV+IJAjQRdG0h9ZsUJkbOjjzuqx2SZdY2TdqQrb7L0l6sV/KiizkX5i9HlY1u+FmxFMH97MNw+sNA7SvKBO2AOxXCIn3u6vgRFld/9/WTnXQ89XBScKLADVvVwjLHGuojet/WHYWzu9KvLdJ4LQhiqXN0wnm77Dfzpgn0fPnw4CSPpME7ZGmDd54ffwArVsv+0ewMJXOfFZZFRYyCD8dDvEaXXeYe2typPTX25SAp9FW+efPgKbTdB9RnBL0FI6eO5R6xGiMKd//Mm8ubj+Xv8G/cLBt8Ma7Zrc+TaFOs/ePbm96FYz8RGtYxJOZD2CsfHWkvIsqYwPwyEZ9NvffbTLPBAaczgZBAZoJAxnevinFxoV//0sTwpqs1OmCkZRxL; 5:/WloxXNCbavf46Q+nPwYvMA3kFrHSEyXZa4BhliESWivYot2I3ZOKMftWyD2GqrlTDQAErIDoaQHhD4G9oULJErGeuWPHLfvmBlRCHE7hpoKH4FTitZ+guF0SsQuHcce0wKjNrgKfnc+UBKqxGXEozaHSboCeGclhUmPNnkOOkr75zSgZ1Lq6G/zINyodn6u; 24:QWEGcKcg6n/hRpnYsdg7hiofl+z1H7+n3b8zBycXcMICJR33YpG4BxRUs34LQkQPYLE2rmiJZMfN09cJ7uNO/iJhYPOHeul1Q1msRBnHhnM= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1; BY2PR0301MB0741; 7:xHG2mv0ALZ4WeU9880+eOlzSbPO9odZm1bu3DpCAzygK3WY1/7aY/kUhmA3Xy0nlfFdeIeL0PJgZPGLuwjdVxTS2j8hXbjzs1yo60in+onLFYeauFAeFkt6jEuAk7Xz0KXAd5UGq788yaBENPDQrA+14lSMGfSg+AVtACl5aureDNmdAcFEpjHHQOE3CWE5RiIP1nZDI5+9sgEdSEM5uTHJvibkF70ZtdmeYhhW2nfQNSh6BrWFemL6AueV7uF4/GOYmvlmdL/HiRJsXBKFA0AXpb158JO6c/siLaIMxXnFFoETpBSijcq+iBt5+AQQulT3hIE88AjSabvChwu0cTVrWatu/r4w2yhg22iAyrENO1k+lZMaUeNKjxRlNbtYLaJLyibjifwloR8n3TS2Y1Gchrveji8r7xFrgDBspRv+0ALHaS2/aPMEol0E6DEEX/+ZuaboynqrRlvo250nXpQ== X-MS-Exchange-CrossTenant-OriginalArrivalTime: 04 Dec 2016 12:44:06.5695 (UTC) X-MS-Exchange-CrossTenant-Id: 5afe0b00-7697-4969-b663-5eab37d5f47e X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=5afe0b00-7697-4969-b663-5eab37d5f47e; Ip=[192.88.168.50]; Helo=[tx30smr01.am.freescale.net] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: BY2PR0301MB0741 Subject: [dpdk-dev] [PATCH 11/32] net/dpaa2: add dpaa2 vfio support X-BeenThere: dev@dpdk.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 04 Dec 2016 12:44:09 -0000 Add support for using VFIO for dpaa2 based fsl-mc bus. Signed-off-by: Hemant Agrawal --- drivers/net/dpaa2/Makefile | 1 + drivers/net/dpaa2/dpaa2_bus.c | 15 +- drivers/net/dpaa2/dpaa2_vfio.c | 451 +++++++++++++++++++++++++++++++++++++++++ drivers/net/dpaa2/dpaa2_vfio.h | 74 +++++++ 4 files changed, 540 insertions(+), 1 deletion(-) create mode 100644 drivers/net/dpaa2/dpaa2_vfio.c create mode 100644 drivers/net/dpaa2/dpaa2_vfio.h diff --git a/drivers/net/dpaa2/Makefile b/drivers/net/dpaa2/Makefile index a99ce22..ab17143 100644 --- a/drivers/net/dpaa2/Makefile +++ b/drivers/net/dpaa2/Makefile @@ -49,6 +49,7 @@ EXPORT_MAP := rte_pmd_dpaa2_version.map LIBABIVER := 1 +SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_vfio.c # Interfaces with DPDK SRCS-$(CONFIG_RTE_LIBRTE_DPAA2_PMD) += dpaa2_bus.c diff --git a/drivers/net/dpaa2/dpaa2_bus.c b/drivers/net/dpaa2/dpaa2_bus.c index 571066c..fa88599 100644 --- a/drivers/net/dpaa2/dpaa2_bus.c +++ b/drivers/net/dpaa2/dpaa2_bus.c @@ -44,6 +44,10 @@ #include "eal_filesystem.h" #include "eal_private.h" +#include "dpaa2_vfio.h" + +#define DPAA2_BUS_LOG(level, fmt, args...) \ + RTE_LOG(level, EAL, "%s(): " fmt "\n", __func__, ##args) void rte_dpaa2_register(struct rte_dpaa2_driver *driver) @@ -79,8 +83,17 @@ int rte_dpaa2_probe(struct rte_driver *driver __rte_unused, return 0; } -int rte_dpaa2_scan(struct rte_bus *bus_d __rte_unused) +int rte_dpaa2_scan(struct rte_bus *bus_d) { + if (dpaa2_vfio_setup_group()) { + DPAA2_BUS_LOG(ERR, "DPAA2: Unable to setup VFIO"); + return -1; + } + if (dpaa2_vfio_process_group(bus_d)) { + DPAA2_BUS_LOG(ERR, "DPAA2: Unable to setup devices"); + return -1; + } + RTE_LOG(INFO, PMD, "DPAA2: Device setup completed\n"); return 0; } diff --git a/drivers/net/dpaa2/dpaa2_vfio.c b/drivers/net/dpaa2/dpaa2_vfio.c new file mode 100644 index 0000000..e7e33d3 --- /dev/null +++ b/drivers/net/dpaa2/dpaa2_vfio.c @@ -0,0 +1,451 @@ +/*- + * BSD LICENSE + * + * Copyright (c) 2015-2016 Freescale Semiconductor, Inc. All rights reserved. + * Copyright (c) 2016 NXP. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Freescale Semiconductor, Inc nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "dpaa2_vfio.h" +#define VFIO_MAX_CONTAINERS 1 + +#define DPAA2_VFIO_LOG(level, fmt, args...) \ + RTE_LOG(level, EAL, "%s(): " fmt "\n", __func__, ##args) + +/** Pathname of FSL-MC devices directory. */ +#define SYSFS_DPAA2_MC_DEVICES "/sys/bus/fsl-mc/devices" + +/* Number of VFIO containers & groups with in */ +static struct dpaa2_vfio_group vfio_groups[VFIO_MAX_GRP]; +static struct dpaa2_vfio_container vfio_containers[VFIO_MAX_CONTAINERS]; +static int container_device_fd; +void *(*mcp_ptr_list); +static uint32_t mcp_id; + +static int vfio_connect_container(struct dpaa2_vfio_group *vfio_group) +{ + struct dpaa2_vfio_container *container; + int i, fd, ret; + + /* Try connecting to vfio container if already created */ + for (i = 0; i < VFIO_MAX_CONTAINERS; i++) { + container = &vfio_containers[i]; + if (!ioctl(vfio_group->fd, VFIO_GROUP_SET_CONTAINER, + &container->fd)) { + DPAA2_VFIO_LOG(INFO, " Container pre-exists with" + " FD[0x%x] for this group", + container->fd); + vfio_group->container = container; + return 0; + } + } + + /* Opens main vfio file descriptor which represents the "container" */ + fd = vfio_get_container_fd(); + if (fd < 0) { + DPAA2_VFIO_LOG(ERR, " Failed to open VFIO container"); + return -errno; + } + + /* Check whether support for SMMU type IOMMU present or not */ + if (ioctl(fd, VFIO_CHECK_EXTENSION, VFIO_TYPE1_IOMMU)) { + /* Connect group to container */ + ret = ioctl(vfio_group->fd, VFIO_GROUP_SET_CONTAINER, &fd); + if (ret) { + DPAA2_VFIO_LOG(ERR, "Failed to setup group container"); + close(fd); + return -errno; + } + + ret = ioctl(fd, VFIO_SET_IOMMU, VFIO_TYPE1_IOMMU); + if (ret) { + DPAA2_VFIO_LOG(ERR, "Failed to setup VFIO iommu"); + close(fd); + return -errno; + } + } else { + DPAA2_VFIO_LOG(ERR, " No supported IOMMU available"); + close(fd); + return -EINVAL; + } + + container = NULL; + for (i = 0; i < VFIO_MAX_CONTAINERS; i++) { + if (vfio_containers[i].used) + continue; + DPAA2_VFIO_LOG(DEBUG, " Unused container at index %d", i); + container = &vfio_containers[i]; + } + if (!container) { + DPAA2_VFIO_LOG(ERR, " No free container found"); + close(fd); + return -ENOMEM; + } + + container->used = 1; + container->fd = fd; + container->group_list[container->index] = vfio_group; + vfio_group->container = container; + container->index++; + return 0; +} + +static int64_t vfio_map_mcp_obj(struct dpaa2_vfio_group *group, char *mcp_obj) +{ + int64_t v_addr = (int64_t)MAP_FAILED; + int32_t ret, mc_fd; + + struct vfio_device_info d_info = { .argsz = sizeof(d_info) }; + struct vfio_region_info reg_info = { .argsz = sizeof(reg_info) }; + + /* getting the mcp object's fd*/ + mc_fd = ioctl(group->fd, VFIO_GROUP_GET_DEVICE_FD, mcp_obj); + if (mc_fd < 0) { + DPAA2_VFIO_LOG(ERR, "VFIO error get device %s fd from group" + " %d", mcp_obj, group->fd); + return v_addr; + } + + /* getting device info*/ + ret = ioctl(mc_fd, VFIO_DEVICE_GET_INFO, &d_info); + if (ret < 0) { + DPAA2_VFIO_LOG(ERR, "VFIO error getting DEVICE_INFO"); + goto MC_FAILURE; + } + + /* getting device region info*/ + ret = ioctl(mc_fd, VFIO_DEVICE_GET_REGION_INFO, ®_info); + if (ret < 0) { + DPAA2_VFIO_LOG(ERR, " VFIO error getting REGION_INFO"); + goto MC_FAILURE; + } + + DPAA2_VFIO_LOG(DEBUG, " region offset = %llx , region size = %llx", + reg_info.offset, reg_info.size); + + v_addr = (uint64_t)mmap(NULL, reg_info.size, + PROT_WRITE | PROT_READ, MAP_SHARED, + mc_fd, reg_info.offset); + +MC_FAILURE: + close(mc_fd); + + return v_addr; +} + +/* Following function shall fetch total available list of MC devices + * from VFIO container & populate private list of devices and other + * data structures + */ +int dpaa2_vfio_process_group(struct rte_bus *bus __rte_unused) +{ + struct dpaa2_vfio_device *vdev; + struct vfio_device_info device_info = { .argsz = sizeof(device_info) }; + char *temp_obj, *object_type __rte_unused, *mcp_obj, *dev_name; + int32_t object_id, i, dev_fd; + DIR *d; + struct dirent *dir; + char path[PATH_MAX]; + int64_t v_addr; + int ndev_count; + struct dpaa2_vfio_group *group = &vfio_groups[0]; + static int process_once; + + /* if already done once */ + if (process_once) { + DPAA2_VFIO_LOG(DEBUG, "\n %s - Already scanned once - re-scan " + "not supported", __func__); + return 0; + } + process_once = 0; + + sprintf(path, "/sys/kernel/iommu_groups/%d/devices", group->groupid); + + d = opendir(path); + if (!d) { + DPAA2_VFIO_LOG(ERR, "Unable to open directory %s", path); + return -1; + } + + /*Counting the number of devices in a group and getting the mcp ID*/ + ndev_count = 0; + mcp_obj = NULL; + while ((dir = readdir(d)) != NULL) { + if (dir->d_type == DT_LNK) { + ndev_count++; + if (!strncmp("dpmcp", dir->d_name, 5)) { + if (mcp_obj) + free(mcp_obj); + mcp_obj = malloc(sizeof(dir->d_name)); + if (!mcp_obj) { + DPAA2_VFIO_LOG(ERR, "Unable to" + " allocate memory"); + return -ENOMEM; + } + strcpy(mcp_obj, dir->d_name); + temp_obj = strtok(dir->d_name, "."); + temp_obj = strtok(NULL, "."); + sscanf(temp_obj, "%d", &mcp_id); + } + } + } + closedir(d); + + if (!mcp_obj) { + DPAA2_VFIO_LOG(ERR, "DPAA2 MCP Object not Found"); + return -ENODEV; + } + RTE_LOG(INFO, PMD, "Total devices in container = %d, MCP ID = %d\n", + ndev_count, mcp_id); + + /* Allocate the memory depends upon number of objects in a group*/ + group->vfio_device = (struct dpaa2_vfio_device *)malloc(ndev_count * + sizeof(struct dpaa2_vfio_device)); + if (!(group->vfio_device)) { + DPAA2_VFIO_LOG(ERR, " Unable to allocate memory\n"); + free(mcp_obj); + return -ENOMEM; + } + + /* Allocate memory for MC Portal list */ + mcp_ptr_list = malloc(sizeof(void *) * 1); + if (!mcp_ptr_list) { + DPAA2_VFIO_LOG(ERR, " Unable to allocate memory!"); + free(mcp_obj); + goto FAILURE; + } + + v_addr = vfio_map_mcp_obj(group, mcp_obj); + free(mcp_obj); + if (v_addr == (int64_t)MAP_FAILED) { + DPAA2_VFIO_LOG(ERR, " Error mapping region (err = %d)", errno); + goto FAILURE; + } + + DPAA2_VFIO_LOG(DEBUG, " DPAA2 MC has VIR_ADD = 0x%ld", v_addr); + + mcp_ptr_list[0] = (void *)v_addr; + + d = opendir(path); + if (!d) { + DPAA2_VFIO_LOG(ERR, " Unable to open %s Directory", path); + goto FAILURE; + } + + i = 0; + DPAA2_VFIO_LOG(DEBUG, "DPAA2 - Parsing devices:"); + /* Parsing each object and initiating them*/ + while ((dir = readdir(d)) != NULL) { + if (dir->d_type != DT_LNK) + continue; + if (!strncmp("dprc", dir->d_name, 4) || + !strncmp("dpmcp", dir->d_name, 5)) + continue; + dev_name = malloc(sizeof(dir->d_name)); + if (!dev_name) { + DPAA2_VFIO_LOG(ERR, " Unable to allocate memory"); + goto FAILURE; + } + strcpy(dev_name, dir->d_name); + object_type = strtok(dir->d_name, "."); + temp_obj = strtok(NULL, "."); + sscanf(temp_obj, "%d", &object_id); + DPAA2_VFIO_LOG(DEBUG, " - %s ", dev_name); + + /* getting the device fd*/ + dev_fd = ioctl(group->fd, VFIO_GROUP_GET_DEVICE_FD, dev_name); + if (dev_fd < 0) { + DPAA2_VFIO_LOG(ERR, " VFIO_GROUP_GET_DEVICE_FD error" + " Device fd: %s, Group: %d", + dev_name, group->fd); + free(dev_name); + goto FAILURE; + } + + free(dev_name); + vdev = &group->vfio_device[group->object_index++]; + vdev->fd = dev_fd; + vdev->index = i; + i++; + /* Get Device inofrmation */ + if (ioctl(vdev->fd, VFIO_DEVICE_GET_INFO, &device_info)) { + DPAA2_VFIO_LOG(ERR, "DPAA2 VFIO_DEVICE_GET_INFO fail"); + goto FAILURE; + } + } + closedir(d); + + return 0; + +FAILURE: + free(group->vfio_device); + group->vfio_device = NULL; + return -1; +} + + +int dpaa2_vfio_setup_group(void) +{ + char path[PATH_MAX]; + char iommu_group_path[PATH_MAX], *group_name; + struct dpaa2_vfio_group *group = NULL; + struct stat st; + int groupid; + int ret, len, i; + char *container; + struct vfio_group_status status = { .argsz = sizeof(status) }; + + /* if already done once */ + if (container_device_fd) + return 0; + + container = getenv("DPRC"); + + if (container == NULL) { + DPAA2_VFIO_LOG(ERR, " VFIO container not set in env DPRC"); + return -1; + } + RTE_LOG(INFO, PMD, "DPAA2: Processing Container = %s\n", container); + snprintf(path, sizeof(path), "%s/%s", + SYSFS_DPAA2_MC_DEVICES, container); + + /* Check whether fsl-mc container exists or not */ + DPAA2_VFIO_LOG(DEBUG, " container device path = %s", path); + if (stat(path, &st) < 0) { + DPAA2_VFIO_LOG(ERR, "vfio: Error (%d) getting FSL-MC device (%s)", + errno, path); + return -errno; + } + + /* DPRC container exists. Now checkout the IOMMU Group */ + strncat(path, "/iommu_group", sizeof(path) - strlen(path) - 1); + + len = readlink(path, iommu_group_path, PATH_MAX); + if (len == -1) { + DPAA2_VFIO_LOG(ERR, " vfio: error no iommu_group for device"); + DPAA2_VFIO_LOG(ERR, " %s: len = %d, errno = %d", + path, len, errno); + return -errno; + } + + iommu_group_path[len] = 0; + group_name = basename(iommu_group_path); + if (sscanf(group_name, "%d", &groupid) != 1) { + DPAA2_VFIO_LOG(ERR, " VFIO error reading %s", path); + return -errno; + } + + DPAA2_VFIO_LOG(DEBUG, " VFIO iommu group id = %d", groupid); + + /* Check if group already exists */ + for (i = 0; i < VFIO_MAX_GRP; i++) { + group = &vfio_groups[i]; + if (group->groupid == groupid) { + DPAA2_VFIO_LOG(ERR, " groupid already exists %d", + groupid); + return 0; + } + } + + /* Open the VFIO file corresponding to the IOMMU group */ + snprintf(path, sizeof(path), "/dev/vfio/%d", groupid); + + group->fd = open(path, O_RDWR); + if (group->fd < 0) { + DPAA2_VFIO_LOG(ERR, " VFIO error opening %s", path); + return -1; + } + + /* Test & Verify that group is VIABLE & AVAILABLE */ + if (ioctl(group->fd, VFIO_GROUP_GET_STATUS, &status)) { + DPAA2_VFIO_LOG(ERR, " VFIO error getting group status"); + close(group->fd); + return -1; + } + if (!(status.flags & VFIO_GROUP_FLAGS_VIABLE)) { + DPAA2_VFIO_LOG(ERR, " VFIO group not viable"); + close(group->fd); + return -1; + } + /* Since Group is VIABLE, Store the groupid */ + group->groupid = groupid; + + /* check if group does not have a container yet */ + if (!(status.flags & VFIO_GROUP_FLAGS_CONTAINER_SET)) { + /* Now connect this IOMMU group to given container */ + if (vfio_connect_container(group)) { + DPAA2_VFIO_LOG(ERR, "VFIO error connecting container" + " with groupid %d", groupid); + close(group->fd); + return -1; + } + } + + /* Get Device information */ + ret = ioctl(group->fd, VFIO_GROUP_GET_DEVICE_FD, container); + if (ret < 0) { + DPAA2_VFIO_LOG(ERR, " VFIO error getting device %s fd from" + " group %d", container, group->groupid); + return ret; + } + container_device_fd = ret; + DPAA2_VFIO_LOG(DEBUG, " VFIO Container FD is [0x%X]", + container_device_fd); + + return 0; +} diff --git a/drivers/net/dpaa2/dpaa2_vfio.h b/drivers/net/dpaa2/dpaa2_vfio.h new file mode 100644 index 0000000..2a866ed --- /dev/null +++ b/drivers/net/dpaa2/dpaa2_vfio.h @@ -0,0 +1,74 @@ +/*- + * BSD LICENSE + * + * Copyright (c) 2015-2016 Freescale Semiconductor, Inc. All rights reserved. + * Copyright (c) 2016 NXP. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in + * the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Freescale Semiconductor, Inc nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef _DPAA2_VFIO_H_ +#define _DPAA2_VFIO_H_ + +#include "eal_vfio.h" + +#define DPAA2_VENDOR_ID 0x1957 +#define DPAA2_MC_DPNI_DEVID 7 +#define DPAA2_MC_DPSECI_DEVID 3 + +#define VFIO_MAX_GRP 1 + +typedef struct dpaa2_vfio_device { + int fd; /* dpaa2_mc root container device ?? */ + int index; /*index of child object */ + struct dpaa2_vfio_device *child; /* Child object */ +} dpaa2_vfio_device; + +typedef struct dpaa2_vfio_group { + int fd; /* /dev/vfio/"groupid" */ + int groupid; + struct dpaa2_vfio_container *container; + int object_index; + struct dpaa2_vfio_device *vfio_device; +} dpaa2_vfio_group; + +typedef struct dpaa2_vfio_container { + int fd; /* /dev/vfio/vfio */ + int used; + int index; /* index in group list */ + struct dpaa2_vfio_group *group_list[VFIO_MAX_GRP]; +} dpaa2_vfio_container; + +int vfio_dmamap_mem_region( + uint64_t vaddr, + uint64_t iova, + uint64_t size); + +int dpaa2_vfio_setup_group(void); +int dpaa2_vfio_process_group(struct rte_bus *bus); + +#endif /* _DPAA2_VFIO_H_ */ -- 1.9.1