From mboxrd@z Thu Jan  1 00:00:00 1970
Return-Path: <shreyansh.jain@nxp.com>
Received: from NAM01-BY2-obe.outbound.protection.outlook.com
 (mail-by2nam01on0050.outbound.protection.outlook.com [104.47.34.50])
 by dpdk.org (Postfix) with ESMTP id 9D2ABF979
 for <dev@dpdk.org>; Wed, 18 Jan 2017 11:35:30 +0100 (CET)
Received: from CY1PR03CA0018.namprd03.prod.outlook.com (10.174.128.28) by
 DM2PR0301MB0752.namprd03.prod.outlook.com (10.160.97.148) with Microsoft SMTP
 Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id
 15.1.860.13; Wed, 18 Jan 2017 10:35:29 +0000
Received: from BY2FFO11FD005.protection.gbl (2a01:111:f400:7c0c::100) by
 CY1PR03CA0018.outlook.office365.com (2603:10b6:600::28) with Microsoft SMTP
 Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P384) id
 15.1.860.13 via Frontend Transport; Wed, 18 Jan 2017 10:35:29 +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
 BY2FFO11FD005.mail.protection.outlook.com (10.1.14.126) with Microsoft SMTP
 Server (version=TLS1_0, cipher=TLS_RSA_WITH_AES_256_CBC_SHA) id 15.1.803.8
 via Frontend Transport; Wed, 18 Jan 2017 10:35:28 +0000
Received: from tophie.ap.freescale.net ([10.232.14.39])
 by tx30smr01.am.freescale.net (8.14.3/8.14.0) with ESMTP id v0IAYYhZ003396;
 Wed, 18 Jan 2017 03:35:26 -0700
From: Shreyansh Jain <shreyansh.jain@nxp.com>
To: <david.marchand@6wind.com>
CC: <dev@dpdk.org>, <thomas.monjalon@6wind.com>, Shreyansh Jain
 <shreyansh.jain@nxp.com>
Date: Wed, 18 Jan 2017 16:07:55 +0530
Message-ID: <1484735880-17178-8-git-send-email-shreyansh.jain@nxp.com>
X-Mailer: git-send-email 2.7.4
In-Reply-To: <1484735880-17178-1-git-send-email-shreyansh.jain@nxp.com>
References: <1484660264-6531-1-git-send-email-shreyansh.jain@nxp.com>
 <1484735880-17178-1-git-send-email-shreyansh.jain@nxp.com>
X-EOPAttributedMessage: 0
X-Matching-Connectors: 131292093287179662;
 (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)(336005)(7916002)(39410400002)(39380400002)(39850400002)(39400400002)(39860400002)(39840400002)(39450400003)(2980300002)(1109001)(1110001)(339900001)(189002)(199003)(50466002)(97736004)(81156014)(48376002)(5890100001)(81166006)(5003940100001)(68736007)(36756003)(2906002)(92566002)(86362001)(77096006)(4326007)(575784001)(5660300001)(85426001)(8676002)(626004)(38730400001)(110136003)(8936002)(54906002)(6916009)(189998001)(2950100002)(8656002)(305945005)(53936002)(2351001)(104016004)(6666003)(106466001)(33646002)(47776003)(50226002)(50986999)(105606002)(356003)(76176999);
 DIR:OUT; SFP:1101; SCL:1; SRVR:DM2PR0301MB0752; H:tx30smr01.am.freescale.net;
 FPR:; SPF:Fail; PTR:InfoDomainNonexistent; MX:1; A:1; LANG:en; 
