1 /*
2 * Copyright 2008 Tungsten Graphics, Inc., Cedar Park, Texas.
3 * All Rights Reserved.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the
7 * "Software"), to deal in the Software without restriction, including
8 * without limitation the rights to use, copy, modify, merge, publish,
9 * distribute, sub license, and/or sell copies of the Software, and to
10 * permit persons to whom the Software is furnished to do so, subject to
11 * the following conditions:
12 *
13 * The above copyright notice and this permission notice (including the
14 * next paragraph) shall be included in all copies or substantial portions
15 * of the Software.
16 *
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
20 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
21 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
22 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
23 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24 *
25 *
26 * Author: Alan Hourihane <alanh@tungstengraphics.com>
27 * Author: Jakob Bornecrantz <wallbraker@gmail.com>
28 *
29 */
30
31 #include "../../state_trackers/xorg/xorg_winsys.h"
32
33 static void intel_xorg_identify(int flags);
34 static Bool intel_xorg_pci_probe(DriverPtr driver,
35 int entity_num,
36 struct pci_device *device,
37 intptr_t match_data);
38
39 static const struct pci_id_match intel_xorg_device_match[] = {
40 {0x8086, PCI_MATCH_ANY, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, 0},
41 {0, 0, 0},
42 };
43
44 static SymTabRec intel_xorg_chipsets[] = {
45 {PCI_MATCH_ANY, "Intel Graphics Device"},
46 {-1, NULL}
47 };
48
49 static PciChipsets intel_xorg_pci_devices[] = {
50 {PCI_MATCH_ANY, PCI_MATCH_ANY, NULL},
51 {-1, -1, NULL}
52 };
53
54 static XF86ModuleVersionInfo intel_xorg_version = {
55 "i915",
56 MODULEVENDORSTRING,
57 MODINFOSTRING1,
58 MODINFOSTRING2,
59 XORG_VERSION_CURRENT,
60 0, 1, 0, /* major, minor, patch */
61 ABI_CLASS_VIDEODRV,
62 ABI_VIDEODRV_VERSION,
63 MOD_CLASS_VIDEODRV,
64 {0, 0, 0, 0}
65 };
66
67 /*
68 * Xorg driver exported structures
69 */
70
71 _X_EXPORT DriverRec modesetting = {
72 1,
73 "modesetting",
74 intel_xorg_identify,
75 NULL,
76 xorg_tracker_available_options,
77 NULL,
78 0,
79 NULL,
80 intel_xorg_device_match,
81 intel_xorg_pci_probe
82 };
83
84 static MODULESETUPPROTO(intel_xorg_setup);
85
86 _X_EXPORT XF86ModuleData modesettingModuleData = {
87 &intel_xorg_version,
88 intel_xorg_setup,
89 NULL
90 };
91
92 /*
93 * Xorg driver functions
94 */
95
96 static pointer
intel_xorg_setup(pointer module,pointer opts,int * errmaj,int * errmin)97 intel_xorg_setup(pointer module, pointer opts, int *errmaj, int *errmin)
98 {
99 static Bool setupDone = 0;
100
101 /* This module should be loaded only once, but check to be sure.
102 */
103 if (!setupDone) {
104 setupDone = 1;
105 xf86AddDriver(&modesetting, module, HaveDriverFuncs);
106
107 /*
108 * The return value must be non-NULL on success even though there
109 * is no TearDownProc.
110 */
111 return (pointer) 1;
112 } else {
113 if (errmaj)
114 *errmaj = LDR_ONCEONLY;
115 return NULL;
116 }
117 }
118
119 static void
intel_xorg_identify(int flags)120 intel_xorg_identify(int flags)
121 {
122 xf86PrintChipsets("modesetting", "Driver for Modesetting Kernel Drivers",
123 intel_xorg_chipsets);
124 }
125
126 static Bool
intel_xorg_pci_probe(DriverPtr driver,int entity_num,struct pci_device * device,intptr_t match_data)127 intel_xorg_pci_probe(DriverPtr driver,
128 int entity_num, struct pci_device *device, intptr_t match_data)
129 {
130 ScrnInfoPtr scrn = NULL;
131 EntityInfoPtr entity;
132
133 scrn = xf86ConfigPciEntity(scrn, 0, entity_num, intel_xorg_pci_devices,
134 NULL, NULL, NULL, NULL, NULL);
135 if (scrn != NULL) {
136 scrn->driverVersion = 1;
137 scrn->driverName = "i915";
138 scrn->name = "modesetting";
139 scrn->Probe = NULL;
140
141 entity = xf86GetEntityInfo(entity_num);
142
143 /* Use all the functions from the xorg tracker */
144 xorg_tracker_set_functions(scrn);
145 }
146 return scrn != NULL;
147 }
148