3 <TITLE>Compilation and Installation
</TITLE>
5 <link rel=
"stylesheet" type=
"text/css" href=
"mesa.css"></head>
10 <H1>Compilation and Installation
</H1>
13 <li><a href=
"#unix-x11">Unix / X11
</a>
14 <li><a href=
"#windows">Windows
</a>
15 <li><a href=
"#vms">VMS
</a>
16 <li><a href=
"#other">Other
</a>
22 <H2>1. Unix/X11 Compilation and Installation
</H1>
24 <h3>1.1 Compilation
</h3>
27 Mesa may be compiled in several different ways:
30 <li><b><em>Stand-alone/Xlib mode
</em></b> - Mesa is compiled as
31 a software renderer using Xlib to do all rendering.
32 libGL.so is a self-contained rendering library.
34 To compile stand-alone Mesa type
<b>make
</b> in the top-level directory.
35 You'll see a list of supported system configurations.
36 Choose one from the list (such as linux-x86), and type:
41 <p>This will produce libGL.so and several other libraries
</p>
44 <li><b><em>DRI/accelerated
</em></b> - The DRI hardware drivers (for ATI,
45 Intel, Matrox, etc) are built.
46 libGL.so implements the GLX extension and dynamically loads the DRI drivers.
48 To build the DRI drivers you'll first need to have the DRM (Direct
49 Rendering Manager) kernel drivers and header files.
50 They're available from the
<a href=
"http://dri.sf.net/" target=
"_parent">DRI
</a> project.
53 You can get them from CVS by doing:
55 cvs -d:pserver:anonymous@pds.freedesktop.org:/cvs/dri login
56 (hit enter when prompted for a password)
57 cvs -z3 -d:pserver:anonymous@pdx.freedesktop.org:/cvs/dri co drm
60 Make note of the directory in which the drm files are placed.
63 See the
<a href=
"http://dri.freedesktop.org/wiki/Building" target=
"_parent">
64 DRI Building Instructions
</a> for the steps to build the DRM modules.
67 Next, in the
<code>Mesa-x.y.z/configs/default
</code> file, set the
68 <code>DRM_SOURCE_PATH
</code> variable to indicate where the DRM files
72 Now build Mesa and the DRI drivers by running
78 There are also
<code>linux-dri-x86
</code>,
<code>linux-dri-x86-
64</code>,
79 and
<code>linux-ppc
</code> configurations, optimized for those architectures.
83 Finally, you'll need a DRI-enabled X server from
84 <a href=
"http://freedesktop.org/wiki/Software_2fXserver" target=
"_parent">
85 X.org
</a> or
<a href=
"http://www.xfree86.org" target=
"_parent">XFree86
</a>.
86 Visit those projects' home pages for more information.
94 Later, if you want to rebuild for a different configuration run
95 <code>make realclean
</code> before rebuilding.
99 <h3>1.2 The libraries
</h3>
102 When compilation has finished, look in the top-level
<code>lib/
</code>
104 You'll see a set of library files similar to this:
107 lrwxrwxrwx
1 brian users
10 Mar
26 07:
53 libGL.so -
> libGL.so
.1*
108 lrwxrwxrwx
1 brian users
19 Mar
26 07:
53 libGL.so
.1 -
> libGL.so
.1.5.060100*
109 -rwxr-xr-x
1 brian users
3375861 Mar
26 07:
53 libGL.so
.1.5.060100*
110 lrwxrwxrwx
1 brian users
11 Mar
26 07:
53 libGLU.so -
> libGLU.so
.1*
111 lrwxrwxrwx
1 brian users
20 Mar
26 07:
53 libGLU.so
.1 -
> libGLU.so
.1.3.060100*
112 -rwxr-xr-x
1 brian users
549269 Mar
26 07:
53 libGLU.so
.1.3.060100*
113 lrwxrwxrwx
1 brian users
12 Mar
26 07:
53 libglut.so -
> libglut.so
.3*
114 lrwxrwxrwx
1 brian users
16 Mar
26 07:
53 libglut.so
.3 -
> libglut.so
.3.7.1*
115 -rwxr-xr-x
1 brian users
597754 Mar
26 07:
53 libglut.so
.3.7.1*
116 lrwxrwxrwx
1 brian users
11 Mar
26 08:
04 libGLw.so -
> libGLw.so
.1*
117 lrwxrwxrwx
1 brian users
15 Mar
26 08:
04 libGLw.so
.1 -
> libGLw.so
.1.0.0*
118 -rwxr-xr-x
1 brian users
20750 Mar
26 08:
04 libGLw.so
.1.0.0*
119 lrwxrwxrwx
1 brian users
14 Mar
26 07:
53 libOSMesa.so -
> libOSMesa.so
.6*
120 lrwxrwxrwx
1 brian users
23 Mar
26 07:
53 libOSMesa.so
.6 -
> libOSMesa.so
.6.1.060100*
121 -rwxr-xr-x
1 brian users
23871 Mar
26 07:
53 libOSMesa.so
.6.1.060100*
125 <b>libGL
</b> is the main OpenGL library (i.e. Mesa).
127 <b>libGLU
</b> is the OpenGL Utility library.
129 <b>libglut
</b> is the GLUT library.
131 <b>libGLw
</b> is the Xt/Motif OpenGL drawing area widget library.
133 <b>libOSMesa
</b> is the OSMesa (Off-Screen) interface library.
137 If you built the DRI hardware drivers, you'll also see the DRI drivers:
140 -rwxr-xr-x
1 brian users
11320803 Jul
21 12:
11 mach64_dri.so
141 -rwxr-xr-x
1 brian users
11418014 Jul
21 12:
12 mga_dri.so
142 -rwxr-xr-x
1 brian users
11064426 Jul
21 12:
12 r128_dri.so
143 -rwxr-xr-x
1 brian users
11849858 Jul
21 12:
12 r200_dri.so
144 -rwxr-xr-x
1 brian users
11757388 Jul
21 12:
12 radeon_dri.so
145 -rwxr-xr-x
1 brian users
11232304 Jul
21 12:
13 s3v_dri.so
146 -rwxr-xr-x
1 brian users
11062970 Jul
21 12:
13 savage_dri.so
147 -rwxr-xr-x
1 brian users
11214212 Jul
21 12:
13 sis_dri.so
148 -rwxr-xr-x
1 brian users
11368736 Jul
21 12:
13 tdfx_dri.so
149 -rwxr-xr-x
1 brian users
10598868 Jul
21 12:
13 trident_dri.so
150 -rwxr-xr-x
1 brian users
10997120 Jul
21 12:
13 unichrome_dri.so
154 <h3>1.3 Running the demos
</h3>
157 If you downloaded/unpacked the MesaDemos-x.y.z.tar.gz archive or
158 obtained Mesa from CVS, the
<b>progs/
</b> directory will contain a
159 bunch of demonstration programs.
163 Before running a demo, you may have to set an environment variable
164 (such as
<b>LD_LIBRARY_PATH
</b> on Linux) to indicate where the
165 libraries are located. For example:
168 <b>cd
</b> into the Mesa
<b>lib/
</b> directory.
170 <b>setenv LD_LIBRARY_PATH ${cwd}
</b> (if using csh or tcsh shell)
174 <b>export LD_LIBRARY_PATH=${PWD}
</b> (if using bash or sh shell)
178 Next, change to the Mesa/demos/ directory:
181 <b>cd ../progs/demos
</b>
185 Run a demo such as gears:
192 If this doesn't work, try the
<b>Mesa/progs/xdemos/glxinfo
</b> program
193 and see that it prints the expected Mesa version number.
197 If you're using Linux or a similar OS, verify that the demo program is
198 being linked with the proper library files:
205 You should see something like this:
208 libglut.so
.3 =
> /home/brian/Mesa/lib/libglut.so
.3 (
0x40013000)
209 libGLU.so
.1 =
> /home/brian/Mesa/lib/libGLU.so
.1 (
0x40051000)
210 libGL.so
.1 =
> /home/brian/Mesa/lib/libGL.so
.1 (
0x400e0000)
211 libc.so
.6 =
> /lib/i686/libc.so
.6 (
0x42000000)
212 libm.so
.6 =
> /lib/i686/libm.so
.6 (
0x403da000)
213 libX11.so
.6 =
> /usr/X11R6/lib/libX11.so
.6 (
0x403fc000)
214 libXmu.so
.6 =
> /usr/X11R6/lib/libXmu.so
.6 (
0x404da000)
215 libXt.so
.6 =
> /usr/X11R6/lib/libXt.so
.6 (
0x404f1000)
216 libXi.so
.6 =
> /usr/X11R6/lib/libXi.so
.6 (
0x40543000)
217 libstdc++.so
.5 =
> /usr/lib/libstdc++.so
.5 (
0x4054b000)
218 libgcc_s.so
.1 =
> /lib/libgcc_s.so
.1 (
0x405fd000)
219 libXext.so
.6 =
> /usr/X11R6/lib/libXext.so
.6 (
0x40605000)
220 libpthread.so
.0 =
> /lib/i686/libpthread.so
.0 (
0x40613000)
221 /lib/ld-linux.so
.2 =
> /lib/ld-linux.so
.2 (
0x40000000)
222 libdl.so
.2 =
> /lib/libdl.so
.2 (
0x40644000)
223 libSM.so
.6 =
> /usr/X11R6/lib/libSM.so
.6 (
0x40647000)
224 libICE.so
.6 =
> /usr/X11R6/lib/libICE.so
.6 (
0x40650000)
228 Retrace your steps if this doesn't look right.
232 <H3>1.4 Installing the header and library files
</H3>
235 The standard location for the OpenGL header files on Unix-type systems is
236 in
<code>/usr/include/GL/
</code>.
237 The standard location for the libraries is
<code>/usr/lib/
</code>.
238 For more information see, the
239 <a href=
"http://oss.sgi.com/projects/ogl-sample/ABI/" target=
"_parent">
240 Linux/OpenGL ABI specification
</a>.
244 If you'd like Mesa to co-exist with another implementation of OpenGL that's
245 already installed, you'll have to choose different directories, like
246 <code>/usr/local/include/GL/
</code> and
<code>/usr/local/lib/
</code>.
250 To install Mesa's headers and libraries, run
<code>make install
</code>
251 You'll be prompted to enter alternative directories for the headers
256 Note: at runtime, you can set the LD_LIBRARY_PATH (on Linux) to switch
257 between the Mesa libs and another vendor libs whenever you want.
258 This is a handy way to compare multiple OpenGL implementations.
264 <H2>2. Windows Compilation and Installation
</H1>
267 Please see the
<a href=
"README.WIN32">README.WIN32
</a> file.
274 <H2>3. VMS Compilation and Installation
</H1>
277 Please see the
<a href=
"README.VMS">README.VMS
</a> file.
284 <H2>4. Other systems
</H1>
287 Documentation for other environments (some may be very out of date):
291 <LI><A HREF=
"README.GGI">README.GGI
</A> - GGI
292 <LI><A HREF=
"README.3DFX">README
.3DFX
</A> -
3Dfx/Glide driver
293 <LI><A HREF=
"README.AMIWIN">README.AMIWIN
</A> - Amiga Amiwin
294 <LI><A HREF=
"README.BEOS">README.BEOS
</A> - BeOS
295 <LI><A HREF=
"README.D3D">README.D3D
</A> - Direct3D driver
296 <LI><A HREF=
"README.DJ">README.DJ
</A> - DJGPP
297 <LI><A HREF=
"README.LYNXOS">README.LYNXOS
</A> - LynxOS
298 <LI><A HREF=
"README.MINGW32">README.MINGW32
</A> - Mingw32
299 <LI><A HREF=
"README.NeXT">README.NeXT
</A> - NeXT
300 <LI><A HREF=
"README.OpenStep">README.OpenStep
</A> - OpenStep
301 <LI><A HREF=
"README.OS2">README.OS2
</A> - OS/
2
302 <LI><A HREF=
"README.WINDML">README.WINDML
</A> - WindML