Chameleon

Chameleon Svn Source Tree

Root/trunk/i386/libsaio/pci_setup.c

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

Archive Download this file

Revision: 2687