Ikon 10117 SGI IRIX 6.4 Device Driver

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
 
 
 
 

1. Introduction
 
 

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.

8. Miscellaneous Notes
 
 

  1. The device ‘open‘ will succeed even if the plotter is ‘offline.’ This way, an ioctl can be used to determine detailed status (ref. VPLT.CSTAT).

  2.  

     
     
     
     
     
     
     

  3. The Ikon board FIFO buffer is cleared on a device timeout and when the device is configured.

  4.  

     
     
     
     
     
     
     

  5. The handshake speed, timeout value, and debug level are not system defined attributes, and must be set in the driver via ioctl() function calls. IRIX has no facility equivalent to the AIX ODM to define system attributes. Once set, theses values remain until the device driver is reloaded by the operating system.

  6.  

     
     
     
     
     
     
     

  7. There is no ‘programmed I/O’ mode for this driver. It uses PCI bus master DMA at all times for data transfer. The AIX driver had a ‘programmed I/O’ mode selection because it used bus slave DMA, a system resource which might not be available in particular configurations.
9. Revision History
 
 

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;

}

/*************************************************************************/