X-Microsoft-Exchange-Diagnostics: 1; BY2FFO11FD005;
 1:Br0+CAV8CNQCCI63AyNfAOiYxbeb85lz4+5UbQl5OFXIVw20qkpYadXYIEPPtCeVh3djvpOe7NCVa5jSAft0YDvRtJotNPgWwErmvDiX6/kMYtbb8KTYeT1k71fIcwcOTuFwN19KZR+obr2Nf3DS8Q0KTqBU6+bgUyXh/q+2EYWADLHjWlI6KZ5FodpYFG7OvvEPq7HbT69joXRYObxpKRFnj1Z/ITBm34dZcnqBIRFXz0sqRAnVFuYgNI3yAz7KOLijaFfOG0dh9IGGlYpWz6IXqKZbg+YrPW+1rZftcb9WSZbxtRGs1JZXx7fDX9C0Hkb+OvlQfpIaUsw64xPC6OQ7PiQrMD+zLte9fVHp2WRiJN2eSb5DlY4v3ZeWqRy6oA6fCIQ5KyVtNb+CvxhMewSazhL4i3dBU0/R0DbL5774Z1po5QJ00PLBLskvFXLWBwGwe9rx7bP/lobIBYROd8HnZlLjR3COK2Jv5WMEIH9eXI8kNHrUyYaUIt3jAtfedH0fd6q6CDJOsBtjEwBpFKBquJ0tL/cbY36eeEr6C5wtPtmBQTm/b3Y21tJernCBonPeRHH7FRjWj69v/nON8LFIlwafpAUdIgeDn+2eSS2/yT8WvlMefRVUaMlsIIqp7t7EmMhN9IJPKs/PmxK87rLTwwcpu14n95JrnJdzel8YEJPruQylv0h7CVjlIHUWE7DK0TFzGr5ukFPDFhjGBA==
