Root/
Source at commit 2605 created 9 years 4 months ago. By ifabio, Temp disabled feature introduced in commit 2562 (Added ability to auto-select last booted partition as the boot volume), cause AllocateKernelMemory error. | |
---|---|
1 | #include "libsaio.h"␊ |
2 | #include "boot.h"␊ |
3 | #include "bootstruct.h"␊ |
4 | #include "pci.h"␊ |
5 | #include "gma.h"␊ |
6 | #include "nvidia.h"␊ |
7 | #include "hda.h"␊ |
8 | #include "modules.h"␊ |
9 | ␊ |
10 | ␊ |
11 | extern bool setup_ati_devprop(pci_dt_t *ati_dev);␊ |
12 | extern bool setup_nvidia_devprop(pci_dt_t *nvda_dev);␊ |
13 | extern bool setup_gma_devprop(pci_dt_t *gma_dev);␊ |
14 | extern bool setup_hda_devprop(pci_dt_t *hda_dev);␊ |
15 | extern void set_eth_builtin(pci_dt_t *eth_dev);␊ |
16 | extern void notify_usb_dev(pci_dt_t *pci_dev);␊ |
17 | extern void force_enable_hpet(pci_dt_t *lpc_dev);␊ |
18 | ␊ |
19 | extern pci_dt_t *dram_controller_dev;␊ |
20 | ␊ |
21 | void setup_pci_devs(pci_dt_t *pci_dt)␊ |
22 | {␊ |
23 | ␉char *devicepath;␊ |
24 | ␉bool doit, do_eth_devprop, do_gfx_devprop, do_enable_hpet, do_hda_devprop;␊ |
25 | ␉pci_dt_t *current = pci_dt;␊ |
26 | ␊ |
27 | ␉do_eth_devprop = do_gfx_devprop = do_enable_hpet = do_hda_devprop = false;␊ |
28 | ␊ |
29 | ␉getBoolForKey(kEthernetBuiltIn, &do_eth_devprop, &bootInfo->chameleonConfig);␊ |
30 | ␉getBoolForKey(kGraphicsEnabler, &do_gfx_devprop, &bootInfo->chameleonConfig);␊ |
31 | ␉getBoolForKey(kHDAEnabler, &do_hda_devprop, &bootInfo->chameleonConfig);␊ |
32 | ␉getBoolForKey(kForceHPET, &do_enable_hpet, &bootInfo->chameleonConfig);␊ |
33 | ␊ |
34 | ␉while (current)␊ |
35 | ␉{␊ |
36 | ␉␉devicepath = get_pci_dev_path(current);␊ |
37 | ␊ |
38 | ␉␉switch (current->class_id)␊ |
39 | ␉␉{␊ |
40 | ␉␉␉case PCI_CLASS_BRIDGE_HOST:␊ |
41 | ␉␉␉␉if (current->dev.addr == PCIADDR(0, 0, 0))␊ |
42 | ␉␉␉␉{␊ |
43 | ␉␉␉␉␉dram_controller_dev = current;␊ |
44 | ␉␉␉␉}␊ |
45 | ␉␉␉␉break;␊ |
46 | ␉␉␉␉␊ |
47 | ␉␉␉case PCI_CLASS_NETWORK_ETHERNET: ␊ |
48 | ␉␉␉␉if (do_eth_devprop)␊ |
49 | ␉␉␉␉{␊ |
50 | ␉␉␉␉␉set_eth_builtin(current);␊ |
51 | ␉␉␉␉}␊ |
52 | ␉␉␉␉break;␊ |
53 | ␊ |
54 | ␉␉␉case PCI_CLASS_DISPLAY_VGA:␊ |
55 | ␉␉␉␉if (do_gfx_devprop)␊ |
56 | ␉␉␉␉{␊ |
57 | ␉␉␉␉␉switch (current->vendor_id)␊ |
58 | ␉␉␉␉␉{␊ |
59 | ␉␉␉␉␉␉case PCI_VENDOR_ID_ATI:␊ |
60 | ␉␉␉␉␉␉␉if (getBoolForKey(kSkipAtiGfx, &doit, &bootInfo->chameleonConfig) && doit)␊ |
61 | ␉␉␉␉␉␉␉{␊ |
62 | ␉␉␉␉␉␉␉␉verbose("Skip ATi/AMD gfx device!\n");␊ |
63 | ␉␉␉␉␉␉␉}␊ |
64 | ␉␉␉␉␉␉␉else␊ |
65 | ␉␉␉␉␉␉␉{␊ |
66 | ␉␉␉␉␉␉␉␉setup_ati_devprop(current);␊ |
67 | ␉␉␉␉␉␉␉}␊ |
68 | ␉␉␉␉␉␉␉break;␊ |
69 | ␊ |
70 | ␉␉␉␉␉␉case PCI_VENDOR_ID_INTEL:␊ |
71 | ␉␉␉␉␉␉␉if (getBoolForKey(kSkipIntelGfx, &doit, &bootInfo->chameleonConfig) && doit)␊ |
72 | ␉␉␉␉␉␉␉{␊ |
73 | ␉␉␉␉␉␉␉␉verbose("Skip Intel gfx device!\n");␊ |
74 | ␉␉␉␉␉␉␉}␊ |
75 | ␉␉␉␉␉␉␉else␊ |
76 | ␉␉␉␉␉␉␉{␊ |
77 | ␉␉␉␉␉␉␉␉setup_gma_devprop(current);␊ |
78 | ␉␉␉␉␉␉␉}␊ |
79 | ␉␉␉␉␉␉␉break;␊ |
80 | ␊ |
81 | ␉␉␉␉␉␉case PCI_VENDOR_ID_NVIDIA:␊ |
82 | ␉␉␉␉␉␉␉if (getBoolForKey(kSkipNvidiaGfx, &doit, &bootInfo->chameleonConfig) && doit)␊ |
83 | ␉␉␉␉␉␉␉{␊ |
84 | ␉␉␉␉␉␉␉␉verbose("Skip Nvidia gfx device!\n");␊ |
85 | ␉␉␉␉␉␉␉}␊ |
86 | ␉␉␉␉␉␉␉␉else␊ |
87 | ␉␉␉␉␉␉␉{␊ |
88 | ␉␉␉␉␉␉␉␉setup_nvidia_devprop(current);␊ |
89 | ␉␉␉␉␉␉␉}␊ |
90 | ␉␉␉␉␉␉␉break;␊ |
91 | ␉␉␉␉␉␉}␊ |
92 | ␉␉␉␉␉}␊ |
93 | ␉␉␉␉␉break;␊ |
94 | ␊ |
95 | ␉␉␉case PCI_CLASS_MULTIMEDIA_AUDIO_DEV:␊ |
96 | ␉␉␉␉if (do_hda_devprop)␊ |
97 | ␉␉␉␉{␊ |
98 | ␉␉␉␉␉setup_hda_devprop(current);␊ |
99 | ␉␉␉␉}␊ |
100 | ␉␉␉␉break;␊ |
101 | ␊ |
102 | ␉␉␉case PCI_CLASS_SERIAL_USB:␊ |
103 | ␉␉␉␉notify_usb_dev(current);␊ |
104 | ␉␉␉␉break;␊ |
105 | ␊ |
106 | ␉␉␉case PCI_CLASS_BRIDGE_ISA:␊ |
107 | ␉␉␉␉if (do_enable_hpet)␊ |
108 | ␉␉␉␉{␊ |
109 | ␉␉␉␉␉force_enable_hpet(current);␊ |
110 | ␉␉␉␉}␊ |
111 | ␉␉␉␉break;␊ |
112 | ␉␉}␊ |
113 | ␉␉␊ |
114 | ␉␉execute_hook("PCIDevice", current, NULL, NULL, NULL);␊ |
115 | ␉␉␊ |
116 | ␉␉setup_pci_devs(current->children);␊ |
117 | ␉␉current = current->next;␊ |
118 | ␉}␊ |
119 | }␊ |
120 |