]> git.proxmox.com Git - mirror_edk2.git/commitdiff
DuetPkg: exit pci function loops early if device is not multi-function
authorJoseph Shifflett <joseph.shifflett@hpe.com>
Tue, 6 Oct 2015 20:55:36 +0000 (20:55 +0000)
committerlersek <lersek@Edk2>
Tue, 6 Oct 2015 20:55:36 +0000 (20:55 +0000)
When looping through all PCI functions, code should not look for functions
1-7 if function 0 is not present or if function 0 indicates the device is
not multifunction.  Prior to this fix the code would use stale data in a
buffer to determine if a device is multifunction even if function 0 is not
present.  This fixes a code bug and provides very small performance
improvements.

PCI 2.3 Specification states: They [multifunction devices] are also
required to always implement function 0 in the device. Implementing other
functions is optional and may be assigned in any order.

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Joseph Shifflett <joseph.shifflett@hpe.com>
Reviewed-by: Ruiyu Ni <ruiyu.ni@intel.com>
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@18575 6f19259b-4bc3-4df7-8a09-765794883524

DuetPkg/PciBusNoEnumerationDxe/PciEnumeratorSupport.c

index fb41727e7ac4ff082ddc6d069028b4ab82f6f1fd..80b2b6b24d24f7bc8e0ee27d615c0d863779dd8e 100644 (file)
@@ -1,6 +1,7 @@
 /*++\r
 \r
 Copyright (c) 2005 - 2014, Intel Corporation. All rights reserved.<BR>\r
+(C) Copyright 2015 Hewlett Packard Enterprise Development LP<BR>\r
 This program and the accompanying materials                          \r
 are licensed and made available under the terms and conditions of the BSD License         \r
 which accompanies this distribution.  The full text of the license may be found at        \r
@@ -216,6 +217,13 @@ Returns:
                 (UINT8) Func\r
                 );\r
 \r
+      if (EFI_ERROR (Status) && Func == 0) {\r
+        //\r
+        // go to next device if there is no Function 0\r
+        //\r
+        break;\r
+      }\r
+\r
       if (!EFI_ERROR (Status)) {\r
 \r
         //\r