MIME-Version: 1.0
Content-Type: text/plain
X-MS-Office365-Filtering-Correlation-Id: 42acefed-7809-4458-c432-08d43f8db8a7
X-Microsoft-Antispam: UriScan:; BCL:0; PCL:0; RULEID:(22001);
 SRVR:DM2PR0301MB0752; 
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 3:KofefptDl23kdqd4Lb6PUHp4j5LcaN3MbUym6cDHowqWsltadPLec3EPP9s7nZqp0zZ3E3fwv10+kInyHT4mRvDrpyq9FZEErNl9z2IHGHJzItn+Bc5AKQFRLa1x5ipZy9CD8+9RgasnXQKzuuGOedkiR94vEv+mSTauRwzFWxyBMV9Q2CX7vahER9WcGdGO131cafaWEQ2CWi933KwWFNBmht2ihV96bmPoSRicqH129RqROOBt55nARz2bC9GpfvW0U0YW2P9+/A7ynt5YA+pZOyY+gp3vNQ1lcZjP7dwAuy9Ue/CxAbFQNmVix9h0cPPyhjMNB56fg+8F7JFzead5rmr+C0wca80Rty9blM4RtEiKWUog8xlf1Pf6bBOs
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 25:3riFDa1mJLDUdM9LKqDP763O2K+Vik88CyW97BmTwVyKFJ2jXrCqCUx8I09MuUGte3yPGyxI7JROlM4rL0AOX2RCJnA6MCiOVsgonPxjQTcd3PtbLU8pJcEKzfXJ8+SxOfzmcBFhGOB+TlOZUvoyAMMFiq8gDQV2XmFl+zXSAk6C8F5Xwk/oJvgI233GFJJPyCqEqKDEaadJex4H48h77QB+Od//YFs/3ofJmtb2U0SvKUgatyTyIWyV/AQwcbHDDneFgoJqGvsFS5uce3YMpga+qM+XjRXsK2ZF5ggpC54k2O4gXw1RWmPehJnMbM7yAtumYSgtEupg/oLBE+3xxAlslayugHlOeQGIbXObSj0LooQZxgKmhi+H6K7teaNKGBNOE1HLvnG4bXa5C0XmXJk5hIvzwTlnzYcqCtJrhIt0KviOb5/WBs801ayTz4YYpxSN5yoK0YnPPbF6ODFGJYkeniCJAr1bc5KwZXopxzsZ7OUAULZfo+pY0rm87edvk1HEzriCy+sruq8Y1tw8fgFIAQYOjdv3BsqNeLjEMmEaxKOdV7E17eb5gLg73ndSvRUBR9V4KC+uoSLzYONZnzaCA9k8NPikdSqwcNAOAefa3cXozFgCObNz4ZwT5qM6CqwXx9JUX0eWFN/fvIbTkSbMUYnLfno3YkMBF0Ahh+9COn70EKhFwF3WQxSJwNu50i1ZwWEzsw3/wczEkZ8MiLwqloSahVDK+mVlKEgaX0hngAcTWEWRMM0KZIbrudYK4F4tRkI6xw1BXWF61Nc859iobBSwxDK3IQQG10vq8X028ZE73MTssRH5dOC2e9O6
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 31:TD2owZR2LCyv3letj98so1gg5+9AioXow0zDHxHMr4kLk1bB0TZH4zNr1Uztr4zb+e9/NbIJIBDcvNFZH+yZ3reMzcQqRlGsBbdARKWbik89YAWJFfr9M9+V42DoIK2XUIzuabrCjBrpIRoc9iVa0Z3roNyiA36h7oojAhXcWnoCzZBQuPT2M/+Zi/QPtZ8Mj/wGahT9IpIMyU0e7lwiopmE/duBlAvIRRoGIhUrhep8XbkAWthz+oPDiKpq0vfMPDEz784E1yWrs1OCh5EXEuOjGENC2GoHeXgzmmaOrNE=
X-Microsoft-Antispam-PRVS: <DM2PR0301MB0752EC4022D869B18E0AAF01907F0@DM2PR0301MB0752.namprd03.prod.outlook.com>
X-Exchange-Antispam-Report-Test: UriScan:(185117386973197)(228905959029699);
X-Exchange-Antispam-Report-CFA-Test: BCL:0; PCL:0;
 RULEID:(6095060)(601004)(2401047)(13023025)(13017025)(13015025)(13024025)(13018025)(5005006)(8121501046)(3002001)(10201501046)(6055026)(6096035)(20161123561025)(20161123559025)(20161123556025)(20161123563025)(20161123565025);
 SRVR:DM2PR0301MB0752; BCL:0; PCL:0; RULEID:(400006); SRVR:DM2PR0301MB0752; 
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 4:gBJuXBJCGG2HlpZpMHIafVw02t1Cw+68zZPnN85BX1fN7ctxiAzkIZecatmZIlsSxgEUcYMSInNd8UtWSXK2fqT7nqNWJXsAQwtDR9FBJWfgtsxFtLLSiy5APbcnXtATuYHa3T3Td2zAxBZFZa+HlY4pRDJbkeaweIc79657pz2KqpA5NpPP2mLV+F3PDn3Hoqi8M/tzBUaWM1l1Vmxp4yDWIqAd63kCqs5GGYm2a9cG2flic9ygwDPJegNOLMRDZTjyy/4yf9eamaLjQ0xM53gXCQrrQ09c+22AuHahrBlLulVl8RV7m1PK7m3/jUAJMQxA13GxdyhFI5g8g35IB7YOn2IsT7st6kb3k6vztnbvlbvdGGZD5ozoyVl/Kpf+wk9iI4LsjMiiEKS5r4DJ+UnmJ64jb0drIg7ONCfNejdRY7DRSrCkW4w7EbYTez6derwc/cUtWBO1U/8IxOLhMZQCn5ZfHzkcObMyUQGlf0wBFGx8se2VtwMCbEUVuYkNM6ZcunciqcH6aCYM1ohTNMY6gjbWcWPeK1ajke/ONRQbe68Mb3L2+k2l3WKqjWlMIJd/6ynvgtrBXjaK7PEJwpbyfz/soRLwvbNLilpvff3j7ZHHqZv6nfC0a/1944InXVzI5GSq+sBJ/jWMmhcgJ7/XCUw4iuHFJuzlY6wJ0YIVIQM9R1G/TRMBupy6ao1I8W144YyrwLNGYfPSsYv4CjTnMzwNPEpt/ORqPg11kRsxU07aDyRF3daPgq+tpeM9w4Feou2gWhOEv15Dt7+ZJA==
X-Forefront-PRVS: 01917B1794
X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1; DM2PR0301MB0752;
 23:1opw5j1/POC8BIxOD+8wRAHwsBYgWnkNkb7OVuj?=
 =?us-ascii?Q?NIaQUF0n0SNle5Q6R6pG4M3VcCnCZpQSE2UdtM/pge28NjX6GFVMH+vChyke?=
 =?us-ascii?Q?F4HlgIMbYvUbMyAIaEKDJzBvK9PtG1jpj1PgvxLg9hiwAHs9ffn+9iZ/WioB?=
 =?us-ascii?Q?EhqH/fK2dnIYcqg0YCG//iNGT0fMSsLtDxjq4cPhyUzsPscWUdbvVBde1Ils?=
 =?us-ascii?Q?i+GsMqAaS6n7tqxBIN1IkL1SMufUA8BsEZToFLXyHHSWxjILGD1YnuZJ+Ufk?=
 =?us-ascii?Q?GFtN5AtmMRgmHXS15wY3P/254yQd35iPyGkAQARTLGDYFRvDuEcAMmAjzmW1?=
 =?us-ascii?Q?NsI1pYtEGtlFjUwr0nY2xGwVAVpIXjLU/lndwuwddZEpPX6RoyN8D6NsJ/lS?=
 =?us-ascii?Q?GeTRwfBpsJdhL4UNffGnRSK7VOxeJUN+JZ1JE57+jDBVZLaWMCubGbJzyPPg?=
 =?us-ascii?Q?Z91UKn4zEDys7aBmzWx12Dt9tV/0HwH+bCtb5weQuqLX8SpYyBNKOuvxPYtS?=
 =?us-ascii?Q?Dvm90kssT1Mhc4ZwZDxvdEW4mSvTUhBNUcgFANi/FS5wywzd9EpJ1Y2qB+i/?=
 =?us-ascii?Q?wFXnmKKUjMGg3srNKhE3mjFL3FguatFNQw2sig8gflzJlbehDp2rjHMPDUZL?=
 =?us-ascii?Q?zw+VfXjnEexKSktfEivN+XGmp6vRhFpLPbPMTz5PE2OhIEGBXrnxcpqwgw9i?=
 =?us-ascii?Q?Oqe2FrsMN8ZNCcziUSE6OfcLlMPVCvErDBOrf/VfBKaBTwgs2CgY6uUiLPd6?=
 =?us-ascii?Q?T5jvh2u31y/A3MyIEqvcYqUv+SutcxohW1bAd3nVbI/movqQnKpWNGGzijSz?=
 =?us-ascii?Q?BDJd+ZmKQ1Wc0SVv27+U1laZ/Ix/5cf+ilyeCfPsV7kWvyt2vjExCgW3+ri2?=
 =?us-ascii?Q?jtbISYzGdQfibO3jSAdxthU1H5N0mr78fjJo1Eip03+kYBrRXg51JSMGgBb0?=
 =?us-ascii?Q?th5gy/Jetj7+rz1n/SqTHBf/apCv9A36oOVLCve97XnceGeSlJidfsgNZBUB?=
 =?us-ascii?Q?b8oWVl2XBFeMVGa8DxMZF/9HJFlnIp1M1S7fyWR0qpHy4VU11W6JBI3qmyUG?=
 =?us-ascii?Q?obuaZHkOzU74Lnqemxl77hZorbL5/BY8VexRJaob+P9u6oXYDnAmFW4mg9Kg?=
 =?us-ascii?Q?+w1YTYVOAEmC4OlNeBsrFCn+LKxTlcfGiOJSJkVkwwe0kTwpjxDBnbfEPo4x?=
 =?us-ascii?Q?t2zdMwoqMWZtPiuAyQ1NA/8BHXHPRe0+SiHz0tfo6Uw1fEe4TBLL0vyFgsDo?=
 =?us-ascii?Q?N46OZP7KWSeVODwJwjro5Q5cisYrHkzti4+hxBjEbZcbM0fRviPLYqGESwDa?=
 =?us-ascii?Q?xJicjGU+J3oYHTsYlsWQDMYLZEWEAuoqh4SY0ZDL4uCMPXINmoXrkpgIY6nC?=
 =?us-ascii?Q?i2VRZog=3D=3D?=
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 6:DpN0E0u9AnMDCp4cvcfz2fJcJ35epqZAaRxWt7q9ebU2X43/A/UeWsLGpTFdvpWF2Kw9h2T0/mU7t8gfdmUMSSja8C44WoothS6hOArfbJITRoxvUxljBg77eDPqmKbb+MX+DqJdgSpEu6yQGAHhpiofP77EWfipmFSebVXW2KtAv1JT6KJcHuqt/Dr4Y4vTd4IrOHNjzkS2+JTHosh4T30cOW2jfk2KS85b2hNBmS6scCLih5+mGZUr/e5vac0zZerJA8puoRFbvvzAit9BXQxqdFjOEY15oEQ3LvqRo4vfX4NBZUg5fZQKteyMba6SiXpUDc9cZArr0mqiM10w7HfEulBGILf9AYFw0lyIGDatq5srYjvluwmPlXj44ttnkAysL55F3rhCwIdFm3uP3UcjyA777iUZRk3Bp/jXTqQvogG0VX/4R2Ot7Js+6/Pr;
 5:n+K45u5FMJ2sr3aS96ilQ6UxtywVvm9oiPc0lO5mk2uWVLwxn3YmAvjayQic3AOAl8qX/dL4bR1hhFA3eAB3W72EF/hcUrYfamlE59XyIv8m6GPpEn2O3+dh33dBR6ZPr1n3CIksCxX37Tm/z9Ae2/p52mgzrBttuIG0aT3W/Sg+pbcFU4/vLiRnWq2QyCV/;
 24:wR4hKCODIWvNZGkadvJSU6GbRK8bISRns/AgmZ8YhT5DNTq2IIflmb+JGaFl5wcElkUF2p8Wzb7flV3wTlNp4I1hHUBTyvA45/PzIAAOPaE=
SpamDiagnosticOutput: 1:99
SpamDiagnosticMetadata: NSPM
X-Microsoft-Exchange-Diagnostics: 1; DM2PR0301MB0752;
 7:ooua2wrZsrwX6CjK27/ZTk/5uzjCcD/lZUKQk+X/C13ewQEAPynRvMUr+H/1fWSBU7Pqk+IGXT1EGwjGYhcLgex/R++8y0dyw/sIFLMSiISKnNTDZBpTHuFfGotSQbImv6hvopWalBdF+ZHDu4+PUlMb440bOPztIlPIWvnXVTvzuk4TMPanlTqRYTp7arIpNq+1oUEy2tM0fOCoYn/WPeaC1Z2yhRDSK6FiwbHHYkoeKJ2lf9psIGH/VJg+FIFUXeqqAKo5Kq49hurXJHO5wlIY+bd8QnG85pacMfrctOx3uJGRVu2Yb5W5/nIop94130SGsfLJNQ75HRoEJ40cYP7bpVGESCHG/e34GwwUKe95NiXO8Pgw6qDEFQt8dRQ1Y186lhpkFGTxs1OmbtbYvvIdlqzJfx9hQev5lwYNZuWFj2gA/VzECRyEm8dydZRMr6Uc/Xs9deOJ0N4/YcKRzQ==
