added new mga.setting to let the driver force a certain card to be used as primary in a system with multiple cards. The card in question gets a minus (-) before it's actual name so it's listed at the top in the /dev/graphics/ folder. It's a hack, but it's handy to have for now.

git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@15156 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Rudolf Cornelissen 2005-11-25 21:57:11 +00:00
parent 7c6865642c
commit a5b2cf2829
2 changed files with 52 additions and 30 deletions

View File

@ -119,16 +119,19 @@ static struct {
{0x0000, NULL} {0x0000, NULL}
}; };
static settings current_settings = { // see comments in mga.settings /* see comments in mga.settings */
// for driver static settings current_settings =
{
/* for kerneldriver */
DRIVER_PREFIX ".accelerant", DRIVER_PREFIX ".accelerant",
false, // dumprom "none", // primary
// for accelerant false, // dumprom
0x00000000, // logmask /* for accelerant */
0, // memory 0x00000000, // logmask
false, // usebios 0, // memory
false, // hardcursor false, // usebios
false, // greensync false, // hardcursor
false, // greensync
}; };
static void dumprom (void *rom, size_t size, pci_info pcii) static void dumprom (void *rom, size_t size, pci_info pcii)
@ -226,12 +229,16 @@ init_driver(void) {
const char *item; const char *item;
char *end; char *end;
uint32 value; uint32 value;
// for driver // for driver
item = get_driver_parameter (settings_handle, "accelerant", "", ""); item = get_driver_parameter (settings_handle, "accelerant", "", "");
if ((strlen (item) > 0) && (strlen (item) < sizeof (current_settings.accelerant) - 1)) { if ((strlen (item) > 0) && (strlen (item) < sizeof (current_settings.accelerant) - 1)) {
strcpy (current_settings.accelerant, item); strcpy (current_settings.accelerant, item);
} }
item = get_driver_parameter (settings_handle, "primary", "", "");
if ((strlen (item) > 0) && (strlen (item) < sizeof (current_settings.primary) - 1)) {
strcpy (current_settings.primary, item);
}
current_settings.dumprom = get_driver_boolean_parameter (settings_handle, "dumprom", false, false); current_settings.dumprom = get_driver_boolean_parameter (settings_handle, "dumprom", false, false);
// for accelerant // for accelerant
@ -562,28 +569,41 @@ static void unmap_device(device_info *di) {
di->regs = NULL; di->regs = NULL;
} }
static void probe_devices(void) { static void probe_devices(void)
{
uint32 pci_index = 0; uint32 pci_index = 0;
uint32 count = 0; uint32 count = 0;
device_info *di = pd->di; device_info *di = pd->di;
char tmp_name[B_OS_NAME_LENGTH];
/* while there are more pci devices */ /* while there are more pci devices */
while ((count < MAX_DEVICES) && ((*pci_bus->get_nth_pci_info)(pci_index, &(di->pcii)) == B_NO_ERROR)) { while ((count < MAX_DEVICES) && ((*pci_bus->get_nth_pci_info)(pci_index, &(di->pcii)) == B_NO_ERROR))
{
int vendor = 0; int vendor = 0;
/* if we match a supported vendor */ /* if we match a supported vendor */
while (SupportedDevices[vendor].vendor) { while (SupportedDevices[vendor].vendor)
if (SupportedDevices[vendor].vendor == di->pcii.vendor_id) { {
if (SupportedDevices[vendor].vendor == di->pcii.vendor_id)
{
uint16 *devices = SupportedDevices[vendor].devices; uint16 *devices = SupportedDevices[vendor].devices;
/* while there are more supported devices */ /* while there are more supported devices */
while (*devices) { while (*devices)
{
/* if we match a supported device */ /* if we match a supported device */
if (*devices == di->pcii.device_id ) { if (*devices == di->pcii.device_id )
{
/* publish the device name */ /* publish the device name */
sprintf(di->name, "graphics/" DEVICE_FORMAT, sprintf(tmp_name, DEVICE_FORMAT,
di->pcii.vendor_id, di->pcii.device_id, di->pcii.vendor_id, di->pcii.device_id,
di->pcii.bus, di->pcii.device, di->pcii.function); di->pcii.bus, di->pcii.device, di->pcii.function);
/* tweak the exported name to show first in the alphabetically ordered /dev/
* hierarchy folder, so the system will use it as primary adaptor if requested
* via mga.settings. */
if (strcmp(tmp_name, current_settings.primary) == 0)
sprintf(tmp_name, "-%s", current_settings.primary);
/* add /dev/ hierarchy path */
sprintf(di->name, "graphics/%s", tmp_name);
/* remember the name */ /* remember the name */
pd->device_names[count] = di->name; pd->device_names[count] = di->name;
/* mark the driver as available for R/W open */ /* mark the driver as available for R/W open */
@ -609,6 +629,7 @@ next_device:
/* next pci_info struct, please */ /* next pci_info struct, please */
pci_index++; pci_index++;
} }
/* propagate count */ /* propagate count */
pd->count = count; pd->count = count;
/* terminate list of device names with a null pointer */ /* terminate list of device names with a null pointer */

View File

@ -4,18 +4,19 @@
# ~/config/settings/kernel/drivers/ # ~/config/settings/kernel/drivers/
# #
# mga.driver parameters # mga.driver parameters:
# accelerant "mga.accelerant" #accelerant "mga.accelerant" # if enabled selects accelerant filename to be used
#primary "102b_0521_020000" # if enabled selects device to be used as primary device ('hack')
dumprom false # dump bios rom to file (in home folder)
# mga.accelerant parameters # mga.accelerant parameters:
usebios false # if true rely on bios to coldstart the card instead of driver usebios false # if true rely on bios to coldstart the card instead of driver
#memory 2 # in MB, override builtin memory size detection #memory 2 # in MB, override builtin memory size detection
hardcursor true # if true use on-chip cursor capabilities hardcursor true # if true use on-chip cursor capabilities
#logmask 0x00000000 # nothing logged, except errors, is default #logmask 0x00000000 # nothing logged, is default
#logmask 0x08000604 # log overlay use in full #logmask 0x08000604 # log overlay use in full to file (in home folder)
#logmask 0xffffffff # log everything #logmask 0xffffffff # log everything to file (in home folder)
dumprom false # dump bios rom in ~/mga.rom greensync false # if true generate sync on green output signal
greensync false # if true generate sync on green output signal
#--------- that's all. #--------- that's all.