Model # VIS1018
Version 4.2 July 28, 1998
Copyright 1998
É:Interface Consultants, Inc.
:È3375 Westpark Drive #143, Houston, TX 77005-4262
713/529-3706
Table of Contents
1. Introduction
2. Installation of the software
3. Deinstallation of the software
4. Configuring the Ikon board and device driver
5. Included Files and Summaries
6. Viptest - test plot and programming example
7. Vipdma - file dma output program
8. Miscellaneous Notes
9. Revision History
The Interface Consultants Model VIS1018
Ikon SGI device driver is a program that accesses the PCI bus to configure
an Ikon board to drive Versatec and compatible plotters, hence the name
VIP (Versatec Ikon PCI).
The device driver supports the Ikon
10117 Hardcopy PCI bus interface board under SGI IRIX 6.4 operating system
environment.
A test program ‘viptest’ is provided
(with C source code) that produces both print and plot mode data.
A file output program ‘vipdma’ is also
provided that allows files to be output to a plotter in print or plot mode,
or a printer using high speed DMA.
The device driver supports the operation
of multiple Ikon boards on a single machine. The driver will identify the
boards as devices /hw/vip0, /hw/vip1, ...
Note that the device special files
are under the '/hw' tree in IRIX 6.4, not the Unix standard '/dev' tree.
If your software requires other names, create a symbolic link to the real
device special files.
The installation script handles all
boards under IRIX 6.4, and more boards can added later without any additional
software installation.
NOTE: This device driver software requires a special
Ikon 10117 board labeled 'VIS1018 Interface Consultants'. This device driver
will not operate properly with any other board.
Disclaimer: Marks copyright Interface
Consultants, Ikon, or Xerox.
2. Installation
of the software
The installation of the VIP1018 can
be accomplished easily and quickly with the included CD.
(Note: you must be logged in as super
user 'root' in order to perform the file copies required for installation.)
First, insert the CD into the CD-ROM
drive. Access the CD drive by typing:
cd /CDROM
Next, run the vinstall script on the
CD by typing:
csh ./vinstall
The device driver is self-configuring.
At this point, the device driver should be functional. A test utility (such
as the viptest utility included) can be run at this time to test
the driver. The machine should be rebooted to make sure the device driver
is properly loaded and configured.
To install from the tar floppy disk,
insert the floppy into the disk drive, and extract the files into a temporary
working directory:
tar -xvf /dev/fd0
Next, run the vinstall script in the
working directory by typing:
csh ./vinstall
3. Deinstallation
of the software
The deinstallation of the VIS1018 is similar in nature to the installation
process by virtue of its ease and speed.
First, insert the CD into the CD-ROM drive. Access the CD drive by
typing:
cd /CDROM
First, insert the CD into the CD-ROM
drive. Next, run the vremove script on the CD by typing:
csh ./vremove
The device driver should be removed
at this point. The machine should be rebooted to make sure the device driver
is properly removed and to ensure nothing else was affected by the deinstall.
4. Configuring
the Ikon board and device driver
The Ikon 10117 board has no external
dip-switches to set, as certain other Ikon boards did. Thus there are no
physical configurations with the board the user must adjust. There still
is a ribbon cable on the board that you may need to adjust to set the board
for either Versatec Differential (long lines), or Centronics interface.
When installing the board, make sure the board is properly seated in its
32 bit PCI slot. Refer to the Ikon 10117 user’s manual for additional information.
The device driver uses DMA and interrupts
to achieve high performance. The Ikon 10117 board possesses a set of PCI
configuration registers that configure all of the bus interface information
such as the register base address of the "working" registers in the PCI
I/O and memory space, and interrupt level. All of the above information
is configured at power-on by the IRIX operating system.
Unlike previous AIX incarnations of
this line of device drivers that used SMIT to configure the Ikon board,
the VIP1018 does not have a direct OS setup interface to change the settings
of the Ikon board. The user will need to send IOCTL commands to the board
itself to change the configurations (see vpioctl.h). Any settings (handshake
speed, timeout value) are retained by the device driver from plot to plot
(i.e. between a ‘close()’ and an ‘open()’ call), but need to be re-set
after a machine boot or device driver load/unload.
5. Included
Files and Summaries
The following is a list of the files included on the installation
CD and tar floppy disk:
vinstall
vipdd.mas
vipdd.o
vipdd.sm
vipdma
viptest
vpioctl.h
vremove
viptest.c
A brief explanation of each of the files can be found
on the following pages.
vinstall batch file
/ script
Contents:
# vinstall - Versatec Ikon PCI device driver for SGI IRIX 6.4
# Copyright (c) 1998, Interface Consultants, Houston, TX
# 3375 Westpark Drive #143
# Houston, TX 77005-4262
# 713/529-3706
# 713/529-3725 Fax
# http://www.ifc2.com
# email: neo@ifc2.com
#
# vinstall Version 4.8 April 20, 1998
#
cp -p vipdd.o /var/sysgen/boot
cp -p vipdd.sm /var/sysgen/system
cp -p vipdd.mas /var/sysgen/master.d/vipdd
cp -p vpioctl.h /usr/include/sys
#install -u root -g sys -f /dev -chr 73,0 vip0
ml ld -c vipdd.o -p vip_
autoconfig
Purpose:
Batch file to install the device driver.
Description:
This batch file will copy all of the
necessary files to the system to run the device driver, and then it will
configure the driver to be ready for operation.
vipdd.mas device master
file
Contents:
* vipdd.mas - Versatec Ikon PCI device driver for SGI IRIX 6.4
* Copyright (c) 1998, Interface Consultants, Houston, TX
* 3375 Westpark Drive #143
* Houston, TX 77005-4262
* 713/529-3706
* 713/529-3725 Fax
* http://www.ifc2.com
* email: neo@ifc2.com
*
* vipdd Version 4.8 April 20, 1998
*
* To Install:
* cp vipdd.mas /var/sysgen/master.d/vipdd
*
* IRIX 6.2 Example driver "vipdd" -- not for production use
*
* Flags used:
* b: block type device
* c: character type device (yes, both)
* d: dynamically loadable kernel module
* n: driver is semaphored
* s: software device driver
* w: driver is prepared to perform any cache write back operation (none)
*
* Field 1: Element characteristics:
* o specify only once
* r required device
* b block device
* c character device
* t initialize cdevsw[].d_ttys
* j filesystem
* s software driver
* f STREAMS driver
* m STREAMS module
* x not a driver; a loadable module
* k kernel module
* u a stubs module that is loaded after all other normal modules
* n driver is fully semaphored for multi-processor operation;
* the n and p directives are ignored on single-processor systems
* p driver is not semaphored and should run on only one processor
* w driver is prepared to perform any cache write back
* operation required on write data passed via the strategy routine
* d dynamically loadable kernel module
* R auto-registrable dynamically loadable kernel module
* N don't allow auto-unload of dynamically loadable kernel module
* D load, then unload a dynamically loadable kernel module
* e ethernet driver
*
* External major number (SOFT) is an arbitrary choice from
* the range of numbers reserved for customer drivers.
*
* #DEV is passed in to the driver and used to configure its info array.
*
*
* Loadable driver: FLAG = fdN
* Non-loadable: FLAG = c
*
*FLAG PREFIX SOFT #DEV DEPENDENCIES
cdR vip_ - -
$$$
Purpose:
This the the ‘master’ file for the
vipdd device driver.
Description:
This file describes the driver to the
IRIX operating system. It details the following information:
c - this is a character device driver
d - this is a dynamically loadable kernel module
R - this is a auto-registrable dynamically loadable kernel module
vip_ - driver prefix is vip_. This
is used by the loader to link to the devswitch functions.
vipdd.o device driver
object file
Purpose:
This is the object file image of the device driver that is loaded
into the kernel by the ‘ml’ command.
Description:
Device driver object file.
vipdd.sm device driver
system file
Contents:
VECTOR: bustype=PCI module=vipdd
Purpose:
This file tells the IRIX operating
system that the the device driver object module vipdd.o supports a PCI
device.
Description:
When IRIX boots, it loads the device
driver module, and calls the ‘prefix_init’ function for all ‘.sm’ files.
In this case, it calls the vip_init function. This allows the driver to
register the vendor id and device id of the PCI card it supports. When
the IRIX probe finds a PCI card, it calls the ‘prefix_attach’ function
for the registered vendor id and device id of the PCI card. The vip_attach
function initializes the device and driver.
vpioctl.h header file
Contents:
/* vpioctl.h - Versatec Ikon PCI device driver for SGI IRIX 6.4
* Copyright (c) 1997, Interface Consultants, Houston, TX
* 3375 Westpark Drive #143
* Houston, TX 77005-4262
* 713/529-3706
* 713/529-3725 Fax
* http://www.ifc2.com
* email: neo@ifc2.com
*/
/* vipdd Version 4.9 April 20,
1998 */
#ifndef _VPIOCTL_H_
#define _VPIOCTL_H_
/* 'V' = 0x5f */
#define VIOCTL ('V'<<8)
#define VPLT_FF VIOCTL + 1 /* form feed pulsed command */
#define VPLT_EOT VIOCTL + 2 /* eot pulsed command */
#define VPLT_CLEAR VIOCTL + 3 /* clear pulsed command */
#define VPLT_RLT VIOCTL + 4 /*
remote line terminate pulsed command */
#define VPLT_PRINT VIOCTL + 5 /* print mode */
#define VPLT_PLOT VIOCTL + 6
/* plot mode */
#define VPLT_LSTAT VIOCTL + 7 /* return last status */
#define VPLT_CSTAT VIOCTL + 8 /* return current status */
#define VPLT_REST VIOCTL + 9
/* reset */
#define VPLT_PIO_MODE VIOCTL + 20 /* select pio data xfer mode*/
#define VPLT_DMA_MODE VIOCTL + 21 /* select dma data xfer mode*/
#define VPLT_MKHWGR VIOCTL +
22 /* 0x5f16 24342 ioconfig - Make Hardware Graph nodes off of /hw */
#define HS_SPEED 0x40
#define VPLT_HS_SPEED_0 VIOCTL+HS_SPEED+0
#define VPLT_HS_SPEED_1 VIOCTL+HS_SPEED+1
#define VPLT_HS_SPEED_2 VIOCTL+HS_SPEED+2
#define VPLT_HS_SPEED_3 VIOCTL+HS_SPEED+3
struct VIPStatusStruct
{
unsigned char PresentMode;
unsigned char LatchedFunctionRegister;
unsigned char InterfaceStatusRegister;
unsigned char DeviceStatusRegister;
};
/* ioctl comaptible with the SunOS vp driver */
#define VPRINT 0100 /* set to print mode 0x040 */
#define VPLOT 0200 /* set to plot mode 0x080 */
#define VPRINTPLOT 0400 /* set to spp mode 0x100 */
#define VPC_TERMCOM 0040 /* pulse remote line terminate 0x20 */
#define VPC_FFCOM 0020 /* pulse ff 0x10*/
#define VPC_EOTCOM 0010 /* pulse eot 0x08 */
#define VPC_CLRCOM 0004 /* pulse clear 0x04 */
#define VPC_RESET 0002 /* pulse
reset to plotter 0x02*/
#define VPSC_BUSY 0400000
#define VPSC_ONLN 0002000
#define VPSC_VRDY 0001000
#define VPSC_MODE 0000700
#define VPSC_SPP 0000400
#define VPSC_PLOT 0000200
#define VPSC_PRINT 0000100
#define VPSC_CMDS 0000076
#define VPSC_OPEN 0000001
struct lp_regs {
unsigned short cisreg ; /* interface status reg */
unsigned short cdsreg ; /* device status reg */
};
#include <sys/ioctl.h>
#define VGETSTATE _IOR('v',0,int)
#define VSETSTATE _IOW('v',1,int)
#define LPGETREGS _IOR('v',10,struct lp_regs)
#define LPSETTIMVAL _IOW('v',11,int)
#define LPGETTIMVAL _IOR('v',12,int)
#define LPSETDEBUGLVL _IOW('v',13,int)
#define LPGETDEBUGLVL _IOR('v',14,int)
/* VIP register bits */
#define VIP_10115_PCI_ID 0xd5111501
#define VIP_10117_PCI_ID 0xd5111701
/* Register Addresses */
#define INTERRUPT_MASK LATCHED_FUNCTION
#define MODE_REGISTER DEVICE_TIMING
#define INTERFACE_CONTROL PULSED_FUNCTION
#define LATCHED_FUNCTION 0x00
#define DEVICE_TIMING 0x04
#define DEVICE_CONTROL 0x08 /* ECP */
#define PULSED_FUNCTION 0x0c
#define INTERFACE_STATUS 0x10
#define DEVICE_STATUS 0x14
#define REVERSE_DATA 0x18 /* ECP */
#define AUTO_LTR_COUNT_LOW 0x20
#define AUTO_LTR_COUNT_HI 0x30
#define PIO_BYTE_OUT 0x40
#define COMMAND_OUT 0x48
#define PIO_OUT_32 0x50
/* Latched functions: register read/write */
#define L_FLTM 0x01 /* enable centronics fault irq */
#define L_NSLM 0x02 /* enable not-selected/off-line irq */
#define L_NPPM 0x04 /* enable out-of-paper irq */
#define L_NFLM 0x10 /* enable not full irq */
#define L_NHFM 0x20 /* enable not half full irq */
#define L_EMTM 0x40 /* enable fifo empty irq */
#define L_DIRM 0x80 /* enable
device and interface ready irq */
/* Device timing: register read/write */
#define T_SPD0 0x01 /* Handshake timing selection 0 */
#define T_SPD1 0x02 /* Handshake timing selection 1 */
#define T_SWIZ 0x04 /* Byte Swizzle */
#define T_IBSY 0x10 /* Ignore Busy */
#define T_UBSY 0x20 /* Use Busy, not ACK */
#define T_REVD 0x40 /* Reverse Data */
#define T_4EDG 0x80 /* 4 edge
handshake */
/* Device Control (ECP): register read/write */
#define E_AINT 0x01 /* Assert nINIT*/
#define E_DSEL 0x02 /* De-assert SEL IN*/
#define E_AAFD 0x04 /* Assert nAutoFd */
#define E_ASTB 0x08 /* Assert Strobe */
#define E_STBD 0x20 /* Disable Auto Strobe */
#define E_RDYD 0x40 /* Disable READY*/
#define E_FRDY 0x80 /* Forece
READY */
/* Pulsed functions: register read/write */
#define P_REST 0x01 /* reset versatec device */
#define P_RINT 0x20 /* reset irq latch */
#define P_SWAK 0x40 /* software ack */
#define P_MCLR 0x80 /* master
clear for board */
/* Interface status: register read */
#define I_8BIT 0x01 /* 8 bit data path */
#define I_PRNT 0x02 /* print mode */
#define I_NFLL 0x04 /* fifo not full */
#define I_NHFL 0x08 /* fifo not half full */
#define I_EMPT 0x10 /* fifo empty */
#define I_INTF 0x20 /* interrupting */
#define I_DRDY 0x40 /* device ready */
#define I_DIRY 0x80 /* device
and interface ready, fifo empty */
/* Device status: register read */
#define D_CFLT 0x01 /* 1 = centronic fault asserted */
#define D_ONLN 0x02 /* 1 = device selected (online) */
#define D_PMTY 0x04 /* 1 = paper empty */
#define D_CBSY 0x08 /* 1 = centronics busy asserted */
#define D_VRDY 0x10 /* 1 = Versatec ready asserted */
#define D_CENT 0x20 /* 0 = centronics selected */
#define D_VDIF 0x40 /* 0 = Versatec differential selected */
#define D_VTTL 0x80 /* 0 = Versatec
TTL selected */
/* Command Out functions: register write */
#define C_VCLR 0x41 /* Versatec clear */
#define C_VTFF 0x42 /* Versatec form feed */
#define C_VEOT 0x44 /* Versatec EOT */
#define C_VLTR 0x48 /* Versatec line terminate */
#define C_VPRN 0x20 /* Versatec print/plot mode */
#define C_VPLT 0x21 /* Versatec print/plot mode */
#define C_VSPP 0x22 /* Versatec spp mode OR'd into C_VPRN or C_VPLT */
#define C_DSTR_OFF 0x00 /* Data streaming off */
#define C_DSTR_ON 0x01 /* Data streaming on */
#define C_ALTR_OFF 0x00 /* Auto LTR off */
#define C_ALTR_ON 0x10 /* Auto
LTR on */
#endif /* #ifndef _VPIOCTL_H_
*/
Purpose:
Assigns register values to constants
used to interface to the device driver.
Description:
This header file contains all the #defined
constants which were used in the device driver routine to substitute for
register values. This file is #included in any program that needs to access
the device. It defines the IOCTL interface to the driver and the meaning
of the return status. This can be incorporated into a program that sends
out IOCTL commands to the Ikon board.
Note: since the IRIX operating system
has no ‘smit’ setable parameters like the AIX operating system, the handshake
speed, device timeout value, and driver debug level are set thru ioctl’s.
See vipdma.c for examples of how to issue the ioctl commands.
vremove batch file
/ script
Contents:
# vremove - Versatec Ikon PCI device driver for SGI IRIX 6.4
# Copyright (c) 1997, Interface Consultants, Houston, TX
# 3375 Westpark Drive #143
# Houston, TX 77005-4262
# 713/529-3706
# 713/529-3725 Fax
# http://www.ifc2.com
# email: neo@ifc2.com
#
# vremove Version 4.8 April 20, 1998
#
#ml unld 73
rm /var/sysgen/boot/vipdd.o
rm /var/sysgen/system/vipdd.sm
rm /var/sysgen/master.d/vipdd
rm /usr/include/sys/vpioctl.h
rm /dev/vip0
autoconfig
Purpose:
Batch file to remove the driver.
Description:
This batch file will remove all files
pertinent to the device driver. It will also remove the device that was
configured by the driver (vip0).
6. Viptest
- test plot and programming example
The viptest program is provided with
C source code as an example of how to write a user program that interfaces
to the vip device driver.
Typing 'viptest' with no parameters
prints the following synopsis:
# viptest
VIP driver test program - Version 3.7 July 24, 1997
Copyright Interface Consultants
1997
Usage: viptest -f<device name>
-f<device name> (e.g. /dev/vip0)
output test print and plot to
device
The following is the screen output
from a call to the viptest program:
# viptest -f/hw/vip0
VIP driver test program - Version 3.7 July 24, 1997
Copyright Interface Consultants 1997
device name = /hw/vip0
block = 0 cnt=1000
block = 1 cnt=2000
...
block = 58 cnt=59000
block = 59 cnt=60000
The plotter output for viptest is 'hello'
in print mode, and then it does dma plot mode of blocks filled with 0xf0.
There are 100 blocks sent. The first block is 1000 bytes, and each block
is increased in size by 1000 bytes until it rolls over the 16 bit max.
Thermal plotters will plot in yellow and white.
To advance the plot out of the plotter,
do a manual form feed, or output a form feed command using vipdma as follows:
# vipdma -cVTFF
7. Vipdma
- file dma output program
The 'vipdma' program allows files to
be output to a plotter or printer in print or plot mode using high speed
DMA. Vipdma is double buffered, and executes command line functions in
a left to right order as entered. Vipdma is full featured, in that it can
perform any plotter function that a user program can issue.
Typing 'vipdma' with no parameters
prints the following synopsis:
VIP driver DMA output program - Version 3.7 July 24, 1997
Copyright Interface Consultants
1997
Usage: vipdma -w<> [-d<>] [-m<>] [-f<>] [-c<>] [-v] [-t<>]
-w<output device> (required- e.g. /hw/vip0)
-d<dma_sizein Kb> (optional - default=16 max=128)
-m<mode> mode for transfer, PRINT(default) or PLOT
-f<filename> data file to dma to port
-c<command> Remote command to plotter, can be:
VRST - Versatec Remote Reset
VCLR - Versatec Remote Clear
VTFF - Versatec Remote Form Feed
VEOT - Versatec End or Terminate
VRLT - Versatec Remote Line Terminate
CSTAT - Get current status
LSTAT - Get latched status
VPRINT - Versatec Print Mode
VPLOT - Versatec Plot Mode
VPRINTPLOT - Versatec SPP Mode
VPC_TERMCOM - Versatec Remote Line Terminate
VPC_FFCOM - Versatec Remote Form Feed
VPC_EOTCOM - Versatec End or Terminate
VPC_CLRCOM - Versatec Remote Clear
VPC_RESET - Versatec Remote Reset
VPLT_HS_SPEED_0 - Set Handshake speed 0 fast
VPLT_HS_SPEED_1 - Set Handshake speed 1
VPLT_HS_SPEED_2 - Set Handshake speed 2
VPLT_HS_SPEED_3 - Set Handshake speed 3 slow
VGETSTATE - Get Versatec VPSC Status
LPGETREGS - Get Versatec registers
LPGETTIMVAL - Get Versatec timeout value
LPGETDEBUGLVL - Get driver debug level
-t<timeout> LPSETTIMVAL - Set Versatec timeout
-b<debug lvl> LPSETDEBUGLVL - Set driver debug level
-v verbose mode
Note: args are executed left to right as found, multiple files in
different modes can be sent in a single command.
e.g. vipdma -w/dev/vip0 -d32 -mPRINT -ffile1.prn -mPLOT -ffile2.plt
sends file1.prn in print mode,
and then file2.plt in plot mode
Full Versatec 'greensheet' output can be implemented with vipdma if preamble and rewind commands are put into files that are output in print mode, and plot data padded to the correct bytes per scan in color separate files is output in plot mode.
07/28/98
4.2.0 - full release version
/* viptest.c - Versatec Ikon PCI device driver for SGI IRIX 6.4
* Copyright (c) 1998, Interface Consultants, Houston, TX
* 3375 Westpark Drive #143
* Houston, TX 77005-4262
* 713/529-3706
* 713/529-3725 Fax
* http://www.ifc2.com
* email: neo@ifc2.com
*/
static char VersionString[] = {
"viptest Version 4.9 April 20,
1998"};
static char InterfaceConsultants[] ={
"Copyright (c) 1997, Interface Consultants, Houston, TX"};
/* VIP driver test program */
/* this test program outputs 'hello' in print mode, and then
does dma plot mode of blocks filled with 0xf0. There are
100 blocks sent. The first block is 1000 bytes, and each
block is increased in size by 1000 bytes until it rolls
over the 16 bit max. */
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <unistd.h> /*Needed
for access subroutine constants*/
#include "vpioctl.h"
int file_ptr;
/*************************************************************************/
uint test_print (int file_ptr,char
*string) {
uint rc;
int length;
rc = ioctl(file_ptr, VPLT_PRINT, NULL);
if (rc != 0) {
printf("Error on test_print ioctl VPLT_PRINT, rc=%d\n",rc,length);
exit(-1);
}
length = strlen(string);
rc = write(file_ptr,string,length);
if (rc != length) {
printf("Error on test_print write, rc=%d length=%d\n",rc,length);
exit(-1);
}
return(0);
}
/*************************************************************************/
int test_plot (int file_ptr,char
*string,uint byte_count) {
uint rc;
rc = ioctl(file_ptr, VPLT_PLOT, NULL);
if (rc != 0) {
printf("Error on test_plot VPLT_PLOT, rc=%d\n",rc);
exit(-1);
}
rc = write(file_ptr,string,byte_count);
if (rc != byte_count) {
printf("Error on test_plot write, rc=%d byte_count=%d\n",rc,byte_count);
exit(-1);
}
return(0);
}
/*************************************************************************/
void dma_file (char *devname) {
uint i;
char *plot_data;
uint pd_count;
uint blk_count;
int rc;
file_ptr = open(devname,O_WRONLY);
if (file_ptr == -1) {
printf("Error opening device %s, errno=%d\n",devname,errno);
exit(-1);
}
rc = test_print(file_ptr,"hello \r\n");
if (rc != 0) {
return;
}
pd_count = 0xf000;
blk_count = 1000;
plot_data = (char *)malloc(pd_count);
if (plot_data == NULL) {
printf("cannot allocate test buffer of %u bytes\n",pd_count);
return;
}
for (i=0;i<pd_count;i++) {
plot_data[i] = 0xf0;
}
for (i=0; i< 60;i++) {
printf("block = %u cnt=%u\n",i,blk_count);
rc = test_plot(file_ptr,plot_data,blk_count);
blk_count += 1000; /* note: this will roll over after 65 or so */
}
}
/*************************************************************************/
void useage (void) {
printf("\nUsage: viptest -f<device name>\n");
printf(" -f<device name> (e.g. /dev/vip0) \n");
printf(" output test print and plot to device\n");
}
/*************************************************************************/
int main(int argc, char ** argv)
{
int c;
/*************************************************************/
/* print opening banner */
/*************************************************************/
printf("VIP driver test program - %s\n",VersionString);
printf(" Copyright Interface
Consultants 1997\n");
if (argc == 1) {
useage();
exit (-1);
}
/*****************************************************************/
/* get command line arguments */
/*****************************************************************/
while (1) {
c = getopt(argc,argv,"f:");
if (c != EOF) {
c = tolower(c);
switch(c) {
case 'f':
printf("device name = %s\n",optarg);
dma_file(optarg);
break;
default:
printf("Unknown parameter 0x%x %c\n",c,c);
useage();
break;
}
}
else {
break;
}
}
return 0;
}
/*************************************************************************/