X-MS-Exchange-CrossTenant-OriginalArrivalTime: 18 Jan 2017 10:35:28.5151 (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: DM2PR0301MB0752
Subject: [dpdk-dev] [PATCH v9 07/12] eal: integrate bus scan and probe with
	EAL
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>,
 <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>,
 <mailto:dev-request@dpdk.org?subject=subscribe>
X-List-Received-Date: Wed, 18 Jan 2017 10:35:31 -0000

Add functions for scanning all the buses and performing probe on all
the buses on EAL initialization.

Presently, no bus exists - in subseqent patches, PCI bus would be
introduced.

Signed-off-by: Shreyansh Jain <shreyansh.jain@nxp.com>
Reviewed-by: Ferruh Yigit <ferruh.yigit@intel.com>
---
 lib/librte_eal/bsdapp/eal/eal.c                 |  7 +++++
 lib/librte_eal/bsdapp/eal/rte_eal_version.map   |  2 ++
 lib/librte_eal/common/eal_common_bus.c          | 40 +++++++++++++++++++++++++
 lib/librte_eal/common/include/rte_bus.h         | 19 ++++++++++++
 lib/librte_eal/linuxapp/eal/eal.c               |  8 +++++
 lib/librte_eal/linuxapp/eal/rte_eal_version.map |  2 ++
 6 files changed, 78 insertions(+)

diff --git a/lib/librte_eal/bsdapp/eal/eal.c b/lib/librte_eal/bsdapp/eal/eal.c
index 2206277..f0abd82 100644
--- a/lib/librte_eal/bsdapp/eal/eal.c
+++ b/lib/librte_eal/bsdapp/eal/eal.c
@@ -577,6 +577,9 @@ rte_eal_init(int argc, char **argv)
 		rte_config.master_lcore, thread_id, cpuset,
 		ret == 0 ? "" : "...");
 
