1 #include <console/console.h>
2 #include <device/device.h>
3 #include <device/pci.h>
4 #include <device/pci_ids.h>
5 #include <device/pci_ops.h>
6 #include <x86emu/x86emu.h>
10 int pcibios_handler(void)
13 struct device *dev = 0;
16 case PCI_BIOS_PRESENT:
17 X86_AH = 0x00; /* no config space/special cycle support */
18 X86_AL = 0x01; /* config mechanism 1 */
19 X86_EDX = 'P' | 'C' << 8 | 'I' << 16 | ' ' << 24;
20 X86_EBX = 0x0210; /* Version 2.10 */
21 X86_ECX = 0xFF00; /* FixME: Max bus number */
22 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
26 /* FixME: support SI != 0 */
27 dev = dev_find_device(X86_DX, X86_CX, dev);
29 X86_BH = dev->bus->secondary;
30 X86_BL = dev->path.pci.devfn;
32 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
35 X86_AH = DEVICE_NOT_FOUND;
36 X86_EFLAGS |= FB_CF; /* set carry flag */
40 case FIND_PCI_CLASS_CODE:
41 /* FixME: support SI != 0 */
42 dev = dev_find_class(X86_ECX, dev);
44 X86_BH = dev->bus->secondary;
45 X86_BL = dev->path.pci.devfn;
47 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
50 X86_AH = DEVICE_NOT_FOUND;
51 X86_EFLAGS |= FB_CF; /* set carry flag */
55 case READ_CONFIG_BYTE:
56 dev = dev_find_slot(X86_BH, X86_BL);
58 X86_CL = pci_read_config8(dev, X86_DI);
60 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
63 X86_AH = DEVICE_NOT_FOUND;
64 X86_EFLAGS |= FB_CF; /* set carry flag */
68 case READ_CONFIG_WORD:
69 dev = dev_find_slot(X86_BH, X86_BL);
71 X86_CX = pci_read_config16(dev, X86_DI);
73 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
76 X86_AH = DEVICE_NOT_FOUND;
77 X86_EFLAGS |= FB_CF; /* set carry flag */
81 case READ_CONFIG_DWORD:
82 dev = dev_find_slot(X86_BH, X86_BL);
84 X86_ECX = pci_read_config32(dev, X86_DI);
86 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
89 X86_AH = DEVICE_NOT_FOUND;
90 X86_EFLAGS |= FB_CF; /* set carry flag */
94 case WRITE_CONFIG_BYTE:
95 dev = dev_find_slot(X86_BH, X86_BL);
97 pci_write_config8(dev, X86_DI, X86_CL);
99 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
102 X86_AH = DEVICE_NOT_FOUND;
103 X86_EFLAGS |= FB_CF; /* set carry flag */
107 case WRITE_CONFIG_WORD:
108 dev = dev_find_slot(X86_BH, X86_BL);
110 pci_write_config16(dev, X86_DI, X86_CX);
112 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
115 X86_AH = DEVICE_NOT_FOUND;
116 X86_EFLAGS |= FB_CF; /* set carry flag */
120 case WRITE_CONFIG_DWORD:
121 dev = dev_find_slot(X86_BH, X86_BL);
123 pci_write_config16(dev, X86_DI, X86_ECX);
125 X86_EFLAGS &= ~FB_CF; /* clear carry flag */
128 X86_AH = DEVICE_NOT_FOUND;
129 X86_EFLAGS |= FB_CF; /* set carry flag */
134 X86_AH = FUNC_NOT_SUPPORTED;