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:
parent
7c6865642c
commit
a5b2cf2829
@ -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 */
|
||||||
|
@ -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.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user