+	if (rte_bus_scan())
+		rte_panic("Cannot scan the buses for devices\n");
+
 	RTE_LCORE_FOREACH_SLAVE(i) {
 
 		/*
@@ -613,6 +616,10 @@ rte_eal_init(int argc, char **argv)
 	if (rte_eal_pci_probe())
 		rte_panic("Cannot probe PCI\n");
 
+	/* Probe all the buses and devices/drivers on them */
+	if (rte_bus_probe())
+		rte_panic("Cannot probe devices\n");
+
 	if (rte_eal_dev_init() < 0)
 		rte_panic("Cannot init pmd devices\n");
 
diff --git a/lib/librte_eal/bsdapp/eal/rte_eal_version.map b/lib/librte_eal/bsdapp/eal/rte_eal_version.map
index c015889..c43140c 100644
--- a/lib/librte_eal/bsdapp/eal/rte_eal_version.map
+++ b/lib/librte_eal/bsdapp/eal/rte_eal_version.map
@@ -182,6 +182,8 @@ DPDK_17.02 {
 	rte_bus_dump;
 	rte_bus_register;
 	rte_bus_unregister;
+	rte_bus_probe;
+	rte_bus_scan;
 	rte_pci_match;
 
 } DPDK_16.11;
diff --git a/lib/librte_eal/common/eal_common_bus.c b/lib/librte_eal/common/eal_common_bus.c
index 3f529e6..ead9a22 100644
--- a/lib/librte_eal/common/eal_common_bus.c
+++ b/lib/librte_eal/common/eal_common_bus.c
@@ -65,6 +65,46 @@ rte_bus_unregister(struct rte_bus *bus)
 	RTE_LOG(INFO, EAL, "Unregistered [%s] bus.\n", bus->name);
 }
 
