summaryrefslogtreecommitdiff
path: root/sgml/Darwin.sgml
blob: d92e60e95afd5fea1fe0661459112c396adfa35e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
<!DOCTYPE linuxdoc PUBLIC "-//XFree86//DTD linuxdoc//EN" [
<!ENTITY % defs SYSTEM "defs.ent"> %defs;
]>

<article>
<title>XFree86 on Darwin and Mac OS X
<author>Torrey T. Lyons, <email>torrey@mrcla.com</email>
<date>12 December 2001

<ident>
$XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/Darwin.sgml,v 1.9 2001/12/13 07:09:05 torrey Exp $
</ident>

<toc>

<sect>Introduction
<p>
<htmlurl url="http://www.xfree86.org/" name="XFree86">, a freely
redistributable open-source implementation of the <htmlurl
url="http://www.x.org/" name="X Window System">, has been ported to <htmlurl
url="http://www.opensource.apple.com/projects/darwin/" name="Darwin">
and <htmlurl url="http://www.apple.com/macosx/" name="Mac OS X">. This
document is a collection of information for anyone
running XFree86 on Apple's next generation operating system.

<p>
Most of the current work on XFree86 for Darwin and Mac OS&nbsp;X is centered
around the <htmlurl url="http://sourceforge.net/projects/xonx/"
name="XonX project"> at <htmlurl url="http://sourceforge.net"
name="SourceForge">. If you are interested in up-to-date status, want to
report a bug, or are interested in working on XFree86 for Darwin, stop by the
<htmlurl url="http://sourceforge.net/projects/xonx/" name="XonX project">.

<sect>Hardware Support and Configuration
<p>
The X window server for Darwin and Mac OS&nbsp;X provided by the <htmlurl
url="http://www.XFree86.Org/" name="XFree86 Project, Inc."> is called
XDarwin. XDarwin can run in three different modes. On Mac OS&nbsp;X,
XDarwin runs in parallel with Aqua in full screen or rootless modes.
These modes are called Quartz modes, named after the Quartz 2D compositing
engine used by Aqua. XDarwin can also be run from the Darwin console in
IOKit mode.

<p>
In full screen Quartz mode, when the X Window System is active, it takes
over the entire screen. You can switch back to the Mac OS&nbsp;X desktop
by holding down Command-Option-A. This key combination can be changed in
the user preferences. From the Mac OS&nbsp;X desktop, click on the XDarwin
icon in the Dock to switch back to the X window system. (You can change
this behavior in the user preferences so that you must click the XDarwin
icon in the floating switch window instead.)

<p>In rootless mode, the X window system and Aqua share your display.
The root window of the X11 display is the size of the screen and contains
all the other windows. The X11 root window is not displayed in rootless
mode as Aqua handles the desktop background.

<p>
From the console, the Darwin port of XFree86 uses the IOKit for device
driver loading and discovery, rather than the XFree86 module loader.
Because of this, the XFree86 configuration file is not used on Darwin
or Mac OS&nbsp;X systems. The descriptions found elsewhere of devices
supported by XFree86 for other operating systems also do not apply.

<p>
XFree86 for Darwin or Mac OS&nbsp;X will work with any video card that
you have an IOKit driver for. If you are running Mac OS&nbsp;X, this
typically means any card that has been shipped by Apple. If a card works
for you with the Mac OS&nbsp;X GUI, it will work on the same machine with
XFree86. If you have a pure Darwin installation, you may need to download
additional third-party drivers from
<htmlurl url="http://www.opensource.apple.com/projects/darwin/"
name="Apple's Darwin site">. IOKit drivers are typically installed in
<tt>/System/Library/Extensions/</tt> or <tt>/Library/Extensions/</tt>.

<p>
Multi-button and scroll wheel mouse support works well with all
USB mice that I have tested. I have done no testing with ADB
mice, but without a special driver, only a single mouse button
will work on an ADB mouse.

<sect>Getting Started
<p>
Following are instructions for building and running your own copy of
XFree86. The procedure for getting your X server up and running on
Darwin and Mac OS&nbsp;X are very similar. Where there are differences
I have noted them below. Note that to build XFree86 for yourself on
Mac OS&nbsp;X, you need to install the Developers' Tools.

<p>
If you don't feel the need to live on the cutting edge, you can save
some time and effort by using the precompiled binaries available on
the XFree86 FTP server at <url
url="ftp://ftp.xfree86.org/pub/XFree86/&relvers;/binaries/">.
Follow the instructions in the <htmlurl
url="http://www.xfree86.org/&relvers;/Install.html" name="Install">
document to install it. This will create two new directory trees,
<tt>/usr/X11R6</tt> and <tt>/etc/X11</tt> For Mac OS&nbsp;X Quartz
support, download the optional Xquartz.tgz tarball. With Quartz support,
the XDarwin application will be installed in <tt>/Applications</tt>.

