From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stephen Hemminger Subject: Re: [PATCH v2 2/3] eal: PCI domain should be 32 bits Date: Thu, 22 Jun 2017 09:23:41 -0700 Message-ID: <20170622092341.7e1544c2@xeon-e3> References: <20170622155641.25916-1-stephen@networkplumber.org> <20170622155641.25916-3-stephen@networkplumber.org> <3793478.bOXkPGkn7S@xps> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Cc: dev@dpdk.org, Stephen Hemminger To: Thomas Monjalon Return-path: Received: from mail-pf0-f179.google.com (mail-pf0-f179.google.com [209.85.192.179]) by dpdk.org (Postfix) with ESMTP id 5B5FC4BE1 for ; Thu, 22 Jun 2017 18:23:49 +0200 (CEST) Received: by mail-pf0-f179.google.com with SMTP id e7so10923213pfk.0 for ; Thu, 22 Jun 2017 09:23:49 -0700 (PDT) In-Reply-To: <3793478.bOXkPGkn7S@xps> List-Id: DPDK patches and discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dev-bounces@dpdk.org Sender: "dev" On Thu, 22 Jun 2017 18:05:42 +0200 Thomas Monjalon wrote: > 22/06/2017 17:56, Stephen Hemminger: > > In some environments, the PCI domain can be larger than 16 bits. > > For example, a PCI device passed through in Azure gets a synthetic domain > > id which is internally generated based on GUID. The PCI standard does > > not restrict domain to be 16 bits. > > > > This change breaks ABI for API's that expose PCI address structure. > > > > Signed-off-by: Stephen Hemminger > > --- > [...] > > --- a/lib/librte_eal/common/include/rte_pci.h > > +++ b/lib/librte_eal/common/include/rte_pci.h > > @@ -63,7 +63,7 @@ const char *pci_get_sysfs_path(void); > > > > /** Formatting string for PCI device identifier: Ex: 0000:00:01.0 */ > > #define PCI_PRI_FMT "%.4" PRIx16 ":%.2" PRIx8 ":%.2" PRIx8 ".%" PRIx8 > > -#define PCI_PRI_STR_SIZE sizeof("XXXX:XX:XX.X") > > +#define PCI_PRI_STR_SIZE sizeof("XXXXXXXX:XX:XX.X") > > I think you need to change PCI_PRI_FMT accordingly. No. I don't want all outputs to have extra leading zeros on other platforms The existing format works: Example: --- cut here --- struct rte_pci_addr { uint32_t domain; /**< Device domain */ uint8_t bus; /**< Device bus */ uint8_t devid; /**< Device ID */ uint8_t function; /**< Device function. */ }; #define PCI_PRI_FMT "%.4" PRIx16 ":%.2" PRIx8 ":%.2" PRIx8 ".%" PRIx8 int main(void) { struct rte_pci_addr pci_addr = { 0, 5, 0, 0 }; printf(PCI_PRI_FMT "\n", pci_addr.domain, pci_addr.bus, pci_addr.devid, pci_addr.function); pci_addr.domain = 0xdeadbeef; printf(PCI_PRI_FMT "\n", pci_addr.domain, pci_addr.bus, pci_addr.devid, pci_addr.function); return 0; } --- output --- 0000:05:00.0 deadbeef:05:00.0