+/* Scan all the buses for registering devices */
+int
+rte_bus_scan(void)
+{
+	int ret;
+	struct rte_bus *bus = NULL;
+
+	TAILQ_FOREACH(bus, &rte_bus_list, next) {
+		ret = bus->scan();
+		if (ret) {
+			RTE_LOG(ERR, EAL, "Scan for (%s) bus failed.\n",
+				bus->name);
+			/* Error in scanning any bus stops the EAL init. */
+			return ret;
+		}
+	}
+
+	return 0;
+}
+
+/* Call bus specific probe */
+int
+rte_bus_probe(void)
+{
+	int ret;
+	struct rte_bus *bus;
+
+	/* For each bus registered with EAL */
+	TAILQ_FOREACH(bus, &rte_bus_list, next) {
+		ret = bus->probe();
+		if (ret) {
+			RTE_LOG(ERR, EAL, "Bus (%s) probe failed.\n",
+				bus->name);
+			return ret;
+		}
+	}
+
+	return 0;
+}
+
 /* Dump information of a single bus */
 static int
 bus_dump_one(FILE *f, struct rte_bus *bus)
diff --git a/lib/librte_eal/common/include/rte_bus.h b/lib/librte_eal/common/include/rte_bus.h
index 17583ad..4b4bb36 100644
--- a/lib/librte_eal/common/include/rte_bus.h
+++ b/lib/librte_eal/common/include/rte_bus.h
@@ -113,6 +113,25 @@ void rte_bus_register(struct rte_bus *bus);
 void rte_bus_unregister(struct rte_bus *bus);
 
 /**
+ * Scan all the buses attached to the framework.
+ *
+ * @return
+ *	0 in case of success in scanning all buses
+ *	!0 in case of failure to scan
+ */
+int rte_bus_scan(void);
+
+/**
+ * For each device on the bus, perform a driver 'match' and call the
+ * bus's probe for device initialization.
+ *
+ * @return
+ *	0 for successful match/probe
+ *	!0 otherwise
+ */
+int rte_bus_probe(void);
+
+/**
  * Dump information of all the buses registered with EAL.
  *
  * @param f
diff --git a/lib/librte_eal/linuxapp/eal/eal.c b/lib/librte_eal/linuxapp/eal/eal.c
index 16dd5b9..f77ff5c 100644
--- a/lib/librte_eal/linuxapp/eal/eal.c
+++ b/lib/librte_eal/linuxapp/eal/eal.c
@@ -69,6 +69,7 @@
 #include <rte_string_fns.h>
 #include <rte_cpuflags.h>
 #include <rte_interrupts.h>
+#include <rte_bus.h>
 #include <rte_pci.h>
 #include <rte_dev.h>
 #include <rte_devargs.h>
@@ -844,6 +845,9 @@ rte_eal_init(int argc, char **argv)
 	if (rte_eal_intr_init() < 0)
 		rte_panic("Cannot init interrupt-handling thread\n");
 
+	if (rte_bus_scan())
+		rte_panic("Cannot scan the buses for devices\n");
+
 	RTE_LCORE_FOREACH_SLAVE(i) {
 
 		/*
@@ -884,6 +888,10 @@ rte_eal_init(int argc, char **argv)
 	if (rte_eal_pci_probe())
 		rte_panic("Cannot probe PCI\n");
 
+	/* Probe all the buses and devices/drivers on them */
+	if (rte_bus_probe())
+		rte_panic("Cannot probe devices\n");
+
 	if (rte_eal_dev_init() < 0)
 		rte_panic("Cannot init pmd devices\n");
 
diff --git a/lib/librte_eal/linuxapp/eal/rte_eal_version.map b/lib/librte_eal/linuxapp/eal/rte_eal_version.map
index 5ed2589..6f047c5 100644
--- a/lib/librte_eal/linuxapp/eal/rte_eal_version.map
+++ b/lib/librte_eal/linuxapp/eal/rte_eal_version.map
@@ -186,6 +186,8 @@ DPDK_17.02 {
 	rte_bus_dump;
 	rte_bus_register;
 	rte_bus_unregister;
+	rte_bus_probe;
+	rte_bus_scan;
 	rte_pci_match;
 
 } DPDK_16.11;
-- 
2.7.4