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
|
<!DOCTYPE linuxdoc PUBLIC "-//XFree86//DTD linuxdoc//EN">
<article>
<!-- TitleS information -->
<title>Information for SCO OpenServer Users
<author>J. Kean Johnston (jkj@sco.com)
<date>14 February 2003
<ident>
$XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/SCO.sgml,v 3.23 2003/12/18 16:38:38 dawes Exp $
</ident>
<!-- Table of contents -->
<toc>
<!-- Begin the document -->
<sect>Requirements<p>
Before you can either compile or execute a binary distribution of
XFree86, the following conditions must be met:
<itemize>
<item>Ensure that you are running Release 5.0.4 or later. This is required
because OSS646 is only supported on those platforms. There are no plans
to support XFree86 on earlier releases of OpenServer.
<item>Ensure that OSS646, the ``Execution Environment Update'' package is
installed, if appropriate. Check the release notes for that update
to see whether or not your current operating system requires this
update. At least version OSS646B is required. If you are running
SCO OpenServer Release 5.0.7, you must have Maintenance Pack 1 installed.
<item>Ensure that the "Graphics, Web and X11 Libraries" package is
installed. At least version 1.3.2Ag is required. You should always
install the latest possible version of this supplement that is valid
for your operating system release. From time to time this release is
bundled with Maintenance Packs, so if you are running 5.0.7 or later,
the latest version may be in the latest Maintenance Pack. Always check
the release notes for GWXLIBS to see if your platform requires the
update. The latest version can always be found at the
<url name="SCO FTP site" url="ftp://ftp.sco.com/pub/openserver5/opensrc">.
<item>To compile XFree86, you must use the SCO-supported version of
the GNU C Compiler. It is possible that Skunkware versions of the
compiler will work too, but this has not been tested. The ``GNU
Development System'' is available for all releases from (and including)
SCO OpenServer Release 5.0.5. It is provided with the operating system
in all versions from Release 5.0.7, although you need to run ``custom''
to install it from the media. You can always download the latest
latest version of the GNU Development System from the
<url name="SCO FTP site" url="ftp://ftp.sco.com/pub/openserver5/opensrc">.
<item>If you are not using OSR 5.0.7 or later, you need to get an updated
console driver. See <url url="http://www.sco.com"> for details on
OpenServer supplements. If you can't or don't want to upgrade your
console driver, XFree86 will still compile, but you may run into
problems with some cards such as the Riva TNT and ATI Rage cards.
The problem with the console driver in 5.0.6A and earlier is that
when the X server sets graphics mode, the driver does not set a
status bit, so any text that is sent directly to <tt>/dev/console</tt>,
such as kernel warning or notice messages when you access tape drives
or NFS notices, will be sent to the console video memory. This just
happens to be slap bang in the middle of palette data for the Riva
TNT, so you get color map corruption. The updated console driver
also has an improved mechanism for allocating video memory that
XFree86 detects at compile time, and it will use it if it exists.
It is STRONGLY recommended that you get the console driver update.
</itemize>
<sect>Compiling XFree86<p>
Using the GNU Development System, compiling XFree86 should be fairly
straightforward. Before attempting to compile the system though, you
should make sure that you have met all of the requirements above.
To actually start the compilation, perform the following steps:
<itemize>
<item>Copy the unmodified <tt>xf86site.def</tt> in <tt>xc/config/cf</tt>
to <tt>host.def</tt>. Edit <tt>host.def</tt> and make any changes you
think you need. The most useful options to change are <tt>HasTcl</tt>,
<tt>HasTk</tt>, <tt>HasXdmAuth</tt> if you have the file
<tt>WrapHelp.c</tt> and <tt>GccWarningOptions</tt>. Due to the nature
of OpenServer's header files, the default options for this last setting
are a bit aggressive, and I recommend you set this option to
<tt>-Wpointer-arith</tt>.
<item>Make sure that the official version of the GNU Development System
is first in your <tt>PATH</tt>. The official version lives in
<tt>/usr/gnu/bin</tt>, and the Skunkware version (if any) lives in
<tt>/usr/local/bin</tt>. You must ensure that <tt>/usr/gnu/bin</tt>
appears first in your <tt>PATH</tt>.
<item>Go to the top level of the source tree and execute the command
<tt>CC=gcc make World BOOTSTRAPCFLAGS=-DSCO5 2>&1 | tee world.log</tt>.
This will do a full build, and send all of the build results to the
file <tt>world.log</tt>.
<item>If the build succeeded, install the new server by executing the
command <tt>make install 2>&1 | tee install.log</tt> as root.
This will send the install results to the file <tt>install.log</tt>.
<item>If you want to install the manual pages, execute the command
<tt>make install.man 2>&1 | tee -a install.log</tt> as root.
</itemize>
<sect>Before Running XFree86<p><label id="sec-runxf86">
The SCO <tt/xterm/ terminfo description is not compatible with the <tt/xterm/
in the R5 distribution.<p>
To use a Bus/Keyboard or PS2 mouse you should configure the mouse drivers
using '<tt>mkdev mouse</tt>'. You may then use the
<tt>OsMouse</tt> option in your <tt>XF86Config</tt> to specify that XFree86
should use the SCO mouse drivers. To do this, set the <tt>Protocol</tt> to
"<tt>OsMouse</tt>" in the <tt>Pointer</tt> section of your
<tt>XF86Config</tt> file. You can also use "<tt>OsMouse</tt>" for your
serial mouse, especially if you are having trouble getting your mouse to
work using the XFree86 mouse drivers.<p>
<sect>Switching Consoles<p>
XFree86 uses similar console switching keys as the SCO R4 and R5
servers. That is, <tt>Ctrl-PrntScr</tt> takes you to the next console along
from the one X is running on. If this is the last console it will take
you to console 1. <tt>Ctrl-Alt-FXX</tt>, where <tt>XX</tt> is a function
key between <tt>F1</tt> and <tt>F12</tt> will switch you to the console
number assigned to that function key. <tt>F1</tt> corresponds to
<tt>tty01</tt> (or console 1), <tt>F2</tt> corresponds to <tt>tty02</tt>
(or console 2) etc.<p>
Unlike the SCO X server, the "kill me now" key is <tt>Alt+Ctrl+Backspace</tt>.
This does not ask for confirmation, it simply kills the X server as
immediately as possible. Use with extreme caution. This may cause
applications to terminate in an unpredictable way. You can set the
<tt>DontZap</tt> option in the <tt>ServerFlags</tt> section of your
<tt>XF86Config</tt> file to disable this.
<sect>Setting up Man Pages<p>
After compiling the tree, or after installing the binary distribution you
can get <tt>man</tt> to recognise the XFree86 man pages by adding
<tt>/usr/X11R6/man</tt> to
the <tt>MANPATH</tt> in <tt>/etc/default/man</tt>. The line should
look similar to:
<tscreen><verb>
MANPATH=/usr/man:/usr/gnu/man:/usr/X11R6/man:/usr/local/man
</verb></tscreen>
This allows all users to view the X man pages. You may change your own
<tt>MANPATH</tt> environment variable if you do not want everyone to access the
man pages.<p>
By default the man pages are compressed using ``<tt>compress</tt>'' to
conserve space. If you do not want to compress the man pages change
<tt>CompressManPages</tt> to <tt>NO</tt> in your ``<tt>host.def</tt>''
file. Those using the binary distribution can use ``<tt>uncompress</tt>''
to uncompress the man pages. Binary distributions contain pre-formatted
versions of all man pages. If you are compiling the server yourself, you
need to have the GNU Tools package installed to get groff, the GNU
nroff replacement, to format the man pages. Use the <tt>manroff</tt>
script to format the manual pages yourself.
<sect>Using SCO binaries/servers.<p>
XFree86 will accept connections from SCO binaries (R3 upwards) and the
SCO R5 server will also accept connections from XFree86 binaries. This
means you may mix and match the two if you have ODT. For example you may
still use the Panning Motif window manager (pmwm) if you prefer.
</article>
|