Chameleon

Chameleon Svn Source Tree

Root/trunk/i386/libsaio/pci_setup.c

1#include "config.h"
2#include "libsaio.h"
3#include "boot.h"
4#include "bootstruct.h"
5#include "pci.h"
6#include "modules.h"
7
8#if DEBUG_PCI_SETUP
9#define DBG(x...)printf(x)
10#else
11#define DBG(x...)
12#endif
13
14extern bool setup_ati_devprop(pci_dt_t *ati_dev);
15extern bool setup_nvidia_devprop(pci_dt_t *nvda_dev);
16extern bool setup_gma_devprop(pci_dt_t *gma_dev);
17extern bool setup_hda_devprop(pci_dt_t *hda_dev);
18extern void setup_eth_devdrop(pci_dt_t *eth_dev);
19extern void setup_wifi_devdrop(pci_dt_t *wifi_dev);
20
21extern void notify_usb_dev(pci_dt_t *pci_dev);
22extern void force_enable_hpet(pci_dt_t *lpc_dev);
23
24extern pci_dt_t *dram_controller_dev;
25
26void setup_pci_devs(pci_dt_t *pci_dt)
27{
28char *devicepath;
29
30bool do_gfx_devprop = false;
31bool do_skip_n_devprop = false;
32bool do_skip_a_devprop = false;
33bool do_skip_i_devprop = false;
34
35bool do_enable_hpet = false;
36bool do_hda_devprop = false;
37
38pci_dt_t *current = pci_dt;
39
40// GraphicsEnabler
41getBoolForKey(kGraphicsEnabler, &do_gfx_devprop, &bootInfo->chameleonConfig);
42
43// Skip keys
44getBoolForKey(kSkipNvidiaGfx, &do_skip_n_devprop, &bootInfo->chameleonConfig);
45getBoolForKey(kSkipAtiGfx, &do_skip_a_devprop, &bootInfo->chameleonConfig);
46getBoolForKey(kSkipIntelGfx, &do_skip_i_devprop, &bootInfo->chameleonConfig);
47
48// HDAEnable
49getBoolForKey(kHDAEnabler, &do_hda_devprop, &bootInfo->chameleonConfig);
50
51// ForceHPET
52getBoolForKey(kForceHPET, &do_enable_hpet, &bootInfo->chameleonConfig);
53
54while (current)
55{
56devicepath = get_pci_dev_path(current);
57
58switch (current->class_id)
59{
60case PCI_CLASS_BRIDGE_HOST:
61DBG("Setup BRIDGE_HOST \n");
62if (current->dev.addr == PCIADDR(0, 0, 0))
63{
64dram_controller_dev = current;
65}
66break; // PCI_CLASS_BRIDGE_HOST
67
68case PCI_CLASS_NETWORK_ETHERNET:
69DBG("Setup ETHERNET %s enabled\n", do_eth_devprop? "is":"is not");
70verbose("[ ETHERNET DEVICE INFO ]\n");
71setup_eth_devdrop(current);
72verbose("\n");
73break; // PCI_CLASS_NETWORK_ETHERNET
74
75case PCI_CLASS_NETWORK_OTHER:
76DBG("Setup WIRELESS %s enabled\n", do_wifi_devprop? "is":"is not");
77verbose("[ WIRELESS DEVICE INFO ]\n");
78setup_wifi_devdrop(current);
79verbose("\n");
80break; // PCI_CLASS_NETWORK_OTHER
81
82case PCI_CLASS_DISPLAY_VGA:
83DBG("GraphicsEnabler %s enabled\n", do_gfx_devprop? "is":"is not");
84if (do_gfx_devprop)
85{
86switch (current->vendor_id)
87{
88case PCI_VENDOR_ID_ATI:
89if ( do_skip_a_devprop )
90{
91verbose("Skip ATi/AMD gfx device!\n");
92}
93else
94{
95verbose("[ ATi GFX DEVICE INFO ]\n");
96setup_ati_devprop(current);
97verbose("\n");
98}
99break; // PCI_VENDOR_ID_ATI
100
101case PCI_VENDOR_ID_INTEL:
102if ( do_skip_i_devprop )
103{
104verbose("Skip Intel gfx device!\n");
105}
106else
107{
108verbose("[ INTEL GMA DEVICE INFO ]\n");
109setup_gma_devprop(current);
110verbose("\n");
111}
112break; // PCI_VENDOR_ID_INTEL
113
114case PCI_VENDOR_ID_NVIDIA:
115if ( do_skip_n_devprop )
116{
117verbose("Skip Nvidia gfx device!\n");
118}
119else
120{
121verbose("[ NVIDIA GFX DEVICE INFO ]\n");
122setup_nvidia_devprop(current);
123verbose("\n");
124}
125break; // PCI_VENDOR_ID_NVIDIA
126
127default:
128break;
129}
130}
131break; // PCI_CLASS_DISPLAY_VGA
132
133case PCI_CLASS_MULTIMEDIA_AUDIO_DEV:
134DBG("Setup HDEF %s enabled\n", do_hda_devprop ? "is":"is not");
135if (do_hda_devprop)
136{
137verbose("[ AUDIO DEVICE INFO ]\n");
138setup_hda_devprop(current);
139verbose("\n");
140}
141break; // PCI_CLASS_MULTIMEDIA_AUDIO_DEV
142
143case PCI_CLASS_SERIAL_USB:
144DBG("USB\n");
145notify_usb_dev(current);
146break; // PCI_CLASS_SERIAL_USB
147
148case PCI_CLASS_SERIAL_FIREWIRE:
149DBG("FireWire\n");
150verbose("[ FIREWIRE DEVICE INFO ]\n");
151verbose("\tClass code: [%04X]\n\tFireWire device [%04x:%04x]-[%04x:%04x]\n\t%s\n",
152current->class_id,current->vendor_id, current->device_id,
153current->subsys_id.subsys.vendor_id,
154current->subsys_id.subsys.device_id, devicepath);
155//set_fwr_devdrop(current);
156verbose("\n");
157break; // PCI_CLASS_SERIAL_FIREWIRE
158
159case PCI_CLASS_BRIDGE_ISA:
160DBG("Force HPET %s enabled\n", do_enable_hpet ? "is":"is not");
161if (do_enable_hpet)
162{
163verbose("[ HPET ]\n");
164force_enable_hpet(current);
165verbose("\n");
166}
167break; // PCI_CLASS_BRIDGE_ISA
168
169}
170
171execute_hook("PCIDevice", current, NULL, NULL, NULL);
172DBG("setup_pci_devs current device ID = [%04x:%04x]\n", current->vendor_id, current->device_id);
173setup_pci_devs(current->children);
174current = current->next;
175}
176}
177

Archive Download this file

Revision: HEAD