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
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
|
<!DOCTYPE linuxdoc PUBLIC "-//XFree86//DTD linuxdoc//EN">
<article>
<title>README for XFree86 3.3.2 on OpenBSD
<author>
Matthieu Herrb
<Date>Last modified on: 20 February 1998
<toc>
<sect>What and Where is XFree86?
<p>
XFree86 3.3.2 is a port of X11R6.3 that supports several versions of
Intel-based Unix. It is derived from X386 1.2, which was the X server
distributed with X11R5. This release consists of many new features
and performance improvements as well as many bug fixes. The release
is available as source patches against the X Consortium X11R6.3 code, as
well as binary distributions for many architectures.
See the <htmlurl url="COPYRIGHT.html" name="Copyright Notice">.
The sources for XFree86 are available by anonymous ftp from:
<htmlurl name="ftp://ftp.XFree86.org/pub/XFree86/current"
url="ftp://ftp.XFree86.org/pub/XFree86/current">
Binaries for OpenBSD 2.2 are available from:
<htmlurl name="ftp://ftp.XFree86.org/pub/XFree86/current/binaries/"
url="ftp://ftp.XFree86.org/pub/XFree86/current/binaries/OpenBSD">
A list of mirror sites is provided by
<htmlurl name="ftp://ftp.XFree86.org/pub/XFree86/MIRRORS"
url="ftp://ftp.XFree86.org/pub/XFree86/MIRRORS">
<p>
XFree86 3.3.2 also builds on other OpenBSD architectures. See section
<ref id="otherarch" name="Building on other architectures"> for details.
<sect>Bug Reports for This Document
<p>
Send email to <em/matthieu@laas.fr/ (Matthieu Herrb) or
<em/XFree86@XFree86.org/ if you have comments or suggestions about
this file and we'll revise it.
<sect>New features in this release
<p>
<enum>
<item>See the <htmlurl url="RELNOTES.html" name="Release Notes"> for
non-OS dependent new features in XFree86 3.3.2.
</enum>
<sect>Installing the Binaries
<p>
Refer to section 5 of the <htmlurl url="RELNOTES.html" name="Release
Notes"> for detailed installation instructions.
<sect>Configuring X for Your Hardware
<p>
The <tt/XF86Config/ file tells the X server what kind of monitor,
video card and mouse you have. You <em/must/ create it to tell the
server what specific hardware you have.
<p>
XFree86 3.2 introduced a new, user-friendly configuration utility
called <bf/XF86Setup/. It has to be run as root. Refer to its
documentation for details about its use.
<p>
You'll need info on your hardware:
<itemize>
<item>Your mouse type, baud rate and its /dev entry.
<item>The video card's chipset (e.g. ET4000, S3, etc).
<item>Your monitor's sync frequencies.
</itemize>
The recommended way to generate an <tt/XF86Config/ file is to use the
<tt/XF86Setup/ utility. The xf86config text utility is still there
for the (few) cases where XF86Setup can't be used. Also, there is a
sample file installed as <tt>/usr/X11R6/lib/X11/XF86Config.eg</tt>,
which can be used as a starting point.
For details about the <tt/XF86Config/ file format, refer to the
<em>XF86Config(5)</em> manual page.
In order to protect your hardware from damage, the server will no
longer read <tt>XF86Config</tt> files from a user's home directory,
but requires that it be in <tt>/etc/XF86Config</tt>,
<tt>/usr/X11R6/lib/X11/XF86Config.hostname</tt> or
<tt>/usr/X11R6/lib/X11/XF86Config</tt>.
Once you've set up a XF86Config file, you can fine tune the video
modes with the <tt>xvidtune</tt> utility.
<sect1>About mouse configuration
<p>
If your serial mouse does not work try using <tt>kermit</tt> or
<tt>tip</tt> to connect to the mouse serial port and verify that it
does indeed generate characters.
<p>
The OpenBSD pms driver provides both "raw" and "cooked"
(translated) modes. "raw" mode does not do protocol translation, so
XFree86 would use the <bf>PS/2</bf> protocol for talking to the device
in that mode. "cooked" mode is the old BusMouse translation.
By default, the driver runs in "cooked" mode. It can be switched using
ioctls or by opening the first minor device which is <tt>/dev/psm0</tt>.
<p>
Only standard PS/2 mice are supported by this driver. Newest PS/2
mice that send more than three bytes at a time (especially
intellimouse, or mouseman+ with a "3D" roller) are not supported yet.
<p>
See <htmlurl url="mouse.html" name="README.mouse"> for general
instruction on mouse configuration in XFree86.
<sect1>Other input devices
<p>
XFree86 supports the dynamic loading of drivers for external
input devices using the <tt/XInput/ extension. Currently supported
devices are:
<itemize>
<item>Joystick (<tt/xf86Jstk.so/)
<item>Wacom tablets (Wacom IV protocol only, <tt/xf86Wacom.so/)
<item>SummaSketch tablets (<tt/xf86Summa.so/)
<item>Elographics touchscreen (<tt/xf86Elo.so/)
</itemize>
To use a specific device, add the line
<tscreen>
<tt/load/ <tt/"/<em/module/<tt/"/
</tscreen>
in the <bf/Module/ section of <tt/XF86Config/, where <em/module/ is
the name of the <tt/.so/ file corresponding to your device.
You also need to set up a <bf/XInput/ section in <tt/XF86Config/.
Refer to the <em>XF86Config(5)</em> man page for detailed
configuration instructions.
<p>
You can then change the device used to drive the X pointer with the
<em/xsetpointer(1)/ command.
<p>
For joystick support, you'll need to enable the joystick device
driver in the kernel. See <em/joy(4)/ for details.
<sect1>Configuring PEX and XIE extensions
<p>
The PEX and XIE extensions are supported as external modules.
If you want to have access to these extensions, add the following
lines to the <bf/Module/ section of <tt/XF86Config/:
<tscreen><verb>
load "pex5.so"
load "xie.so"
</verb></tscreen>
<sect>Installing Xdm, the display manager
<p>
The file <tt>xc/lib/Xdmcp/WrapHelp.c</tt> is not available in
France (where the binary distribution is built) so support for
XDM-AUTHORIZATION-1 is not included here. You'll have to get
WrapHelp.c and rebuild xdm after having set <tt/HasXdmAuth/ in
<tt/host.def/.
The file is available within the US; for
details see <htmlurl name="ftp.x.org:/pub/R6/xdm-auth/README"
url="ftp://ftp.x.org/pub/R6/xdm-auth/README">.
To start the display manager, log in as root on the console and type:
``<tt/xdm -nodaemon/''.
You can start xdm automatically on bootup un-commenting the following
code in <tt>/etc/rc.local</tt>:
<tscreen><verb>
if [ -x /usr/X11R6/bin/xdm ]; then
echo -n ' xdm'; /usr/X11R6/bin/xdm
fi
</verb></tscreen>
On the default OpenBSD 2.2 installation, you will also need to create
the virtual console device for the X server:
<tscreen><verb>
cd /dev
./MAKEDEV ttyC5
</verb></tscreen>
It's also better to specify explicitly the virtual console to be used
by the X server. If you're experimenting keyboards lockup with xdm, in
<tt>/usr/X11R6/lib/X11/xdm/Xservers</tt>, replace the line:
<tscreen><verb>
:0 local /usr/X11R6/bin/X
</verb></tscreen>
by:
<tscreen><verb>
:0 local /usr/X11R6/bin/X vt06
</verb></tscreen>
<sect>Running X
<p>
8mb of memory is a recommended minimum for running X. The server,
window manager and an xterm take about 4 Mb of memory themselves. On
a 4Mb system that would leave nothing left over for other applications
like gcc that expect a few meg free. X will work with 4Mb of memory,
but in practice compilation while running X can take 5 or 10 times as
long due to constant paging.
The easiest way for new users to start X windows is to type: ``<tt/startx
>& startx.log/''. Error messages are lost unless you redirect them
because the server takes over the screen.
To get out of X windows, type: ``<tt/exit/'' in the console xterm.
You can customize your X by creating <tt/.xinitrc/, <tt/.xserverrc/,
and <tt/.twmrc/ files in your home directory as described in the xinit
and startx man pages.
<sect>Kernel Support for X
<p>
To make sure X support is enabled under OpenBSD, the following
line must be in your config file in <tt>/sys/arch/i386/conf</tt>:
<tscreen>
options XSERVER
</tscreen>
The server supports the two standard OpenBSD/i386
console drivers: pccons and pcvt. They are detected at runtime and no
configuration of the server itself is required.
<p>
The pcvt console driver is now the default in OpenBSD. It offers
several virtual consoles and international keyboard support.
<p>
When not using XKB, the server can read the actual keymap from
the keyboard driver and use to build the X keymap. Be sure to use
``<tt/RightAlt ModeShift/'' in <tt/XF86Config/ to have the right <bf/Alt/ key
behave as <bf/AltGr/.
<p>
Syscons and codrv are not bundled with OpenBSD. They are available by
anonymous FTP from a number of sites. They are not supported by the
XFree86 binary distribution anymore. You can compile support for them
by adding -DSYSCONS_SUPPORT or -DCODRV_SUPPORT to
<tt/XFree86ConsoleDefines/ in <tt/xf86site.def/. See the section <ref
id="console-drivers" name="Console drivers"> for details.
<sect1>Aperture Driver
<p>
By default OpenBSD includes the BSD 4.4 kernel security
feature that disable access to the <tt>/dev/mem</tt> device when in
multi-users mode. But XFree86 servers can take advantage (or require)
linear access to the display memory.
The P9000, Mach64 and AGX servers require linear memory access, other
accelerated servers can take advantage of it, but do not require it.
Some drivers in the SVGA server require linear memory access too,
notably the Matrox driver.
There are two ways to allow XFree86 to access linear memory:
<enum>
<item>Disable the kernel security feature by adding
`option INSECURE' in the kernel configuration file and build a new
kernel.
In OpenBSD 2.2 and later, you will also need to comment out the line
initializing <tt/securelevel/ to 1 in <tt>/etc/rc.securelevel</tt>.
<item>Install the aperture driver:
<enum>
<item> The first step is highly dependent from your exact operating
system version:
<itemize>
<item> OpenBSD 2.0
<p>
Use the aperture driver from /usr/lkm:
add the following lines to the end of <tt>/etc/rc.local</tt>:
<tscreen><verb>
KERNDIR=/usr/lkm
if [ -f ${KERNDIR}/ap.o ]; then
modload -o ${KERNDIR}/ap -e ap -p ${KERNDIR}/apinstall ${KERNDIR}/ap.o
fi
</verb></tscreen>
<item> OpenBSD 2.1, 2.2
<p>
Uncomment the lines loading the aperture driver from
<tt>/etc/rc.securelevel</tt>
<item> OpenBSD-current
<p>
In addition to the loadable kernel module, you can now use an
in-kernel aperture driver. Add 'option APERTURE' to your kernel
configuration file, build and install the new kernel and run
<tt>./MAKEDEV std</tt> in <tt>/dev</tt>. Edit
<tt>/etc/sysctl.conf</tt> to set the variable
<bf>machdep.allowaperture</bf> to 1.
</itemize>
<item> Reboot your system. XFree86 will auto-detect the aperture
driver if available.
</enum>
<bf/Warning:/ if you boot another kernel than <tt>/bsd</tt>,
loadable kernel modules can crash your system. Always boot in
single user mode when you want to run another kernel.
<p>
<quote>
<bf/Caveat:/ the aperture driver only allows one access at a time
(so that the system is in the same security state once X is
launched). This means that if you run multiple servers on multiples
VT, only the first one will have linear memory access.
Use 'option INSECURE' if you need more that one X server at a time.
</quote>
</enum>
<sect1>MIT-SHM
<p>
OpenBSD supports System V shared memory. If XFree86
detects this support in your kernel, it will support the MIT-SHM
extension.
To add support for system V shared memory to your kernel add the
lines:
<tscreen><verb>
# System V-like IPC
options SYSVMSG
options SYSVSEM
options SYSVSHM
</verb></tscreen>
to your kernel config file. Then from <tt>/sys/arch/i386/config</tt>, type:
<tscreen><verb>
# rm -f ../compile/<KERNEL-NAME>/*
# config <KERNEL-NAME>
# cd ../compile/<KERNEL-NAME>
# make depend
# make
</verb></tscreen>
Then install your new kernel and re-boot:
<tscreen><verb>
# cp /bsd /obsd
# cp bsd /
# reboot
</verb></tscreen>
<sect> Rebuilding the XFree86 Distribution
<p>
The server link kit allow you to rebuild just the X server with a
minimum amount of disk space. Just unpack it, make the appropriate
changes to the <tt/xf86site.def/, type ``<tt>./mkmf</tt>'' and
``<tt/make/'' to link the server. See <tt>/usr/X11R6/lib/Server/README</tt>
for more info.
See <htmlurl url="INSTALL.html" name="INSTALL"> for instructions on
unbundling and building the source distribution.
You should configure the distribution by editing
<tt>xc/config/cf/xf86site.def</tt> before compiling. To compile the
sources, invoke ``<tt/make World/'' in the xc directory.
<sect1>Console drivers<label id="console-drivers">
<p>
XFree86 3.3.2 has a configuration option to select the console
drivers to use in <tt/xf86site.def/:
<itemize>
<item> if you're using pccons put:
<tscreen><verb>
#define XFree86ConsoleDefines -DPCCONS_SUPPORT
</verb></tscreen>
<item>if you're using pcvt put:
<tscreen><verb>
#define XFree86ConsoleDefines -DPCVT_SUPPORT
</verb></tscreen>
<item>if you're using syscons put:
<tscreen><verb>
#define XFree86ConsoleDefines -DSYSCONS_SUPPORT
</verb></tscreen>
<item>if you're running codrv put:
<tscreen><verb>
#define XFree86ConsoleDefines -DCODRV_SUPPORT
</verb></tscreen>
</itemize>
If you don't define <bf/XFree86ConsoleDefines/ in <tt/xf86site.def/ the
pccons and pcvt drivers will be supported.
<sect1>console.h and ioctl_pc.h files:
<p>
If you want to build a server supporting codrv and you
don't already have the corresponding header file
<tt/ioctl_pc.h/ installed in <tt>/usr/include/machine</tt>, then
install the copy that is supplied in
<tt>xc/programs/Xserver/hw/xfree86/etc</tt>. If you run
OpenBSD-current you probably want to install it in
<tt>/usr/src/sys/arch/i386/include</tt> too, so that it get
reinstalled each time you run <tt/make includes/.
If you have installed the codrv console driver, this
file should be taken from your installed version of the driver.
The <tt/console.h/ file for syscons isn't distributed with XFree86
anymore. You should get it from the syscons distribution.
<sect1>Building on other architectures<label id="otherarch">
<p>
XFree86 3.3.2 also compiles on other OpenBSD architectures.
The XFree86 servers can also been built on OpenBSD/mips. The S3 server
has been tested on an Acer Mips system with a S3/928 board. Contact
Per Fogelstrom (pefo@OpenBSD.org) for details.
The Xsun server patches from Dennis Ferguson and Matthew Green for
NetBSD have been integrated in
<tt>xc/programs/Xserver/hw/sun</tt>. The Xsun server can be built on
the sparc and the sun3.
The client side of XFree86 also builds on the alpha, pmax, amiga,
mac68k and mvme68k architectures.
Problems with this port should be reported directly to the OpenBSD
mailing lists rather than to the xfree86 mailing list.
<sect>Building New X Clients
<p>
The easiest way to build a new client (X application) is to use
<tt/xmkmf/ if an <tt/Imakefile/ is included in the sources. Type
``<tt/xmkmf -a/'' to create the Makefiles, check the configuration if
necessary and type ``<tt/make/''. Whenever you install additional man
pages you should update <tt/whatis.db/ by running ``<tt>makewhatis
/usr/X11R6/man</tt>''.
To avoid the ``Virtual memory exhausted'' message from cc while
compiling, increase the data and stack size limits (in csh type ``<tt/limit
datasize 32M/'' and ``<tt/limit stacksize 16M/'').
<sect> Thanks
<p>
Many thanks to:
<itemize>
<item><bf/Pace Willison/ for providing the initial port to 386BSD.
<item><bf/Amancio Hasty/ for fixing cursor restoration, mouse bugs
and many others.
<item><bf/Christoph Robitschko/ for fixing <tt/com.c/ and thus select().
<item><bf/Nate Williams/ for the patchkit support for X.
<item><bf/Rod Grimes/ and <bf/Jack Velte/ of Walnut Creek Cdrom for use
of their machines in preparing the FreeBSD binary release.
</itemize>
<verb>
$XFree86: xc/programs/Xserver/hw/xfree86/doc/sgml/OpenBSD.sgml,v 1.1.2.5 1998/02/26 13:59:07 dawes Exp $
$Xorg: OpenBSD.sgml,v 1.3 2000/08/17 19:51:02 cpqbld Exp $
</verb>
</article>
|