mirror of
git://nv-tegra.nvidia.com/tegra/gfx-src/nv-xconfig.git
synced 2025-12-22 09:22:53 +03:00
22a5c807291792a264b5acca7ff6d199468890b8 - nvidia-xconfig-35.6.2/Makefile 4cc77b90af91e615a64ae04893fdffa7939db84c - nvidia-xconfig-35.6.2/COPYING f14e9577e537037d4778d490ef70f13b0e94a70a - nvidia-xconfig-35.6.2/option_table.h 647e7896275a1113ec99352d573823a05001f57e - nvidia-xconfig-35.6.2/lscf.c 1e39095238886dfc6a69f7ec750e10c05a93e7d1 - nvidia-xconfig-35.6.2/nvidia-xconfig.1.m4 a5ad539267b73169480e7898b284823639c4db3a - nvidia-xconfig-35.6.2/tree.c b3d0f9f27c4d9cb7940d04e1dd387d357a16024c - nvidia-xconfig-35.6.2/nvidia-xconfig.c 46f2ea329459b0b16cb36cc14cec0de737d0963e - nvidia-xconfig-35.6.2/options.c 6f6f68f976250f2646450e571f9ab2d7eee1ac80 - nvidia-xconfig-35.6.2/nvidia-cfg.h 913b088cb559f31e09a1baf89d85d75cb43079b4 - nvidia-xconfig-35.6.2/nvidia-xconfig.h bfa37f78ba458f14a1865bbf3f67eb84987a7e1c - nvidia-xconfig-35.6.2/extract_edids.c d37da5a118e0418b267a48d05fd144611316b42c - nvidia-xconfig-35.6.2/gen-manpage-opts.c 41bcac41393c9a465c30c07cf1ab386647a16687 - nvidia-xconfig-35.6.2/util.c 9b0c02164398be2795fea7cb13c9e1b062d24bfb - nvidia-xconfig-35.6.2/query_gpu_info.c c946eefad99cec9366d8abbd4e45c5d138d3b7be - nvidia-xconfig-35.6.2/make_usable.c 10edc2c301fd331439b38d001c0df41669c238b2 - nvidia-xconfig-35.6.2/multiple_screens.c c7b8d8ca0f7c9dcc2cdca4f8e77d1122c71892ef - nvidia-xconfig-35.6.2/XF86Config-parser/Read.c a9bc06f33bf525c2b08be2dc3cd64a59c4c7946d - nvidia-xconfig-35.6.2/XF86Config-parser/Configint.h 2022a4a3c2a1b23a67ae74f50a3849f5f3a45e4b - nvidia-xconfig-35.6.2/XF86Config-parser/Keyboard.c 83b0a8efd6a508db54995688ab353591bdb242a2 - nvidia-xconfig-35.6.2/XF86Config-parser/Flags.c e67d630ef396ab7d34524c333f3a77fc42ba8fc6 - nvidia-xconfig-35.6.2/XF86Config-parser/configProcs.h f3d611bdbddfa64675a0810ef81dada57e224bcd - nvidia-xconfig-35.6.2/XF86Config-parser/Extensions.c 5ffb2caa5077a2e6ec1c5ece807e71503fb2fbce - nvidia-xconfig-35.6.2/XF86Config-parser/Module.c 7344be997921dec57959691e986763ee686888d5 - nvidia-xconfig-35.6.2/XF86Config-parser/Device.c 33211ca0a10f50e2c87b9e8feef6c1ab381b57a1 - nvidia-xconfig-35.6.2/XF86Config-parser/DRI.c 953b945f3b117d6fb44f1f738af17b6380a9ec72 - nvidia-xconfig-35.6.2/XF86Config-parser/Monitor.c 6c210ad0eaee1db3fec48ff01746cb054b4f9aaa - nvidia-xconfig-35.6.2/XF86Config-parser/Video.c 4407207cf890539dc604cff5b834c994b307729a - nvidia-xconfig-35.6.2/XF86Config-parser/Write.c de1c758e29f217e1a99e4c076d54ac84bce98b18 - nvidia-xconfig-35.6.2/XF86Config-parser/Screen.c c66a0a141e25e31b568fb9df41f17d7fb9e6d3b9 - nvidia-xconfig-35.6.2/XF86Config-parser/xf86Parser.h 9cbc29da282aa957f28b7fc83caf1e3b19ee2a52 - nvidia-xconfig-35.6.2/XF86Config-parser/Vendor.c 18711ff932af2202869a30f3b32d6d7fe7811c84 - nvidia-xconfig-35.6.2/XF86Config-parser/Layout.c cda3a4ab05bf48ba28af35b5c4c632e968afc7fa - nvidia-xconfig-35.6.2/XF86Config-parser/Util.c ec19d673a6a7d1d8f855f2d32d3e8f63046c3625 - nvidia-xconfig-35.6.2/XF86Config-parser/Files.c ac878b26ded86a3c502a6a81fc4c4a96162afefb - nvidia-xconfig-35.6.2/XF86Config-parser/Merge.c 0a274c4bc54b6ae0f6d009e443bda0cb033d66b5 - nvidia-xconfig-35.6.2/XF86Config-parser/Pointer.c 3f2238c88d737bd329a9bca1ac4b0bcf77bb9ac2 - nvidia-xconfig-35.6.2/XF86Config-parser/xf86tokens.h 45ceb0129668346ae3e52d81bb6e2f97efadf9d0 - nvidia-xconfig-35.6.2/XF86Config-parser/Input.c 4d9b03ea3badceb6bdfdf6589e6731140ec44079 - nvidia-xconfig-35.6.2/XF86Config-parser/Generate.c 04efe162cf6d97882f2bb87f3712d9a65c2320f3 - nvidia-xconfig-35.6.2/XF86Config-parser/Scan.c 5d55b94375c2055cfa1578e4c7f34c90e63a33f7 - nvidia-xconfig-35.6.2/common-utils/gen-manpage-opts-helper.c 384e36102dcd08ed4c5de05b5e3b8a7cdb2e257d - nvidia-xconfig-35.6.2/common-utils/nvgetopt.c dc2678d8a9d794a4b2b2718fce57ec087f21f54b - nvidia-xconfig-35.6.2/common-utils/common-utils.h aac5cbf0e68e1da4e646c316a7c0e620304ee16b - nvidia-xconfig-35.6.2/common-utils/msg.c e572cac43202f6c2af1c80b9e3901215126093ed - nvidia-xconfig-35.6.2/common-utils/nvgetopt.h 8a346196b052cfb1e06dd83d2ad1fe71e928d2b3 - nvidia-xconfig-35.6.2/common-utils/common-utils.c 1654638c567bc7f2bd70b54d807b498ab14c1061 - nvidia-xconfig-35.6.2/common-utils/nvpci-utils.h 8259a24058c714629f9819cc8c830ea9b202bb27 - nvidia-xconfig-35.6.2/common-utils/gen-manpage-opts-helper.h 524990f5497f9bbeb3d148b5e7dc8d2267c3163d - nvidia-xconfig-35.6.2/common-utils/nvpci-utils.c abb5c1b445d9353f2d2840bda848cd16109710a4 - nvidia-xconfig-35.6.2/common-utils/msg.h Change-Id: I99682b72c725a16fef77ba060c57fd78b05ae428
438 lines
12 KiB
C
438 lines
12 KiB
C
/*
|
|
* nvidia-xconfig: A tool for manipulating X config files,
|
|
* specifically for use by the NVIDIA Linux graphics driver.
|
|
*
|
|
* Copyright (C) 2005 NVIDIA Corporation
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms and conditions of the GNU General Public License,
|
|
* version 2, as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
* more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses>.
|
|
*
|
|
*
|
|
* make_usable.c
|
|
*/
|
|
|
|
#include <unistd.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
#include <sys/types.h>
|
|
|
|
#include "nvidia-xconfig.h"
|
|
#include "xf86Parser.h"
|
|
#include "configProcs.h"
|
|
#include "msg.h"
|
|
#include "nvpci-utils.h"
|
|
|
|
|
|
static void ensure_module_loaded(XConfigPtr config, char *name);
|
|
static int update_device(Options *op, XConfigPtr config, XConfigDevicePtr device);
|
|
static void update_depth(Options *op, XConfigScreenPtr screen);
|
|
static void update_display(Options *op, XConfigScreenPtr screen);
|
|
|
|
/*
|
|
* ensure_module_loaded() - make sure the given module is present
|
|
*/
|
|
|
|
static void ensure_module_loaded(XConfigPtr config, char *name) {
|
|
XConfigLoadPtr load;
|
|
int found = FALSE;
|
|
|
|
for (load = config->modules->loads; load && !found; load = load->next) {
|
|
if (xconfigNameCompare(name, load->name) == 0) found = TRUE;
|
|
}
|
|
|
|
if (!found) {
|
|
xconfigAddNewLoadDirective(&config->modules->loads,
|
|
name, XCONFIG_LOAD_MODULE,
|
|
NULL, FALSE);
|
|
}
|
|
} /* ensure_module_loaded */
|
|
|
|
/*
|
|
* update_modules() - make sure the glx module is present, and remove
|
|
* the GLcore and dri modules if they are present.
|
|
*/
|
|
|
|
int update_modules(XConfigPtr config)
|
|
{
|
|
XConfigLoadPtr load, next;
|
|
|
|
/*
|
|
* Return early if the original X configuration file lacked a
|
|
* "Module" section, and rely on the server's builtin list
|
|
* of modules to load, instead. We can safely do this if the
|
|
* X server is an X.Org server or XFree86 release >= 4.4.0. On
|
|
* installations with older XFree86 servers, the vendor's X
|
|
* configuration utility should have added a "Module" section
|
|
* we can extend, if necessary.
|
|
*/
|
|
if (config->modules == NULL)
|
|
return FALSE;
|
|
|
|
/* make sure all our required modules are loaded */
|
|
ensure_module_loaded(config, "glx");
|
|
#if defined(NV_SUNOS)
|
|
ensure_module_loaded(config, "xtsol");
|
|
#endif // defined(NV_SUNOS)
|
|
|
|
/* make sure GLcore and dri are not loaded */
|
|
|
|
load = config->modules->loads;
|
|
while (load) {
|
|
next = load->next;
|
|
if (xconfigNameCompare("GLcore", load->name) == 0) {
|
|
xconfigRemoveLoadDirective(&config->modules->loads, load);
|
|
} else if (xconfigNameCompare("dri", load->name) == 0) {
|
|
xconfigRemoveLoadDirective(&config->modules->loads, load);
|
|
}
|
|
load = next;
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
} /* update_modules() */
|
|
|
|
|
|
|
|
/*
|
|
* update_screen() - apply any requested updates to the given screen
|
|
*/
|
|
|
|
int update_screen(Options *op, XConfigPtr config, XConfigScreenPtr screen)
|
|
{
|
|
/* migrate any options from device to screen to avoid conflicts */
|
|
screen->options = xconfigOptionListMerge(screen->options,
|
|
screen->device->options);
|
|
screen->device->options = NULL;
|
|
|
|
update_display(op, screen);
|
|
update_depth(op, screen);
|
|
update_device(op, config, screen->device);
|
|
update_options(op, screen);
|
|
|
|
return TRUE;
|
|
|
|
} /* update_screen() */
|
|
|
|
|
|
|
|
/*
|
|
* get_layout() - get the right layout from the config that we should
|
|
* edit
|
|
*/
|
|
|
|
XConfigLayoutPtr get_layout(Options *op, XConfigPtr config)
|
|
{
|
|
XConfigLayoutPtr layout;
|
|
|
|
/* select a screenLayout to use */
|
|
|
|
if (op->layout) {
|
|
|
|
/* if a layout was specified on the commandline, use that */
|
|
|
|
layout = xconfigFindLayout(op->layout, config->layouts);
|
|
if (!layout) {
|
|
nv_error_msg("Unable to find layout \"%s\".\n", op->layout);
|
|
return NULL;
|
|
}
|
|
} else {
|
|
|
|
/* otherwise, use the first layout in the config file */
|
|
|
|
if (!config->layouts) {
|
|
nv_error_msg("unable to select ScreenLayout to use.\n");
|
|
return NULL;
|
|
}
|
|
|
|
layout = config->layouts;
|
|
}
|
|
|
|
return layout;
|
|
|
|
} /* get_layout() */
|
|
|
|
|
|
|
|
/*
|
|
* update_extensions() - apply any requested updates to the Extensions
|
|
* section; currently, this only applies to the Composite option.
|
|
*/
|
|
|
|
int update_extensions(Options *op, XConfigPtr config)
|
|
{
|
|
char *value;
|
|
|
|
/* validate the composite option against any other options specified */
|
|
|
|
validate_composite(op, config);
|
|
|
|
if (GET_BOOL_OPTION(op->boolean_options, COMPOSITE_BOOL_OPTION)) {
|
|
|
|
/* if we don't already have the Extensions section, create it now */
|
|
|
|
if (!config->extensions) {
|
|
config->extensions = calloc(1, sizeof(XConfigExtensionsRec));
|
|
}
|
|
|
|
/* remove any existing composite extension option */
|
|
xconfigRemoveNamedOption(&(config->extensions->options),
|
|
op->gop.compositeExtensionName,
|
|
NULL);
|
|
|
|
|
|
/* determine the value to set for the Composite option */
|
|
|
|
value = GET_BOOL_OPTION(op->boolean_option_values,
|
|
COMPOSITE_BOOL_OPTION) ?
|
|
"Enable" : "Disable";
|
|
|
|
/* add the option */
|
|
xconfigAddNewOption(&config->extensions->options,
|
|
op->gop.compositeExtensionName,
|
|
value);
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
} /* update_extensions() */
|
|
|
|
|
|
/*
|
|
* update_server_flags() - update the server flags section with any
|
|
* server flag options; the only option so far is "HandleSpecialKeys"
|
|
*/
|
|
|
|
int update_server_flags(Options *op, XConfigPtr config)
|
|
{
|
|
if (!op->handle_special_keys) return TRUE;
|
|
|
|
if (!config->flags) {
|
|
config->flags = nvalloc(sizeof(XConfigFlagsRec));
|
|
if ( !config->flags ) {
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if (config->flags->options) {
|
|
xconfigRemoveNamedOption(&(config->flags->options),
|
|
"HandleSpecialKeys", NULL);
|
|
}
|
|
|
|
if (op->handle_special_keys != NV_DISABLE_STRING_OPTION) {
|
|
xconfigAddNewOption(&config->flags->options, "HandleSpecialKeys",
|
|
op->handle_special_keys);
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
} /* update_server_flags() */
|
|
|
|
|
|
|
|
|
|
static int count_non_nv_gpus(void)
|
|
{
|
|
struct pci_device_iterator *iter;
|
|
struct pci_device *dev;
|
|
int count = 0;
|
|
|
|
if (pci_system_init()) {
|
|
return -1;
|
|
}
|
|
|
|
iter = nvpci_find_gpu_by_vendor(PCI_MATCH_ANY);
|
|
|
|
for (dev = pci_device_next(iter); dev; dev = pci_device_next(iter)) {
|
|
if (dev->vendor_id != NV_PCI_VENDOR_ID) {
|
|
count++;
|
|
}
|
|
}
|
|
|
|
pci_system_cleanup();
|
|
|
|
return count;
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
* update_device() - update the device; there is a lot of information
|
|
* in the device that is not relevant to the NVIDIA X driver. In
|
|
* fact, some options, like "Chipset" can actually prevent XFree86
|
|
* from using the NVIDIA driver. The simplest solution is to zero out
|
|
* the device, and only retain the few fields that are meaningful for
|
|
* the NVIDIA X driver.
|
|
*/
|
|
|
|
static int update_device(Options *op, XConfigPtr config, XConfigDevicePtr device)
|
|
{
|
|
char *identifier, *vendor, *comment, *board, *busid, *driver;
|
|
int screen;
|
|
size_t index_id;
|
|
XConfigDevicePtr next;
|
|
XConfigOptionPtr options;
|
|
|
|
next = device->next;
|
|
options = device->options;
|
|
identifier = device->identifier;
|
|
vendor = device->vendor;
|
|
comment = device->comment;
|
|
screen = device->screen;
|
|
board = device->board;
|
|
busid = device->busid;
|
|
driver = device->driver;
|
|
index_id = device->index_id;
|
|
|
|
memset(device, 0, sizeof(XConfigDeviceRec));
|
|
|
|
device->next = next;
|
|
device->options = options;
|
|
device->identifier = identifier;
|
|
device->vendor = vendor;
|
|
device->comment = comment;
|
|
device->screen = screen;
|
|
device->board = board;
|
|
device->index_id = index_id;
|
|
|
|
/*
|
|
* Considering five conditions, in order, while populating busid field
|
|
* 1. If the field is required for the configuration chosen and not passed in
|
|
* 2. If the user specified "--no-busid", obey that
|
|
* 3. If we want to write busid with option --busid
|
|
* 4. If we want to preserve existing bus id
|
|
* 5. If there are multiple screens
|
|
* 6. If the system has any non-NVIDIA GPUs
|
|
*/
|
|
|
|
if (GET_BOOL_OPTION(op->boolean_option_values, ENABLE_PRIME_OPTION) &&
|
|
op->busid == NULL) {
|
|
device->busid = nv_format_busid(op, device->index_id);
|
|
if (device->busid == NULL) {
|
|
return FALSE;
|
|
}
|
|
} else if (op->busid == NV_DISABLE_STRING_OPTION) {
|
|
device->busid = NULL;
|
|
} else if (op->busid) {
|
|
device->busid = op->busid;
|
|
} else if (GET_BOOL_OPTION(op->boolean_options,
|
|
PRESERVE_BUSID_BOOL_OPTION)) {
|
|
if (GET_BOOL_OPTION(op->boolean_option_values,
|
|
PRESERVE_BUSID_BOOL_OPTION)) {
|
|
device->busid = busid;
|
|
} else {
|
|
device->busid = NULL;
|
|
}
|
|
} else if (config->screens->next) {
|
|
/* enable_separate_x_screens() already generated a busid string */
|
|
device->busid = busid;
|
|
} else if (count_non_nv_gpus() > 0) {
|
|
device->busid = nv_format_busid(op, device->index_id);
|
|
if (device->busid == NULL) {
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
device->chipid = -1;
|
|
device->chiprev = -1;
|
|
device->irq = -1;
|
|
|
|
if (op->preserve_driver) {
|
|
device->driver = driver;
|
|
} else {
|
|
device->driver = "nvidia";
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
} /* update_device() */
|
|
|
|
|
|
|
|
/*
|
|
* update_depth() - make sure there is a display section with the
|
|
* default depth, and possibly update the default depth
|
|
*/
|
|
|
|
static void update_depth(Options *op, XConfigScreenPtr screen)
|
|
{
|
|
XConfigDisplayPtr display;
|
|
int found;
|
|
|
|
/* update the depth */
|
|
if ((op->depth == 8) || (op->depth == 15) ||
|
|
(op->depth == 16) || (op->depth == 24) ||
|
|
(op->depth == 30)) {
|
|
screen->defaultdepth = op->depth;
|
|
} else {
|
|
/* read the default depth to SVC and set it as the default depth */
|
|
int scf_depth;
|
|
|
|
if (read_scf_depth(&scf_depth) && scf_depth != screen->defaultdepth) {
|
|
nv_warning_msg("The default depth of %d read from "
|
|
"the Solaris Management Facility is set as the "
|
|
"default depth for screen \"%s\"", scf_depth,
|
|
screen->identifier);
|
|
screen->defaultdepth = scf_depth;
|
|
}
|
|
}
|
|
|
|
/*
|
|
* if there is no display at the default depth, force the first
|
|
* display section to that depth
|
|
*/
|
|
|
|
found = FALSE;
|
|
|
|
for (display = screen->displays; display; display = display->next) {
|
|
if (display->depth == screen->defaultdepth) {
|
|
found = TRUE;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!found) {
|
|
screen->displays->depth = screen->defaultdepth;
|
|
}
|
|
|
|
} /* update_depth() */
|
|
|
|
|
|
|
|
/*
|
|
* update_display() - if there are no display subsections, create one
|
|
*/
|
|
|
|
static void update_display(Options *op, XConfigScreenPtr screen)
|
|
{
|
|
|
|
if (!screen->displays) {
|
|
XConfigDisplayPtr display;
|
|
XConfigModePtr mode = NULL;
|
|
|
|
xconfigAddMode(&mode, "nvidia-auto-select");
|
|
|
|
display = nvalloc(sizeof(XConfigDisplayRec));
|
|
display->depth = screen->defaultdepth;
|
|
display->modes = mode;
|
|
display->frameX0 = -1;
|
|
display->frameY0 = -1;
|
|
display->black.red = -1;
|
|
display->white.red = -1;
|
|
|
|
screen->displays = display;
|
|
}
|
|
|
|
} /* update_display() */
|
|
|
|
|