<p>
If you get the precompiled binaries you can skip ahead to the section
on <ref id="running" name="running the X Window System"> On the other hand,
if you want to build things yourself from scratch, follow the directions
below.

<sect1> Get the Code 

<p>
The first thing you need to do is to get the source code from the
XFree86 project.

<itemize>
<item> Setup CVS: Both Darwin and Mac OS&nbsp;X include CVS (Concurrent
Versions System), which is an easy way to download and keep up to date
with open source code released by XFree86 and others. You do have to
setup CVS properly, however, to tell it where to look. Follow the
<htmlurl url="http://www.xfree86.org/cvs/" name="XFree86 instructions"> on
how to do this either via ssh or via the cvs pserver.

<item> Now make a directory in some convenient place which will serve
as your top level directory for you open source development efforts. I
am going to call this directory <tt>sandbox/</tt> in the following discussions
and you could put this directory, for example, in <tt>~/sandbox/</tt>.

<item>From the command line type:
<tscreen><verb>
cd sandbox
cvs checkout xc
</verb></tscreen>
Wait for all the files to complete downloading. 

</itemize>

<sect1> Build XFree86
<p>
Once you have everything ready it is easy to build and install
XFree86. From the command line: 

<tscreen><verb>
cd sandbox/xc
make World >& world.log

(wait for several hours)

sudo make install >& install.log
sudo make install.man >& man.log
</verb></tscreen>

<sect>Run the X Window System<label id="running">
<p>
You need to add the X Window System executables to your path. Your path
is the list of directories to be searched for executable commands. 
The X11 commands are located in <tt>/usr/X11R6/bin</tt>, which needs to be
added to your path. XDarwin does this for you by default and can also add
additional directories where you have installed command line applications.

<p>
More experienced users will have already set their path correctly using the
initialization files for their shell. In this case, you can inform XDarwin
not to modify your path in the preferences. XDarwin launches the initial
X11 clients in the user's default login shell. (An alternate shell can also
be specified in the preferences.) The way to set the path depends on the
shell you are using. This is described in the man page documentation for
the shell.

<p>
In addition you may also want to add the man pages from XFree86 to the list
of pages to be searched when you are looking for documentation. The X11 man
pages are located in <tt>/usr/X11R6/man</tt> and the <tt>MANPATH</tt>
environment variable contains the list of directories to search.

<p>
On Mac OS&nbsp;X, you can run XFree86 from the Darwin
text console or in parallel with Aqua. To get to the text
console in Mac OS&nbsp;X you need to logout and type ``&gt;console'' as
the user name. This will shutdown Core Graphics and
bring up the console login prompt. Login again as your user. 

<p>
From the text console you can start the X Window System by typing
``exec startx''. After a brief wait at least one terminal window should
pop up for you. So far it probably isn't very impressive as you might not
even have a window manager running to allow you to move windows around.

<p>
When you are ready to quit XFree86 type ``exit'' in the main
terminal window or quit with the window manager if you have one
running. Unfortunately the X server does not shutdown correctly and if
you did not start with ``exec startx'', you 
will get an apparently frozen screen with only a spinning beachball
cursor on it. Nothing you type shows up on the screen, but in fact
your keystrokes are being received by the console. Type
``logout'' to return to normalcy after a brief delay. With
Darwin, this should put you back at the text console login prompt. With
Mac OS&nbsp;X, Core Graphics will restart and you should be given a login
window.

<p>
To start XFree86 in Quartz mode you can launch the XDarwin application
in the <tt>/Applications</tt> folder, or from the command line type
``startx -- -quartz''. By default this will give you a mode picker to
choose between full screen or rootless mode. You can change the default
to always use a particular mode in the preferences, or you can specify
the ``-fullscreen'' or ``-rootless'' options on the command line instead
of ``-quartz''.

<p>
<bf/Customize the X Window System/
<p>

The X Window System is very customizable and you will certainly want to
change some things. There is a lot you can do to control how your windows
look, how the windows are moved, resized, etc. You will likely want to
get a fancier window manager than twm, which is included with
XFree86. The <tt>.xinitrc</tt> file in your home directory controls what
programs are run when you start the X Window System. You can find a sample
<tt>.xinitrc</tt> file in <tt>/etc/X11/xinit/xinitrc</tt>.  

<p>
There are many window managers that have been ported to Darwin. The
following pages contain collections of window managers and other X
window system clients:

<itemize>
<item> <htmlurl url="http://fink.sourceforge.net/" name="Fink">: A
package manager that will easily download, compile, and install lots
of open source software from the Internet.

<item> <htmlurl url="http://gnu-darwin.sourceforge.net/" name="GNU-Darwin">:
A source for tons of software ported to Darwin.

<item> <htmlurl url="http://softrak.stepwise.com/Apps/WebObjects/Softrak"
name="Stepwise's Softrak site">

<item> <htmlurl url="http://www.darwinfo.org/ports/"
name="Darwinfo's ports page">

</itemize>

<p>
Good luck!

</article>