]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
UBUNTU: SAUCE: x86/PCI: Export find_cap() to be used in early PCI code
authorGuilherme G. Piccoli <gpiccoli@canonical.com>
Thu, 8 Nov 2018 21:07:19 +0000 (19:07 -0200)
committerAndrea Righi <andrea.righi@canonical.com>
Thu, 9 Mar 2023 14:57:16 +0000 (15:57 +0100)
BugLink: https://bugs.launchpad.net/bugs/1797990
This patch exports (and renames) the function find_cap() to be used
in the early PCI quirk code, by the next patch.

This is being moved out from AGP code to generic early-PCI code
since it's not AGP-specific and can be used for any PCI device.
No functional changes intended.

Signed-off-by: Guilherme G. Piccoli <gpiccoli@canonical.com>
Signed-off-by: Mauricio Faria de Oliveira <mfo@canonical.com>
Acked-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com>
Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com>
arch/x86/include/asm/pci-direct.h
arch/x86/kernel/aperture_64.c
arch/x86/pci/early.c

index 94597a3cf3d0f14fa1e81989437cf43a485d59e0..813996305bf55c88780e1481b88ecb9d5e6f8c44 100644 (file)
@@ -10,6 +10,7 @@
 extern u32 read_pci_config(u8 bus, u8 slot, u8 func, u8 offset);
 extern u8 read_pci_config_byte(u8 bus, u8 slot, u8 func, u8 offset);
 extern u16 read_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset);
+extern u32 pci_early_find_cap(int bus, int slot, int func, int cap);
 extern void write_pci_config(u8 bus, u8 slot, u8 func, u8 offset, u32 val);
 extern void write_pci_config_byte(u8 bus, u8 slot, u8 func, u8 offset, u8 val);
 extern void write_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset, u16 val);
index 4feaa670d5783b8fe9bb226d0635c09bb15939da..dd7c987f21a737394da5bd9136330ab41e437769 100644 (file)
@@ -136,32 +136,6 @@ static u32 __init allocate_aperture(void)
 }
 
 
-/* Find a PCI capability */
-static u32 __init find_cap(int bus, int slot, int func, int cap)
-{
-       int bytes;
-       u8 pos;
-
-       if (!(read_pci_config_16(bus, slot, func, PCI_STATUS) &
-                                               PCI_STATUS_CAP_LIST))
-               return 0;
-
-       pos = read_pci_config_byte(bus, slot, func, PCI_CAPABILITY_LIST);
-       for (bytes = 0; bytes < 48 && pos >= 0x40; bytes++) {
-               u8 id;
-
-               pos &= ~3;
-               id = read_pci_config_byte(bus, slot, func, pos+PCI_CAP_LIST_ID);
-               if (id == 0xff)
-                       break;
-               if (id == cap)
-                       return pos;
-               pos = read_pci_config_byte(bus, slot, func,
-                                               pos+PCI_CAP_LIST_NEXT);
-       }
-       return 0;
-}
-
 /* Read a standard AGPv3 bridge header */
 static u32 __init read_agp(int bus, int slot, int func, int cap, u32 *order)
 {
@@ -250,8 +224,8 @@ static u32 __init search_agp_bridge(u32 *order, int *valid_agp)
                                case PCI_CLASS_BRIDGE_HOST:
                                case PCI_CLASS_BRIDGE_OTHER: /* needed? */
                                        /* AGP bridge? */
-                                       cap = find_cap(bus, slot, func,
-                                                       PCI_CAP_ID_AGP);
+                                       cap = pci_early_find_cap(bus, slot,
+                                                func, PCI_CAP_ID_AGP);
                                        if (!cap)
                                                break;
                                        *valid_agp = 1;
index f5fc953e584832901a6f45cd130f29a321c6b280..f1ba9d781b52494a47cb04208bc8851fd851c2b8 100644 (file)
@@ -51,6 +51,31 @@ void write_pci_config_16(u8 bus, u8 slot, u8 func, u8 offset, u16 val)
        outw(val, 0xcfc + (offset&2));
 }
 
+u32 pci_early_find_cap(int bus, int slot, int func, int cap)
+{
+       int bytes;
+       u8 pos;
+
+       if (!(read_pci_config_16(bus, slot, func, PCI_STATUS) &
+                                               PCI_STATUS_CAP_LIST))
+               return 0;
+
+       pos = read_pci_config_byte(bus, slot, func, PCI_CAPABILITY_LIST);
+       for (bytes = 0; bytes < 48 && pos >= 0x40; bytes++) {
+               u8 id;
+
+               pos &= ~3;
+               id = read_pci_config_byte(bus, slot, func, pos+PCI_CAP_LIST_ID);
+               if (id == 0xff)
+                       break;
+               if (id == cap)
+                       return pos;
+               pos = read_pci_config_byte(bus, slot, func,
+                                               pos+PCI_CAP_LIST_NEXT);
+       }
+       return 0;
+}
+
 int early_pci_allowed(void)
 {
        return (pci_probe & (PCI_PROBE_CONF1|PCI_PROBE_NOEARLY)) ==