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);
75verbose("\n");
76break; // PCI_CLASS_NETWORK_ETHERNET
77
78case PCI_CLASS_NETWORK_OTHER:
79DBG("Setup WIRELESS %s enabled\n", do_wifi_devprop? "is":"is not");
80verbose("[ WIRELESS DEVICE INFO ]\n");
81setup_wifi_devdrop(current);
82verbose("\n");
83break; // PCI_CLASS_NETWORK_OTHER
84
85case PCI_CLASS_DISPLAY_VGA:
86DBG("GraphicsEnabler %s enabled\n", do_gfx_devprop? "is":"is not");
87if (do_gfx_devprop)
88{
89switch (current->vendor_id)
90{
91case PCI_VENDOR_ID_ATI:
92if ( do_skip_a_devprop )
93{
94verbose("Skip ATi/AMD gfx device!\n");
95}
96else
97{
98verbose("[ ATi GFX DEVICE INFO ]\n");
99setup_ati_devprop(current);
100verbose("\n");
101}
102break; // PCI_VENDOR_ID_ATI
103
104case PCI_VENDOR_ID_INTEL:
105if ( do_skip_i_devprop )
106{
107verbose("Skip Intel gfx device!\n");
108}
109else
110{
111verbose("[ INTEL GMA DEVICE INFO ]\n");
112setup_gma_devprop(current);
113verbose("\n");
114}
115break; // PCI_VENDOR_ID_INTEL
116
117case PCI_VENDOR_ID_NVIDIA:
118if ( do_skip_n_devprop )
119{
120verbose("Skip Nvidia gfx device!\n");
121}
122else
123{
124verbose("[ NVIDIA GFX DEVICE INFO ]\n");
125setup_nvidia_devprop(current);
126verbose("\n");
127}
128break; // PCI_VENDOR_ID_NVIDIA
129
130default:
131break;
132}
133}
134break; // PCI_CLASS_DISPLAY_VGA
135
136case PCI_CLASS_MULTIMEDIA_AUDIO_DEV:
137DBG("Setup HDEF %s enabled\n", do_hda_devprop ? "is":"is not");
138if (do_hda_devprop)
139{
140verbose("[ AUDIO DEVICE INFO ]\n");
141setup_hda_devprop(current);
142verbose("\n");
143}
144break; // PCI_CLASS_MULTIMEDIA_AUDIO_DEV
145
146case PCI_CLASS_SERIAL_USB:
147DBG("USB\n");
148notify_usb_dev(current);
149break; // PCI_CLASS_SERIAL_USB
150
151case PCI_CLASS_SERIAL_FIREWIRE:
152DBG("FireWire\n");
153verbose("[ FIREWIRE DEVICE INFO ]\n");
154verbose("\tClass code: [%04X]\n\tFireWire device [%04x:%04x]-[%04x:%04x]\n\t%s\n",
155current->class_id,current->vendor_id, current->device_id,
156current->subsys_id.subsys.vendor_id,
157current->subsys_id.subsys.device_id, devicepath);
158//set_fwr_devdrop(current);
159verbose("\n");
160break; // PCI_CLASS_SERIAL_FIREWIRE
161
162case PCI_CLASS_BRIDGE_ISA:
163DBG("Force HPET %s enabled\n", do_enable_hpet ? "is":"is not");
164if (do_enable_hpet)
165{
166verbose("[ HPET ]\n");
167force_enable_hpet(current);
168verbose("\n");
169}
170break; // PCI_CLASS_BRIDGE_ISA
171
172}
173
174execute_hook("PCIDevice", current, NULL, NULL, NULL);
175DBG("setup_pci_devs current device ID = [%04x:%04x]\n", current->vendor_id, current->device_id);
176setup_pci_devs(current->children);
177current = current->next;
178}
179}
180

Archive Download this file

Revision: 2759