xfree86: Do not use uninitialized pointer during probe
Commitsb5dffbb
andd75ffcd
introduce code in xf86platformProbe() that references a member of xf86configptr. However, when using the "-configure" option, xf86configptr may not be initialized when xf86platformProbe() is called. Avoid referencing a member of xf86configptr if uninitialized. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=100405 Signed-off-by: Jeff Smith <whydoubt@gmail.com> Reviewed-by: Adam Jackson <ajax@redhat.com>
This commit is contained in:
parent
1e23f03dd5
commit
1a24a0ae7b
|
@ -276,7 +276,8 @@ xf86platformProbe(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
Bool pci = TRUE;
|
Bool pci = TRUE;
|
||||||
XF86ConfOutputClassPtr cl;
|
XF86ConfOutputClassPtr cl, cl_head = (xf86configptr) ?
|
||||||
|
xf86configptr->conf_outputclass_lst : NULL;
|
||||||
char *old_path, *path = NULL;
|
char *old_path, *path = NULL;
|
||||||
|
|
||||||
config_odev_probe(xf86PlatformDeviceProbe);
|
config_odev_probe(xf86PlatformDeviceProbe);
|
||||||
|
@ -296,7 +297,7 @@ xf86platformProbe(void)
|
||||||
* Deal with OutputClass ModulePath directives, these must be
|
* Deal with OutputClass ModulePath directives, these must be
|
||||||
* processed before we do any module loading.
|
* processed before we do any module loading.
|
||||||
*/
|
*/
|
||||||
for (cl = xf86configptr->conf_outputclass_lst; cl; cl = cl->list.next) {
|
for (cl = cl_head; cl; cl = cl->list.next) {
|
||||||
if (!OutputClassMatches(cl, &xf86_platform_devices[i]))
|
if (!OutputClassMatches(cl, &xf86_platform_devices[i]))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
@ -317,7 +318,7 @@ xf86platformProbe(void)
|
||||||
/* First see if there is an OutputClass match marking a device as primary */
|
/* First see if there is an OutputClass match marking a device as primary */
|
||||||
for (i = 0; i < xf86_num_platform_devices; i++) {
|
for (i = 0; i < xf86_num_platform_devices; i++) {
|
||||||
struct xf86_platform_device *dev = &xf86_platform_devices[i];
|
struct xf86_platform_device *dev = &xf86_platform_devices[i];
|
||||||
for (cl = xf86configptr->conf_outputclass_lst; cl; cl = cl->list.next) {
|
for (cl = cl_head; cl; cl = cl->list.next) {
|
||||||
if (!OutputClassMatches(cl, dev))
|
if (!OutputClassMatches(cl, dev))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue