freebsd-skq/sys/i386/isa
Peter Wemm 019ab50b3d This commit was generated by cvs2svn to compensate for changes in r15587,
which included commits to RCS files with non-trunk default branches.
1996-05-04 06:03:59 +00:00
..
ic This commit was generated by cvs2svn to compensate for changes in r15587, 1996-05-04 06:03:59 +00:00
matcd Forget that TAILQ's must be init'ed. 1996-05-03 16:49:14 +00:00
pcvt Oops, include opt_pcvt_hdr.h before the key value in it is used. 1996-04-13 16:59:29 +00:00
sound Added a note about OPTi 82C929 based cards. 1996-04-11 15:34:22 +00:00
aha1542.c Removed now-unused #includes of <machine/cpu.h>. They were for bootverbose 1996-04-07 17:32:42 +00:00
aic6360.c First pass at cleaning up macros relating to pages, clusters and all that. 1996-05-02 10:43:17 +00:00
asc.c Declared `unittab' as static. It was bogusly shared between the asc and 1996-04-13 12:18:45 +00:00
ascreg.h
atapi.c Eliminated sloppy common-style declarations. Now there are no duplicated 1996-04-13 12:45:57 +00:00
atapi.h Eliminated sloppy common-style declarations. Now there are no duplicated 1996-04-13 12:45:57 +00:00
b004.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
b004.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
bt5xx-445.c Override the unit number passed into us in the isa_device structure with 1996-03-31 03:06:20 +00:00
clock.c Added calibration the i8254 and the i586 clocks agains the RTC at boot 1996-05-01 08:39:02 +00:00
cronyx.c Staticize and cleanup. 1995-12-10 13:40:44 +00:00
ctx.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
ctxreg.h
cx.c Completed function declarations and/or added prototypes and/or added 1995-12-15 00:54:32 +00:00
cxreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
cy.c KGDB is dead. It may come back one day if somebody does it. 1996-05-02 09:34:51 +00:00
cyreg.h
diskslice_machdep.c Removed now-unused #includes of <machine/cpu.h>. They were for bootverbose 1996-04-07 17:32:42 +00:00
elink.c
elink.h
fd.c Typo. 1996-05-03 20:15:11 +00:00
fdc.h Move from the old buf.b_actf to the new TAILQ(buf.b_act). 1996-05-03 14:57:27 +00:00
fdreg.h
ft.c Completed function declarations and/or added prototypes and/or added 1995-12-15 00:54:32 +00:00
ftreg.h
gpib.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
gpib.h
gpibreg.h
gsc.c Declared `unittab' as static. It was bogusly shared between the asc and 1996-04-13 12:18:45 +00:00
gscreg.h
icu.h
icu.s Removed undocumented an unused APM_SLOWSTART code. 1996-03-12 05:44:25 +00:00
if_ar.c Improve the handling of receive errors. Fix a nasty bug in the receive 1996-04-12 19:57:44 +00:00
if_arregs.h Changes to the Digi/Arnet SYNC driver: 1996-03-17 00:29:35 +00:00
if_cx.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
if_ed.c Format the already applied PCCARD additions to use KNF form. No 1996-04-23 18:36:56 +00:00
if_edreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
if_eg.c Removed never-used #includes of <machine/cpu.h>. Many were apparently 1996-04-07 17:39:28 +00:00
if_egreg.h
if_el.c Clean up Ethernet drivers: 1996-02-06 18:51:28 +00:00
if_elreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
if_ep.c Fix media type determination. 1996-02-28 17:19:04 +00:00
if_epreg.h Fix media type determination. 1996-02-28 17:19:04 +00:00
if_fe.c Format the already applied PCCARD additions to use KNF form. No 1996-04-23 18:36:56 +00:00
if_fereg.h This is a revised fe, Ethernet driver for MB8696x based adapters. 1996-03-17 08:36:38 +00:00
if_ie507.h
if_ie.c Clean up Ethernet drivers: 1996-02-06 18:51:28 +00:00
if_iereg.h
if_ix.c Clean up Ethernet drivers: 1996-02-06 18:51:28 +00:00
if_ixreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
if_le.c Remove reference to ac_ipaddr, which was being used to 1996-03-23 19:34:12 +00:00
if_lnc.c Clean up Ethernet drivers: 1996-02-06 18:51:28 +00:00
if_lnc.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
if_ze.c Clean up Ethernet drivers: 1996-02-06 18:51:28 +00:00
if_zp.c Now that ac->ac_ipaddr and arpwhohas() no longer exist, remove the 1996-03-23 21:32:39 +00:00
if_zpreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
isa_device.h Add a lock for DMA Channels to prevent two devices from using the same DMA 1996-04-08 19:38:57 +00:00
isa.c First pass at cleaning up macros relating to pages, clusters and all that. 1996-05-02 10:43:17 +00:00
isa.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
joy.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
kbd.h
kbdtables.h Change RUKEYMAP sligtly 1996-01-25 16:37:20 +00:00
labpc.c A nasty #define, so that we don't use buf->b_actf anymore. 1996-05-03 20:52:18 +00:00
lpt.c Work around a braindead signal handling in many newer HP printers. 1996-04-04 12:28:36 +00:00
lptreg.h
mcd.c Forget that TAILQ's must be init'ed. 1996-05-03 16:49:14 +00:00
mcdreg.h Calculate TOC size to match what scsi cd says. 1996-02-02 20:50:04 +00:00
mse.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
ncr5380.c Cleanse the SCSI subsystem of its internally defined types 1996-03-10 07:04:48 +00:00
npx.c Choose a different name to hold the option definition.. The original one 1996-01-06 23:10:57 +00:00
pcaudio.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
pcibus.c Make pcibus_check() ignore Device/Vendor IDs of all 0. 1996-04-30 21:37:21 +00:00
pcic.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
pcicx.c Staticize and cleanup. 1995-12-10 13:40:44 +00:00
prof_machdep.c Added a $Id$ keyword. Bruce still needs to put a copyright notice 1996-04-08 16:41:06 +00:00
psm.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
qcam.c slight re-ordering to allow the qcam to compile with devfs enabled. 1996-04-29 20:05:52 +00:00
qcamdefs.h Add support for /very/ experimental -e (exposure) option. 1996-03-21 08:22:59 +00:00
qcamio.c Add in linux support for the quickcam driver bottom half and 1996-04-17 09:00:53 +00:00
qcamreg.h Update the Connectix QuickCam driver to match my current work. 1996-03-02 03:48:19 +00:00
random_machdep.c Use rdtsc() function instead of inline essembler. 1996-04-07 18:16:26 +00:00
rc.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
rcreg.h
README.le
README.stl Initial import of driver for the Stallion EasyIO and EasyConnection 8/32 1996-05-04 06:03:59 +00:00
rtc.h
scd.c Forget that TAILQ's must be init'ed. 1996-05-03 16:49:14 +00:00
scdreg.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
seagate.c Cleanse the SCSI subsystem of its internally defined types 1996-03-10 07:04:48 +00:00
si_code.c
si.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
sio.c KGDB is dead. It may come back one day if somebody does it. 1996-05-02 09:34:51 +00:00
sioreg.h Staticize and cleanup. 1995-12-10 13:40:44 +00:00
sireg.h Mainly cosmetic cleanups... It now uses more consistant message reporting 1995-11-28 02:07:36 +00:00
spigot.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
spkr.c Fixed name of /dev/speaker (it's not spkr). 1996-03-27 19:07:33 +00:00
stallion.c Initial import of driver for the Stallion EasyIO and EasyConnection 8/32 1996-05-04 06:03:59 +00:00
syscons.c Fix ^[[1K (clear from beginning of line to cursor) and 1996-05-02 21:47:50 +00:00
syscons.h Fix a bunch of spelling errors in the comment fields of 1996-01-30 23:02:38 +00:00
timerreg.h
tw.c Switched from using devfs_add_sw() to using devfs_add_swf() 1996-03-28 14:29:52 +00:00
ultra14f.c Cleanse the SCSI subsystem of its internally defined types 1996-03-10 07:04:48 +00:00
vector.s Moved AUTO_EOI_[12] and most sio and pcvt options out of the makefile. 1996-04-11 21:18:49 +00:00
wcd.c Replace usage of buf->b_actf with queue.3 and buf->b_act. 1996-04-08 07:56:42 +00:00
wd7000.c Removed never-used #includes of <machine/cpu.h>. Many were apparently 1996-04-07 17:39:28 +00:00
wd.c Move from the old buf.b_actf to the new TAILQ(buf.b_act). 1996-05-03 14:57:27 +00:00
wdreg.h Implement a prototype interface to bus-master IDE DMA on the Triton 1996-01-28 22:16:20 +00:00
wt.c Update drivers to use isa_dma_acquire() and isa_dma_release() 1996-04-08 19:40:57 +00:00
wtreg.h . move out the error and status register def's for wt into 1996-02-22 00:31:49 +00:00

Stallion Multiport Serial Driver Readme
---------------------------------------

Version: 0.0.1 alpha
Date:    21DEC95
Author:  Greg Ungerer (gerg@stallion.oz.au)



1. INTRODUCTION

This is a FreeBSD driver for some of the Stallion Technologies range of
multiport serial boards. This is the very first release of this driver, so
it should be considered to be of very alpha quality.

This driver has not been developed by Stallion Technologies. I developed it
in my spare time in the hope that it would be useful. As such there is no
warranty or support of any form.

What this means is that this driver is not officially supported by Stallion
Technologies, so don't ring their support if you can't get it working. They
will probably not be able to help you. Instead email me if you have problems
or bug reports and I will do what I can... (Sorry to sound so heavy handed,
but I need to stress that this driver is not officially supported in any way.)

This driver supports the EasyIO and EasyConnection 8/32 range of boards.
All of these boards are not classical intelligent multiport boards, but are
host based multiport boards that use high performance Cirrus Logic CL-CD1400
RISC UART's (they have built in FIFO's, automatic flow control, and some
other good stuff).

The EasyIO range of cards comes in 3 forms, the EasyIO-4, EasyIO-8 and the
EasyIO-8M. All of these are non-expandable, low cost, ISA, multiport boards
with 4, 8 and 8 RS-232C ports respectively. The EasyIO-8M is not currently
supported by this driver. Though it is pretty easy to support so I'll do
that when I get a chance. Each EasyIO board requires 8 bytes of IO address
space and 1 interrupt. On an EISA system it is possible to share 1 interrupt
between multiple boards. The EasyIO-4 has 10 pin RJ connectors, and the
EasyIO-8 comes with a dongle cable that can be either 10 pin RJ connectors or
DB-25 connectors. The EasyIO-8M has 6 pin RJ connectors.

The EasyConnection 8/32 family of boards is a relatively low cost modular
range of multiport serial boards. The EasyConnection 8/32 boards can be
configured to have from 8 to 32 serial ports by plugging in external serial
port modules that contain from 8 to 16 ports each. There is a wide range of
external modules available that offer: DB-25 connectors, RJ-45 connectors
(both with RS-232 D and E compatible drivers), and also RS-422 ports. The
EasyConnection 8/32 boards come in ISA and MCA bus versions. The board takes
the form of a host adapter card, with an external connector cable that plugs
into the external modules. The external modules just clip together to add
ports (BTW they are not hot pluggable). Each EasyConnection 8/32 board
requires 2 separate IO address ranges, one 2 bytes in size and a secondary
region of 32 bytes. Each board also requires 1 interrupt, on EISA systems
multiple boards can share 1 interrupt. The secondary IO range (the 32 byte
range) can be shared between multiple boards on any bus type.

So thats the hardware supported (sounds like a marketing spiel doesn't it!).
I am working on drivers for other boards in the Stallion range, so look
out for those some time soon...



2. INSTALLATION

This driver was developed on a FreeBSD 2.0.5 system. I have not tryed it
on a 2.1 system yet, so I don't know if it will go in painlessly or not...

You will need to build a new kernel to use this driver. So the first thing
you need is to have the full kernel source. Most people will have this
(I hope!). The following assumes that the kernel source is in /usr/src/sys.

The driver can support up to 8 boards (any combination of EasyIO and
EasyConnection 8/32 boards). So there is a theoretical maximum of 256 ports.
(Off-course I have not tested a system with this many!)

Instructions to install:

1. Copy the driver source files into the kernel source tree.

        cp stallion.c /usr/src/sys/i386/isa
        cp scd1400.h /usr/src/sys/i386/ic

2. Add a character device switch table entry for the driver into the cdevsw
   table structure. This involves adding some code into the kernel conf.c
   file:

        cd /usr/src/sys/i386/i386
        vi conf.c
            - add the following lines (in 2.0.5 I put them at line 1019):

/* Stallion Multiport Serial Driver */
#include "stl.h"
#if	NSTL > 0
d_open_t        stlopen;
d_close_t       stlclose;
d_read_t        stlread;
d_write_t       stlwrite;
d_ioctl_t	stlioctl;
d_stop_t        stlstop;
d_ttycv_t	stldevtotty;
#define stlreset	nxreset
#define	stlmmap		nxmmap
#define stlstrategy	nxstrategy
#else
#define	stlopen		nxopen
#define stlclose	nxclose
#define stlread		nxread
#define stlwrite	nxwrite
#define stlioctl	nxioctl
#define stlstop		nxstop
#define stlreset	nxreset
#define stlmmap		nxmmap
#define stlstrategy	nxstrategy
#define	stldevtotty	nxdevtotty
#endif


            - and then inside the actual cdevsw structure definition, at the
              last entry add (this is now line 1259 in the 2.0.5 conf.c):

	{ stlopen,	stlclose,	stlread,	stlwrite,	/*67*/
	  stlioctl,	stlstop,	stlreset,	stldevtotty,/*stallion*/
	  ttselect,	stlmmap,	stlstrategy },

            - the line above used major number 67, but this may be different
              on your system. Take note of what major number you are using.
              
            - save the file and exit vi.

3. Add the driver source files to the kernel files list:

        cd /usr/src/sys/i386/conf
        vi files.i386
            - add the following definition line into the list (it is stored
              alphabetically, so insert it appropriately):

i386/isa/stallion.c		optional	stl	device-driver

            - save the file and exit vi.

4. Add board probe entries into the kernel configuration file:

        cd /usr/src/sys/i386/conf
        cp GENERIC MYKERNEL
            - if you already have a kernel config that you use then you
              could just use that (instead of MYKERNEL)
        vi MYKERNEL
            - enter a line for each board that you want to use, eg:

device		stl0	at isa? port 0x2a0 tty irq 10 vector stlintr

            - change the io address and irq in this line as required
            - save the file and exit

5. Build a new kernel using this configuration.

        cd /usr/src/sys/i386/conf
        config MYKERNEL
        cd ../../compile/MYKERNEL
        make depend
        make all
        make install


And there you have it!  It is a little bit of effort to get it in there...

So once you have a new kernel built, reboot to start it up. On startup the
Stallion board probes will report on whether the boards were found or not.
For each board found the driver will print out the type of board found,
and how many panels and ports it has. 

If a board is not found by the driver but is actually in the system then the
most likely problem is that the IO address is wrong. The easiest thing to do
is change the DIP switches on the board to the desired address and reboot.
On EasyIO and EasyConnection 8/32 boards the IRQ is software programmable,
so if there is a conflict you may need to change the IRQ used for a board in
the MYKERNEL configuration file and rebuild the kernel.

Note that the secondary IO address of the EasyConnection 8/32 boards is hard
wired into the stallion.c driver code. It is currently set to IO address
0x280. If you need to use a different address then you will need to edit this
file and change the variable named stl_ioshared.



3. USING THE DRIVER

Once the driver is installed you will need to setup some device nodes to
access the serial ports. Use the supplied "mkdevnods" script to automatically
create all required device entries for your boards. To make device nodes for
more than 1 board then just supply the number of boards you are using as a
command line parameter to mkdevnods and it will create nodes for that number
of boards. By default it will create device nodes for 1 board only.

Note that if the driver is not installed at character major number 67 then
you will need to edit the mkdevnods script and modify the STL_SERIALMAJOR
variable to the major number you are using.

Device nodes created for the normal serial port devices are named /dev/ttyEX
where X is the port number. (The second boards ports will start from ttyE32,
the third boards from ttyE64, etc). It will also create a set of modem call
out devices named cueX where again X is the port number.

For the most part the Stallion driver tries to emulate the standard PC system
com ports and the standard sio serial driver. The idea is that you should
be able to use Stallion board ports and com ports inter-changeably without
modifying anything but the device name. Anything that doesn't work like that
should be considered a bug in this driver!

Since this driver tries to emulate the standard serial ports as much as
possible then most system utilities should work as they do for the standard
com ports. Most importantly "stty" works as expected and "comcontrol" can be
used just like for the serial ports.

This driver should work with anything that works on standard com serial ports.
Having said that, I have used it on at least the following types of "things"
under FreeBSD:
    a) standard dumb terminals (using getty)
    b) modems (using cu, etc)



4. NOTES

Be aware that this is the first release of this driver, so there is sure to
be some bugs in it. Please email me any feedback on bugs, problems, or even
good experiences with this driver!

There is no real smart line discipline bypass code yet (like in the sio
driver). I will add this for the next driver release.

I will probably also add LKM support for the next driver release.



5. ACKNOWLEDGEMENTS

This driver is loosely based on the code of the FreeBSD sio serial driver.
A big thanks to Stallion Technologies for the use of their equipment.