

**Revision: A** February 2004



## **Control Information**

| Control Item      | Details              |
|-------------------|----------------------|
| Document Owner    | Mark Mason           |
| Information Label | EDT Public           |
| Supersedes        | None                 |
| File Location     | frm:/pci11w/p11w.doc |
| Document Number   | 008-00907-00         |

## **Revision History**

| Revision | Date      | Revision Description                                    | Originator |
|----------|-----------|---------------------------------------------------------|------------|
| Draft    | 04-Feb-04 | Convert from FrameMaker to Word; update pciload section | S Vasil    |



The information in this document is subject to change without notice and does not represent a commitment on the part of Engineering Design Team, Inc. The software described in this document is furnished under a license agreement or nondisclosure agreement. The software may be used or copied only in accordance with the terms of the agreement.

Engineering Design Team, Inc. ("EDT"), makes no warranties, express or implied, including without limitation the implied warranties of merchantibility and fitness for a particular purpose, regarding the software described in this document ("the software"). EDT does not warrant, guarantee, or make any representations regarding the use or the results of the use of the software in terms of its correctness, accuracy, reliability, currentness, or otherwise. The entire risk as to the results and performance of the software is assumed by you. The exclusion of implied warranties is not permitted by some jurisdictions. The above exclusion may not apply to you.

In no event will EDT, its directors, officers, employees, or agents be liable to you for any consequential, incidental, or indirect damages (including damages for loss of business profits, business interruption, loss of business information, and the like) arising out of the use or inability to use the software even if EDT has been advised of the possibility of such damages. Because some jurisdictions do not allow the exclusion or limitation of liability for consequential or incidental damages, the above limitations may not apply to you. EDT's liability to you for actual damages for any cause whatsoever, and regardless of the form of the action (whether in contract, tort [including negligence], product liability or otherwise), will be limited to \$50.

No part of this manual may be reproduced or transmitted in any form or by any means, electronic or mechanical, without the express written agreement of Engineering Design Team, Inc.

© Copyright Engineering Design Team, Inc. 1997–2004. All rights reserved.

Sun, SunOS, SBus, SPARC, and SPARCstation are trademarks of Sun Microsystems, Incorporated.

Windows NT/2000/XP is a registered trademark of Microsoft Corporation.

Intel and Pentium are registered trademarks of Intel Corporation.

UNIX is a registered trademark of X/Open Company, Ltd.

OPEN LOOK is a registered trademark of UNIX System Laboratories, Inc.

Red Hat is a trademark of Red Hat Software, Inc.

IRex is a trademark of Silicon Graphics, Inc.

AIX is a registered trademark of International Business Machines Corporation.

Xilinx is a registered trademark of Xilinx, Inc.

Kodak is a trademark of Eastman Kodak Company.

The software described in this manual is based in part on the work of the independent JPEG Group.

EDT and Engineering Design Team are trademarks of Engineering Design Team, Inc.

## Contents

| Overview                                                                                                                                                      | 5                          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| After Installing<br>Testing<br>Building the Sample Programs<br>Uninstalling                                                                                   | 6<br>7<br>8                |
| Upgrading the Firmware                                                                                                                                        |                            |
| Real-time Input and Output<br>Elements of EDT Interface Applications<br>DMA Library Routines<br>EDT Message Handler Library<br>Message Definitions            | 10<br>12<br>47<br>47       |
| Files                                                                                                                                                         |                            |
| Hardware<br>PCI Local Bus Interface<br>FIFO<br>Device Interface<br>Logic Levels                                                                               | 56<br>56<br>56             |
| Signals<br>Synchronous Control Signals<br>Handshake Signals<br>Asynchronous Control Signals<br>Unimplemented DR11W Signals<br>Timing                          | 60<br>60<br>61<br>61       |
| Registers<br>Configuration Space<br>PCI Local Bus Addresses<br>Scatter-gather DMA<br>Performing DMA<br>Flash ROM Access Registers<br>Device Control Registers | 63<br>64<br>65<br>66<br>71 |
| Specifications                                                                                                                                                | 77                         |
| References                                                                                                                                                    | 78                         |

# **Overview**

The PCI 11W is a single-slot, 16-bit parallel input/output interface for PCI local bus-based computer systems. The external interface conforms to the DR11W standard of Digital Equipment Corporation. The PCI 11W features 128 bytes of FIFO storage in each direction and can support continuous data rates of up to 8 MB per second. The board also includes diagnostic capability.

The PCI 11W supports scatter-gather Direct Memory Access (DMA) in hardware, adapting to the memory management model of the host architecture. It includes a software driver and software library, enabling applications to access the PCI 11W and transfer data continuously or in bursts across the PCI 11W interface using standard library calls.

The PCI 11W supports a high-speed block mode as well as all standard DR11W protocols. In this block mode, the PCI 11W transfers data from the PCI Local Bus memory with burst transfers, using FIFO memory on the PCI 11W to buffer the transfer. This capability is useful if your application requires high data transfer rates and does not change direction in mid-block.

The PCI 11W also allows link mode applications, in which one PCI 11W communicates with another or with a DR11W.

Test the PCI 11W by installing an optional loopback connector and executing the PCI 11W diagnostics. A diagnostic program is included with the standard PCI 11W software. The loopback connector kit is available separately. Contact Engineering Design Team or your distributor for further information.

A high-density connector attaches the PCI 11W device to the device cable supplied with the interface. The other end of the cable terminates in two standard DR11W 40-pin connectors. High-density connectors terminate both ends of a PCI 11W-to-PCI 11W interface.

This manual describes the operation of the PCI 11W with UNIX-based and Windows NT operating systems.

# After Installing

After installing the PCI 11W, test the board and build the sample programs, if you wish. Instructions for uninstalling the software and upgrading the firmware are also provided if necessary.

## Testing

You can perform diagnostics on the PCI 11W by installing an optional loopback connector and executing the looptest.c diagnostic program included with the standard PCI 11W software. The diagnostic program requires that the PCI 11W driver be installed.

To test the PCI 11W, loop output data from the host back panel or the end of the device cable back to the input. The optional EDT PCI 11W Loopback Kit, part number 012-00067, provides test connectors for both loopback configurations. The loopback kit contains complete instructions for the PCI 11W loopback diagnostics.

The diagnostic program looptest.c, used in conjunction with the loopback test connectors, performs the tests described in the table below. To install the program, at the command prompt, enter:

make looptest

Use looptest with the following command-line arguments:

looptest [-u n] [-c n] [-b n] [-e] [-t [psfklbi]] loopcount

- -u *n* The device number of the board to test: use 0 for the first PCI 11W board, 1 for the second, etc. The default device is 0.
- -c n Sets how many words to write for loopback data test. The default is 0xFFFF.
- -b *n* Sets how many blocks to write for DMA test. The default is 1000.
- -e Prints first miscompared word only.
- -t Selects which test to perform (the default is all):

| р | program I/O |
|---|-------------|
| S | swap        |

- f function/status bits
- k input/ouput skew
- 1 loopback data
- b block loopback
- i interrupt event

loopcount How many times to run the test. Zero means run until explicitly halted.

| Test Name          | Test Operation Performed                                                                                                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Loopback Data Test | Wrtie successive values from 0 to 0xFFFF (or other value, if specified with $-c$ argument), then read each word and compare the expected values with the actual values. |
| Swap Test          | With the SWAP bit set, write and read walking ones and zeroes. This test exercises different data paths in the PCI 11W.                                                 |

| Block Loopback               | Write 1000 blocks (or other value, if specified with –b argument) of 0x1F000 words, then read back the value of the last word in each block, comparing the actual value with the expected value. |
|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function/Status Bits         | Output all function bits, and compare the reported function bits in the Status Register with the looped-back status bits.                                                                        |
| ATTN event from<br>pulsed F2 | Set an event interrupt function on ATTN, then pulse FNCT2 (which loops back to ATTN), and check for occurrence of the event.                                                                     |
| Program I/O                  | Writes to data register without DMA and compares value read to value written, to ensure correctness.                                                                                             |
| Input and Output Skew        | Writes values to the input and output skew bits of the configuration register to ascertain the input and output skew are functioning correctly.                                                  |

See the "Signals" section on page 58 and the "Registers" section on page 63 for more information.

## **Building the Sample Programs**

## **UNIX-based Systems**

To build any of the example programs on UNIX-based systems, cd to /opt/EDTp11w and enter the command:

make program name

where *file* is the name of the example program you wish to install.

To build and install all the example programs, enter the command:

make

**Outcome:** All example programs display a message that explains their usage when you enter their names without parameters.

#### Windows NT Systems

To build any of the example programs on Windows NT systems:

- 1. Runpcill Utilities.
- 2. Enter the command:

nmake program.exe

where *file* is the name of the example program you wish to build.

To build and install all the example programs, simply enter the command:

nmake

**Outcome:** All example programs display a message that explains their usage when you enter their names without parameters.

**Note:** You can also build the sample programs by setting up a project in Windows Visual C++. Contact EDT for instructions.

## Uninstalling

## Solaris Systems

To remove the PCI 11W driver on Solaris systems:

- 1. Become root or superuser.
- 2. Enter:

pkgrm EDTp11w

For further details, consult your operating system documentation, or call Engineering Design Team.

## Linux Systems

To remove the PCI 11W driver on Linux systems, enter:

```
cd /opt/EDTp11w
make unload
cd /
rm -rf /opt/EDTp11w
```

## Windows Systems

To remove the PCI 11W toolkit on Windows systems, use the Windows Add/Remove utility. For further details, consult your Windows documentation.

You can always get the most recent update of the software from our web site, **www.edt.com**. See the document titled *Contact Us*.

## **Upgrading the Firmware**

Field upgrades to the PCI firmware may occasionally be necessary when upgrading to a new device driver.

The Xilinx file is downloaded to the board's PCI interface Xilinx PROM using the pciload program:

- 1. Navigate to the directory in which you installed the driver (for UNIX-based systems, usually /opt/EDTp11w; for Windows, usually C:\EDT\p11w).
- 2. At the prompt, enter:

pciload verify

This will compare the current PCI Xilinx file in the package with what is currently on the board's PROM.

**Note:** If more than one board is installed on a system, use the following, where N is the board unit number:

pciload -u N verify

**Outcome:** Dates and revision numbers of the PROM and File ID will be displayed. If these numbers match, there is no need for a field upgrade. If they differ, upgrade the flash PROM as follows:

a. At the prompt, enter:

pciload update

b. Shut down the operating system and turn the host computer off and then back on again. The board reloads firmware from flash ROM only during power-up. Therefore, after running pciload, the new bit file is not in the Xilinx until the system has been power-cycled; simply rebooting is not adequate.

To just see what boards are in the system, run pciload without any arguments:

pciload

To see other pciload options, run:

pciload help



# **Real-time Input and Output**

The PCI 11W device driver can perform two kinds of DMA transfers: continuous and noncontinuous.

To perform continuous transfers, use ring buffers. The ring buffers are a set of buffers that applications can access continuously, reading and writing as required. When the last buffer in the set has been accessed, the application then cycles back to the first buffer. See

edt\_configure\_ring\_buffers for a complete description of the ring buffer parameters that can be configured. See the sample programs simple\_getdata.c and simple\_putdata.c distributed with the driver for examples of using the ring buffers.

For noncontinuous transfers, the driver uses DMA system calls read and write. Each read and write system call performs a single, noncontinuous DMA transfer.

**Note:** For portability, use the library calls edt\_reg\_read, edt\_reg\_write, edt\_reg\_or, or edt\_reg\_and to read or write the hardware registers rather than ioctls.

## **Elements of EDT Interface Applications**

Applications for performing continuous transfers typically include the following elements:

```
#include "edtinc.h"
main()
{
   EdtDev *edt_p = edt_open("pcd", 0) ;
   char *buf_ptr; int outfd = open("outfile", 1) ;
   /* Configure a ring buffer with four 1MB buffers */
   edt_configure_ring_buffers(edt_p, 1024*1024, 4, EDT_READ, NULL) ;
   /* start 4 buffers*/
   edt_start_buffers(edt_p, 4) ;
   /* This loop will capture data indefinitely, but the write()
    * (or whatever processing on the data) must be able to keep up.
   * /
   while ((buf_ptr = edt_wait_for_buffers(edt_p, 1)) != NULL)
       write(outfd, buf_ptr, 1024*1024) ;
       edt_start_buffers(edt_p, 1) ;
   edt_close(edt_p) ;
}
```

Applications for performing noncontinuous transfers typically include the following elements. This example opens a specific DMA channel with edt\_open\_channel, assuming that a multi-channel Xilinx firmware file has been loaded:

```
#include "edtinc.h"
main()
{
    EdtDev *edt_p = edt_open_channel("pcd", 1, 2) ;
    char buf[1024] ;
    int numbytes, outfd = open("outfile", 1) ;
```

```
/*
    * Because read()s are noncontinuous, unless is there hardware
    * handshaking there will be gaps in the data between each read().
    */
   while ((numbytes = edt_read(edt_p, buf, 1024)) > 0)
      write(outfd, buf, numbytes) ;
   edt_close(edt_p) ;
}
```

You can use ring buffer mode for real-time data capture using a small number of buffers (usually four of 1 MB) configured in a round-robin data FIFO. During capture, the application must be able to transfer or process the data before data acquisition wraps around and overwrites the buffer currently being processed.

The example below shows real-time data capture using ring buffers, although it includes no error checking. In this example, process\_data (bufptr) must execute in the same amount of time it takes DMA to fill a single buffer or faster.

```
#include "edtinc.h"
main()
{
  EdtDev *edt_p = edt_open("pcd", 0) ;
   /* Configure four 1 MB buffers:
   * one for DMA
   * one for the second DMA register on most EDT boards
   * one for "process_data(bufptr)" to work on
   * one to keep DMA away from "process_data()"
   */
  edt_configure_ring_buffers(edt_p, 1*1024*1024, 4, EDT_READ, NULL) ;
  edt_start_buffers(edt_p, 4) ; /* start 4 buffers */
  for (;;)
   {
     char *bufptr ;
     /* Wait for each buffer to complete, then process it.
      * The driver continues DMA concurrently with processing.
      * /
     bufptr = edt_wait_for_buffers(edt_p, 1) ;
     process_data(bufptr) ;
     edt_start_buffers(edt_p, 1) ;
  }
}
```

Check compiler options in the EDT-provided make files.

EDI

## **DMA Library Routines**

The DMA library provides a set of consistent routines across many of the EDT products, with simple yet powerful ring-buffered DMA capabilities. The following table lists the general DMA library routines, described in an order corresponding roughly to their general usefulness.

| Routine                     | Description                                                                                                               |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------|
| Startup/Shutdown            |                                                                                                                           |
| edt_open                    | Opens the EDT Product for application access.                                                                             |
| edt_open_channel            | Opens a specific channel on the EDT Product for application access.                                                       |
| edt_close                   | Terminates access to the EDT Product and releases resources.                                                              |
| edt_parse_unit              | Parses an EDT device name string.                                                                                         |
| Input/Output                |                                                                                                                           |
| edt_read                    | Single, application-level buffer read from the EDT Product.                                                               |
| edt_write                   | Single, application-level buffer write to the EDT Product.                                                                |
| edt_start_buffers           | Begins DMA transfer from or to specified number of buffers.                                                               |
| edt_stop_buffers            | Stops DMA transfer after the current buffer(s) complete(s).                                                               |
| edt_check_for_buffers       | Checks whether the specified number of buffers have completed without blocking.                                           |
| edt_done_count              | Returns absolute (cumulative) number of completed buffers.                                                                |
| edt_get_todo                | Gets the number of buffers that the driver has been told to acquire.                                                      |
| edt_wait_for_buffers        | Blocks until the specified number of buffers have completed.                                                              |
| edt_wait_for_next_buffer    | Waits for the next buffer that completes DMA.                                                                             |
| edt_wait_buffers_timed      | Blocks until the specified number of buffers have completed; returns a pointer to the time that the last buffer finished. |
| edt_next_writebuf           | Returns a pointer to the next buffer scheduled for output DMA.                                                            |
| edt_set_buffer              | Sets which buffer should be started next.                                                                                 |
| edt_set_buffer_size         | Used to change the size or direction of one of the ring buffers.                                                          |
| edt_last_buffer             | Waits for the last buffer that has been transferred.                                                                      |
| edt_last_buffer_timed       | Like edt_last_buffer but also returns the time at which the dma was complete on this buffer.                              |
| edt_configure_ring_buffers  | Configures the ring buffers.                                                                                              |
| edt_buffer_addresses        | Returns an array of addresses referencing the ring buffers.                                                               |
| edt_disable_ring_buffers    | Stops DMA transfer, disables ring buffers and releases resources.                                                         |
| edt_ring_buffer_overrun     | Detects ring buffer overrun which may have corrupted data.                                                                |
| edt_reset_ring_buffers      | Stops DMA in progress and resets the ring buffers.                                                                        |
| edt_configure_block_buffers | Configures ring buffers using a contiguous block of memory.                                                               |
| edt_startdma_action         | Specifies when to perform the action at the start of a dma transfer as set by edt_startdma_reg().                         |
| edt_enddma_action           | Specifies when to perform the action at the end of a dma transfer as set by edt_ednddma_reg().                            |

| Routine                  | Description                                                                                                                                  |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| edt_startdma_reg         | Specifies the register and value to use at the start of dma, as set by edt_startdma_action().                                                |
| edt_abort_dma            | Cancels the current DMA, resets pointers to the current buffer.                                                                              |
| edt_ablort_current_dma   | Cancels the current DMA, moves pointers to the next buffer.                                                                                  |
| edt_get_bytecount        | Returns the number of bytes transferred.                                                                                                     |
| edt_timeouts             | Returns the cumulative number of timeouts since the device was opened.                                                                       |
| edt_get_timeout_count    | Returns the number of bytes transferred as of the last timeout.                                                                              |
| edt_set_timeout_action   | Sets the driver behavior on a timeout.                                                                                                       |
| edt_get_timeout_goodbits | Returns the number of bits from the remote device since the last timeout.                                                                    |
| edt_do_timeout           | Causes the driver to perform the same actions as it would on a timeout (causing partially filled fifos to be flushed and dma to be aborted). |
| edt_get_rtimeout         | Gets the DMA read timeout period.                                                                                                            |
| edt_set_rtimeout         | Sets how long to wait for a DMA read to complete, before returning.                                                                          |
| edt_get_wtimeout         | Gets the DMA write timeout period.                                                                                                           |
| edt_set_wtimeout         | Sets how long to wait for a DMA write to complete, before returning.                                                                         |
| edt_get_timestamp        | Gets the seconds and microseconds timestamp of dma completion on the buffer specified by bufnum.                                             |
| edt_get_reftime          | Gets the seconds and mircroseconds timestamp in the same format as the buffer_timed function.                                                |
| edt_ref_tmstamp          | Used for debugging. Able to see a history with setdebug _g with an application defined event in the same timeline as driver events.          |
| edt_get_burst_enable     | Returns a value indicating whether PCI Bus burst transfers are enabled during DMA.                                                           |
| edt_set_burst_enable     | Turns on or off PCI Bus burst transfers during DMA.                                                                                          |
| edt_get_firstflush       | Returns the value set by edt_set_firstflush(). This is an obsolete function.                                                                 |
| edt_set_firstflush       | Tells whether and when to flush FIFOs before DMA.                                                                                            |
| edt_flush_fifo           | Flushes the EDT Product FIFOs.                                                                                                               |
| edt_get_goodbits         | Returns the number of bits from the remote device.                                                                                           |
| Control                  |                                                                                                                                              |
| edt_set_event_func       | Defines a function to call when an event occurs.                                                                                             |
| edt_remove_event_func    | Removes a previously set event function.                                                                                                     |
| edt_reg_read             | Reads the contents of the specified EDT Product register.                                                                                    |
| edt_reg_write            | Writes a value to the specified EDT Product register.                                                                                        |
| edt_reg_and              | ANDs the value provided with the value of the specified EDT Product register.                                                                |
| edt_reg_or               | ORs the value provided with the value of the specified EDT Product                                                                           |

EDT

| Routine               | Description                                                                                         |
|-----------------------|-----------------------------------------------------------------------------------------------------|
|                       | register.                                                                                           |
| edt_get_foicount      | Returns the number of RCI modules connected to the EDT FOI (fiber optic interface) board.           |
| edt_set_foiunit       | Sets which RCI unit to address with subsequent serial and register read/write functions.            |
| edt_intfc_write       | A convenience routine, partly for backward compatability, to access the XILINX interface registers. |
| edt_intfc_write_short | A convenience routine, partly for backward compatability, to access the XILINX interface registers. |
| edt_intfc_write_32    | A convenience routine, partly for backward compatability, to access the XILINX interface registers. |
| Utility               |                                                                                                     |
| edt_msleep            | Sleep for the specified number of microseconds.                                                     |
| edt_alloc             | Allocate page-aligned memory in a system-independent way.                                           |
| edt_free              | Free the memory allocated with edt_alloc.                                                           |
| edt_perror            | Prints a system error message in case of error.                                                     |
| edt_errno             | Returns an operating system-dependent error number.                                                 |
| edt_access            | Determines file access independent of operating system.                                             |
| edt_get_bitpath       | Obtains pathname to the currently loaded interface bitfile from the driver.                         |

#### edt\_open

#### Description

Opens the specified EDT Product and sets up the device handle.

#### Syntax

#include "edtinc.h"
EdtDev \*edt\_open(char \*devname, int unit) ;

#### Arguments

| devname | a string with the name of the EDT Product board. For example, "edt". |
|---------|----------------------------------------------------------------------|
| unit    | specifies the device unit number                                     |

#### Return

A handle of type (EdtDev \*), or NULL if error. (The structure(EdtDev \*) is defined in libedt.h.) If an error occurs, check the erron global variable for the error number. The device name for the EDT Product is "edt". Once opened, the device handle may be used to perform I/O using edt\_read(), edt\_write(), edt\_configure\_ring\_buffers(), and other input-output library calls.

## edt\_open\_channel

#### Description

Opens a specific DMA channel on the specified EDT Product, when multiple channels are supported by the Xilinx firmware, and sets up the device handle. Use edt\_close() to close the channel.

## Syntax

#include "edtinc.h"

EdtDev \*edt\_open\_channel(char \*devname, int unit, int channel) ;

#### Arguments

| devname | a string with the name of the EDT Product board. For example, $\$ "edt" . |
|---------|---------------------------------------------------------------------------|
| unit    | specifies the device unit number                                          |
| channel | specifies the DMA channel number counting from zero                       |

## Return

A handle of type (EdtDev \*), or NULL if error. (The structure(EdtDev \*) is defined in libedt.h.) If an error occurs, check the erron global variable for the error number. The device name for the EDT Product is "edt". Once opened, the device handle may be used to perform I/O using edt\_read(), edt\_write(), edt\_configure\_ring\_buffers(), and other input-output library calls.

## edt\_close

## Description

Shuts down all pending I/O operations, closes the device or channel and frees all driver resources associated with the device handle.

## Syntax

#include "edtinc.h"
int edt\_close(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_parse\_unit

#### Description

Parses an EDT device name string. Fills in the name of the device, with the default\_device if specified, or a default determined by the package, and returns a unit number. Designed to facilitate a flexible device/unit command line argument scheme for application programs. Most EDT example/utility programs use this subroutine to allow users to specify either a unit number alone or a device/unit number concatenation.

For example, if you are using a PCI CD, then either xtest -u 0 or xtest -u pcd0 could both be used, since xtest sends the argument to edt\_parse\_unit, and the subroutine parses the string to returns the device and unit number separately.

#### Syntax

```
int edt_parse_unit(char *str, char *dev, char *default_dev)
```

#### Arguments

| str         | device name string. Should be either a unit number ("0" - "8") or device/unit concantenation ("pcd0," "pcd1," etc.)                                                                                                             |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dev         | device string, filled in by the routine. For example, "pcd."                                                                                                                                                                    |
| default_dev | device name to use if none is given in the str argument. If NULL, will be filled in by the default device for the package in use. For example, if the code base is from a PCI CD package, the default_dev will be set to "pcd." |

## Return

Unit number or -1 on error. The first device is unit 0.

#### See Also

example/utility programs xtest.c, initcam.c, take.c

## edt\_read

#### Description

Performs a read on the EDT Product. For those on UNIX systems, the UNIX 2 GB file offset bug is avoided during large amounts of input or output, that is, reading past 231 bytes does not fail. This call is not multibuffering, and no transfer is active when it completes.

#### Syntax

```
#include "edtinc.h"
```

int edt\_read(EdtDev \*edt\_p, void \*buf, int size);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> |
|-------|------------------------------------------------------------------------|
| buf   | address of buffer to read into                                         |
| size  | size of read in bytes                                                  |



## Return

The return value from read, normally the number of bytes read; -1 is returned in case of error. Call edt\_perror() to get the system error message.

**Note** If using timeouts, call edt\_timeouts after edt\_read returns to see if the number of timeouts has incremented. If it has incremented, call edt\_get\_timeout\_count to get the number of bytes transferred into the buffer. DMA does not automatically continue on to the next buffer, so you need to call edt\_start\_buffers to move on to the next buffer in the ring.

#### edt\_write

#### Description

Perform a write on the EDT Product. For those on UNIX systems, the UNIX 2 GB file offset bug is avoided during large amounts of input or output; that is, writing past 231 does not fail. This call is not multibuffering, and no transfer is active when it completes.

#### Syntax

#include "edtinc.h"

int edt\_write(EdtDev \*edt\_p, void \*buf, int size);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> |
|-------|------------------------------------------------------------------------|
| buf   | address of buffer to write from                                        |
| size  | size of write in bytes                                                 |

#### Return

The return value from write; -1 is returned in case of error. Call edt\_perror() to get the system error message.

**Note** If using timeouts, call edt\_timeouts after edt\_write returns to see if the number of timeouts has incremented. If it has incremented, call edt\_get\_timeout\_count to get the number of bytes transferred into the buffer. DMA does not automatically continue on to the next buffer, so you need to call edt\_start\_buffers to move on to the next buffer in the ring.

## edt\_start\_buffers

#### Description

Starts DMA to the specified number of buffers. If you supply a number greater than the number of buffers set up, DMA continues looping through the buffers until the total count has been satisfied.

#### Syntax

```
#include "edtinc.h"
int edt_start_buffers(EdtDev *edt_p, int bufnum);
```

## Arguments

| edt_p  | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                                                                                    |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bufnum | Number of buffers to release to the driver for transfer. An argument of 0 puts the driver in free running mode, and transfers run continuously until <b>edt_stop_buffers()</b> is called. |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_stop\_buffers

## Description

Stops DMA transfer after the current buffer has completed. Ring buffer mode remains active, and transfers will be continued by calling edt\_start\_buffers().

## Syntax

```
#include "edtinc.h"
```

int edt\_stop\_buffers(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_check\_for\_buffers

#### Description

Checks whether the specified number of buffers have completed without blocking.

## Syntax

```
#include "edtinc.h"
```

```
void *edt_check_for_buffers(EdtDev *edt_p, int count);
```

## Arguments

```
count number of buffers. Must be 1 or greater. Four is recommended.
```

## Return

Returns the address of the ring buffer corresponding to count if it has completed DMA, or NULL if count buffers are not yet complete.

**Note** If the ring buffer is in free-running mode and the application cannot process data as fast as it is acquired, DMA will wrap around and overwrite the referenced buffer. The application must ensure that the data in the buffer is processed or copied out in time to prevent overrun.

## edt\_done\_count

## Description

Returns the cumulative count of completed buffer transfers in ring buffer mode.

#### Syntax

#include "edtinc.h"

int edt\_done\_count(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

The number of completed buffer transfers. Completed buffers are numbered consecutively starting with 0 when edt\_configure\_ring\_buffers() is invoked. The index of the ring buffer most recently completed by the driver equals the number returned modulo the number of ring buffers. –1 is returned if ring buffer mode is not configured. If an error occurs, call edt\_perror() to get the system error message.

## edt\_get\_todo

## Description

Gets the number of buffers that the driver has been told to acquire. This allows an application to know the state of the ring buffers within an interrupt, timeout, or when cleaning up on close. It also allows the application to know how close it is getting behind the acquisition. It is not normally needed.

## Syntax

uint\_t edt\_get\_todo(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Example

int curdone;

int curtodo;

curdone=edt\_done\_count(pdv\_p);

curtodo=edt\_get\_todo(pdv\_p);

```
/* curtodo--curdone how close the dma is to catching with our processing ^{\ast}/
```

## Return

Number of buffers started via edt\_start\_buffers.

## See Also

edt\_done\_count(), edt\_start\_buffers(), edt\_wait\_for\_buffers()

## edt\_wait\_for\_buffers

#### Description

Blocks until the specified number of buffers have completed.

#### Syntax

#include "edtinc.h"

void \*edt\_wait\_buffers(EdtDev \*edt\_p, int count);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                            |
|-------|---------------------------------------------------------------------------------------------------|
| count | How many buffers to block for. Completed buffers are numbered relatively; start each call with 1. |

## Return

Address of last completed buffer on success; NULL on error. If an error occurs, call edt\_perror() to get the system error message.

| Note | If using timeouts, call edt_timeouts after edt_wait_for_buffers returns to see if the number of timeouts has incremented. If it has incremented, call edt_get_timeout_count to get the number of bytes transferred into the buffer. DMA does not automatically continue on to the next buffer, so you need to call edt_start_buffers to move on to the next buffer in the ring. |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Note | If the ring buffer is in free-running mode and the application cannot process data as fast as it is acquired, DMA will wrap around and overwrite the referenced buffer. The application must ensure that the data in the buffer is processed or copied out in time to prevent overrun.                                                                                          |

## edt\_wait\_for\_next\_buffer

#### Description

Waits for the next buffer that finishes DMA. Depending on how often this routine is called, buffers that have already completed DMA might be skipped.

## Syntax

#include "edtinc.h"

void \*edt\_wait\_for\_next\_buffer(EdtDev \*edt\_p) ;

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

Returns a pointer to the buffer, or NULL on failure. If an error occurs, call edt\_perror() to get the system error message.

## edt\_wait\_buffers\_timed

## Description

Blocks until the specified number of buffers have completed with a pointer to the time the last buffer finished.

## Syntax

#include "edtinc.h"

void \*edt\_wait\_buffers\_timed (EdtDev \*edt\_p, int count, uint \*timep);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| count | buffer number for which to block. Completed buffers are numbered cumulatively starting with 0 when the EDT Product is opened.                                            |
| timep | pointer to an array of two unsigned integers. The first integer is seconds, the next integer is microseconds representing the system time at which the buffer completed. |

## Return

Address of last completed buffer on success; NULL on error. If an error occurs, call edt\_perror() to get the system error message.

**Note** If the ring buffer is in free-running mode and the application cannot process data as fast as it is acquired, DMA will wrap around and overwrite the referenced buffer. The application must ensure that the data in the buffer is processed or copied out in time to prevent overrun.

## edt\_next\_writebuf

## Description

Returns a pointer to the next buffer scheduled for output DMA, in order to fill the buffer with data.

#### Syntax

```
#include "edtinc.h"
```

void \*edt\_next\_writebuf(EdtDev \*edt\_p) ;

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

Returns a pointer to the buffer, or NULL on failure. If an error occurs, call edt\_perror() to get the system error message.

## edt\_set\_buffer

#### Description

Sets which buffer should be started next. Usually done to recover after a timeout, interrupt, or error.

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

#### Syntax

```
#include "edtinc.h"
void *edt_next_writebuf(EdtDev *edt_p) ;
```

## Example

u\_int curdone;

edt\_stop\_buffers(edt\_p);

curdone=edt\_done\_count(edt\_p);

edt\_set\_buffer(edt\_p, 0);

## Return

0 on success, -1 on failure.

#### See Also

edt\_stop\_buffers(), edt\_done\_count(), edt\_get\_todo()

## edt\_set\_buffer\_size

## Description

Used to change the size or direction of one of the ring buffers. Almost never used. Mixing directions requires detailed knowledge of the interface since pending preloaded DMA transfers need to be coordinated with the interface fifo direction. For example, a dma write will complete when the data is in the output fifo, but the dma read should not be started until the data is out to the external device. Most applications requiring fast mixed reads/writes have worked out more cleanly using seperate, simultaneous, read and write dma transfers using different dma channels.

## Arguments

| edt_p      | device handle returned from edt_open or edt_open_channel |
|------------|----------------------------------------------------------|
| which_buf  | index of ring buffer to change                           |
| size       | size to change it to                                     |
| write_flag | direction                                                |

## Syntax

```
int edt_set_buffer_size(EdtDev *edt_p, unsigned int which_buf,
unsigned int size, unsigned int write_flag)
```

## Example

```
u_int bufnum=3;
```

```
u_int bsize=1024;
```

u\_int dirflag=EDT\_WRITE;

int ret;

ret=edt\_set\_buffer\_size(edt\_p, bufnum, bsize, dirflag);

## Return

0 on success, -1 on failure.

## See Also

edt\_open\_channel(), redpcd8.c, rd16.c, rdssdio.c, wrssdio.c

## edt\_last\_buffer

#### Description

Waits for the last buffer that has been transferred. This is useful if the application cannot keep up with buffer transfer. If this routine is called for a second time before another buffer has been transferred, it will block waiting for the next transfer to complete.

## Arguments

| edt_p    | device struct returned from edt_open                                                  |
|----------|---------------------------------------------------------------------------------------|
| nSkipped | pointer to an integer which will be filled in with number of buffers skipped, if any. |

## Syntax

```
unsigned char *edt_last_buffer(EdtDev *edt_p, int *nSkipped)
```

## Example

int skipped\_bufs;

u\_char \*buf;

buf=edt\_last\_buffer(edt\_p, &skipped\_bufs);

#### Return

Address of the image.

## See Also

edt\_wait\_for\_buffers, edt\_last\_buffer\_timed

## edt\_last\_buffer\_timed

## Description

Like edt\_last\_buffer but also returns the time at which the dma was complete on this buffer. "timep" should point to an array of unsigned integers which will be filled in with the seconds and microseconds of the time the buffer was finished being transferred.

## Arguments

| edt_p | device struct returned from edt_open |
|-------|--------------------------------------|
| timep | pointer to an unsigned integer array |

## Syntax

unsigned char \*edt\_last\_buffer\_timed(EdtDev \*edt\_p, u\_int \*timep)

## Example

u\_int timestamp [2];

u\_char \*buf;

buf=edt\_last\_buffer\_timed(edt\_p, timestamp);

## Return

Address of the image.

## See Also

edt\_wait\_for\_buffers(), edt\_last\_buffer(), edt\_wait\_buffers\_timed

## edt\_configure\_ring\_buffers

#### Description

Configures the EDT device ring buffers. Any previous configuration is replaced, and previously allocated buffers are released. Buffers can be allocated and maintained within the EDT device library or within the user application itself.

#### Syntax

#include "edtinc.h"

#### Arguments

| guillense      |                                                                                                                                                                                                                                                                                                                    |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| edt_p          | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                                                                                                                                                                                                             |
| bufsize        | size of each buffer. For optimal efficiency, allocate a value approximating<br>throughput divided by 20: that is, if transfer occurs at 20 MB per second,<br>allocate 1 MB per buffer. Buffers significantly larger or smaller can overuse<br>memory or lock the system up in processing interrupts at this speed. |
| nbufs          | number of buffers. Must be 1 or greater. Four is recommended for most applications.                                                                                                                                                                                                                                |
| data_direction | Indicates whether this connection is to be used for input or output. Only one direction is possible per device or subdevice at any given time:                                                                                                                                                                     |
|                | $EDT_READ = 0$                                                                                                                                                                                                                                                                                                     |
|                | $EDT_WRITE = 1$                                                                                                                                                                                                                                                                                                    |
| bufarray       | If NULL, the library will allocate a set of page-aligned ring buffers. If not<br>NULL, this argument is an array of pointers to application-allocated buffers;<br>these buffers must match the size and number of buffers specified in this call<br>and will be used as the ring buffers.                          |

#### Return

0 on success; -1 on error. If all buffers cannot be allocated, none are allocated and an error is returned. Call edt\_perror() to get the system error message.

## edt\_buffer\_addresses

#### Description

Returns an array containing the addresses of the ring buffers.

#### Syntax

#include "edtinc.h"

```
void **edt_buffer_addresses(EdtDev *edt_p);
```

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

#### Return

An array of pointers to the ring buffers allocated by the driver or the library. The array is indexed from zero to n-1 where n is the number of ring buffers set in edt\_configure\_ring\_buffers().

## edt\_disable\_ring\_buffers

#### Description

Disables the EDT device ring buffers. Pending DMA is cancelled and all buffers are released.

#### Syntax

#include "edtinc.h"

int edt\_disable\_ring\_buffers(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_ring\_buffer\_overrun

## Description

Returns true (1) when DMA has wrapped around the ring buffer and overwritten the buffer which the application is about to access. Returns false (0) otherwise.

#### Syntax

#include "edtinc.h"

int edt\_ring\_buffer\_overrun(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

1 (true) when overrun has occurred, corrupting the current buffer, 0 (false) otherwise.

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_reset\_ring\_buffers

## Description

Stops any DMA currently in progress, then resets the ring buffer to start the next DMA at bufnum.

## Syntax

```
#include "edtinc.h"
int edt_reset_ring_buffers(EdtDev *edt_p, int bufnum) ;
```

## Arguments

| edt_p  | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> .                                                                                                                             |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bufnum | The index of the ring buffer at which to start the next DMA. A number larger<br>than the number of buffers set up sets the current done count to the number<br>suppliedmodulo the number of buffers. |

## Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_configure\_block\_buffers

#### Description

Similar to edt\_configure\_ring\_buffers, except that it allocates the ring buffers as a single large block, setting the ring buffer addresses from within that block. This allows reading or writing buffers from/to a file in single chunks larger than the buffer size, which is sometimes considerable more efficient. Buffer sizes are rounded up by PAGE\_SIZE so that DMA occurs on a page boundary.

#### Syntax

int edt\_configure\_block\_buffers(EdtDev 8edt\_p, int bufsize, int numbufs, int write\_flag, int header\_size, int header\_before)

#### Arguments

| device struct returned from edt_open                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| size of the individual buffers                                                                                                                                                                       |
| number of buffers to create                                                                                                                                                                          |
| 1, if these buffers are set up to go out; 0 otherwise                                                                                                                                                |
| if non-zero, additional memory (header_size bytes) will be allocated for each<br>buffer for Header data. The loocation of this header space is determined by<br>the argument header_before.          |
| if non-zero, the header space defined by header_size is placed before the DMA buffer; otherwise, it comes after the DMA buffer. The value returned by edt_wait_for_buffers is always the DMA buffer. |
|                                                                                                                                                                                                      |

#### Return

0 on success, -1 on failure.

#### See Also

edt\_configure\_ring\_buffers

## edt\_startdma\_action

#### Description

Specifies when to perform the action at the start of a dma transfer as specified by edt\_startdma\_reg(). A common use of this is to write to a register which signals an external device that dma has started, to trigger the device to start sending. The default is no dma action. The PDV library uses this function to send a trigger to a camera a the start of dma. This function allows the register write to occur in a critical section with the start of dma and at the same time.

## Syntax

```
void edt_startdma_action(EdtDev *edt_p, uint_t val);
```

## Arguments

| edt_p | device struct returned from edt_open                  |
|-------|-------------------------------------------------------|
| val   | One of EDT_ACT_NEVER, EDT_ACT_ONCE, or EDT_ACT_ALWAYS |

## Example

edt\_startdma\_action(edt\_p, EDT\_ACT\_ALWAYS);

edt\_startdma\_reg(edt\_p, PDV\_CMD, PDV\_ENABLE\_GRAB);

## Return

void

## See Also

edt\_startdma\_reg(), edt\_reg\_write(), edt\_reg\_read()

## edt\_enddma\_action

## Description

Specifies when to perform the action at the end of a dma transfer as specified by edt\_enddma\_reg(). A common use of this is to write to a register which signals an external device that dma is complete, or to change the state of a signal which will be changed at the start of dma, so the external device can look for an edge. The default is no end of dma action. Most applications can set the output signal, if needed, from the application with edt\_reg\_write(). This routine is only needed if the action must happen within microseconds of the end of dma.

## Syntax

```
void edt_enddma_action(EdtDev *edt_p, uint_t val);
```

## Arguments

| edt_p | device struct returned from edt_open                  |
|-------|-------------------------------------------------------|
| val   | One of EDT_ACT_NEVER, EDT_ACT_ONCE, or EDT_ACT_ALWAYS |

## Example

u\_int fnct\_value=0x1; edt\_enddma\_action(edt\_p, EDT\_ACT\_ALWAYS); edt\_enddma\_reg(edt\_p, PCD\_FUNCT, fnct\_value);

#### Return

void

## See Also

edt\_startdma\_action(), edt\_startdma\_reg(), edt\_reg\_write(), edt\_reg\_read()

## edt\_startdma\_reg

## Description

Sets the register and value to use at the start of dma, as set by edt\_startdma\_action().

## Syntax

```
void edt_startdma_reg(EdtDev *edt_p, uint_t desc, uint_t val);
```

## Arguments

| edt_p | device struct returned from edt_open                         |  |
|-------|--------------------------------------------------------------|--|
| desc  | register description of which register to use as in edtreg.h |  |
| val   | value to write                                               |  |

## Example

edt\_startdma\_action(edt\_p, EDT\_ACT\_ALWAYS);

edt\_startdma\_reg(edt\_p, PDV\_CMD, PDV\_ENABLE\_GRAB);

## Return

void

## See Also

edt\_startdma\_action()

## edt\_abort\_dma

## Description

Stops any transfers currently in progress, resets the ring buffer pointers to restart on the current buffer.

## Syntax

```
#include "edtinc.h"
```

int edt\_abort\_dma(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

## Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_abort\_current\_dma

## Description

Stops the current transfers, resets the ring buffer pointers to the next buffer.



## Syntax

#include "edtinc.h"

int edt\_abort\_current\_dma(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel*.

#### Return

0 on success, -1 on failure

## edt\_get\_bytecount

#### Description

Returns the number of bytes transferred since the last call of edt\_open, accurate to the burst size, if burst is enabled.

#### Syntax

#include "edtinc.h"

int edt\_get\_bytecount(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

#### Return

The number of bytes transferred, as described above.

## edt\_timeouts

#### Description

Returns the number of read and write timeouts that have occurred since the last call of edt\_open.

#### Syntax

```
#include "edtinc.h"
```

int edt\_timeouts(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

The number of read and write timeouts that have occurred since the last call of edt\_open.

## edt\_get\_timeout\_count

## Description

Returns the number of bytes transferred at last timeout.

#### Syntax

#include "edtinc.h"



int edt\_get\_timeout\_count(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

#### Return

The number of bytes transferred at last timeout.

## edt\_set\_timeout\_action

#### Description

Sets the driver behavior on a timeout.

#### Syntax

#include "edtinc.h"

void edt\_set\_timeout\_action(EdtDev \*edt\_p, int action);

#### Arguments

| edt_p  | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> |                                                       |
|--------|------------------------------------------------------------------------|-------------------------------------------------------|
| action | integer configures the any action taken on a timeout. Definitions:     |                                                       |
|        | EDT_TIMEOUT_NULL                                                       | no extra action taken                                 |
|        | EDT_TIMEOUT_BIT_STROBE                                                 | flush any valid bits left in input circuits of SSDIO. |

#### Return

No return value.

## edt\_get\_timeout\_goodbits

#### Description

Returns the number of good bits in the last long word of a read buffer after the last timeout. This routine is called after a timeout, if the timeout action is set to EDT\_TIMEOUT\_BIT\_STROBE. (See edt\_set\_timeout\_action on page 30.)

#### Syntax

#include "edtinc.h"

int edt\_get\_timeout\_goodbits(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

Number 0–31 represents the number of good bits in the last 32-bit word of the read buffer associated with the last timeout.

## edt\_do\_timeout

#### Description

Causes the driver to perform the same actions as it would on a timeout (causing partially filled fifos to be flushed and dma to be aborted). Used when the application has knowledge that no more data will be sent/accepted. Used when a common timeout cannot be known, such as when acquiring data from a telescope ccd array where the amount of data sent depends on unknown future celestial events. Also used by the library when the operating system can not otherwise wait for an interrupt and timeout at the same time.

## Syntax

int edt\_do\_timeout(EdtDev \*edt\_p)

#### Arguments

*edt\_p* device struct returned from edt\_open

## Example

edt\_do\_timeout(edt\_p);

#### Return

0 on success, -1 on failure

#### See Also

ring buffer discussion

## edt\_get\_rtimeout

## Description

Gets the current read timeout value: the number of milliseconds to wait for DMA reads to complete before returning.

## Syntax

#include "edtinc.h"

int edt\_get\_rtimeout(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

The number of milliseconds in the current read timeout period.

## edt\_set\_rtimeout

## Description

Sets the number of milliseconds for data read calls, such as edt\_read(), to wait for DMA to complete before returning. A value of 0 causes the I/O operation to wait forever—that is, to block on a read. Edt\_set\_rtimeout affects edt\_wait\_for\_buffers (see page XX) and edt\_read (see page XX).

## Syntax

#include "edtinc.h"

int edt\_set\_rtimeout(EdtDev \*edt\_p, int value);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> |
|-------|------------------------------------------------------------------------|
| value | The number of milliseconds in the timeout period.                      |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_get\_wtimeout

#### Description

Gets the current write timeout value: the number of milliseconds to wait for DMA writes to complete before returning.

#### Syntax

#include "edtinc.h"

int edt\_get\_wtimeout(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

#### Return

The number of milliseconds in the current write timeout period.

## edt\_set\_wtimeout

#### Description

Sets the number of milliseconds for data write calls, such as edt\_write(), to wait for DMA to complete before returning. A value of 0 causes the I/O operation to wait forever—that is, to block on a write. Edt\_set\_wtimeout affects edt\_wait\_for\_buffers (see page XX) and edt\_write (see page XX).

#### Syntax

#include "edtinc.h"
int edt\_set\_wtimeout(EdtDev \*edt\_p, int value);

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> |
|-------|------------------------------------------------------------------------|
| value | The number of milliseconds in the timeout period.                      |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_get\_timestamp

#### Description

Gets the seconds and microseconds timestamp of when dma was completed on the buffer specified by bufnum. "bufnum" is moded by the number of buffers in the ring buffer, so it can either be an index, or the number of buffers completed.

## Syntax

```
int edt_get_timestamp(EdtDev *edt_p, u_int *timep, u_int bufnum)
```

#### Arguments

| edt_p  | device struct returned from edt_open         |  |
|--------|----------------------------------------------|--|
| timep  | pointer to an unsigned integer array         |  |
| bufnum | buffer index, or number of buffers completed |  |

## Example

int timestamp[2];

u\_int bufnum=edt\_done\_count(edt\_p);

edt\_get\_timestamp(edt\_p, timestamp, bufnum);

## Return

0 on success, -1 on failure. Fills in timestamp pointed to by timep.

## See Also

edt\_timestamp(), edt\_done\_count(), edt\_wait\_buffers\_timed

## edt\_get\_reftime

## Description

Gets the seconds and microseconds timestamp in the same format as the buffer\_timed functions. Used for debugging and coordinating dma completion time with other events.

## Syntax

```
int edt_get_reftime(EdtDev *edt_p, u_int *timep)
```

## Arguments

| edt_p  | device struct returned from edt_open         |  |
|--------|----------------------------------------------|--|
| timep  | pointer to an unsigned integer array         |  |
| bufnum | buffer index, or number of buffers completed |  |

## Example

int timestamp[2];

edt\_get\_regtime(edt\_p, timestamp);

## Return

0 on success, -1 on failure. Fills in timestamp pointed to by timep.

## See Also

edt\_timestamp(), edt\_done\_count(), edt\_wait\_buffers\_timed

## edt\_ref\_tmstamp

#### Description

Used for debugging and viewing a history with setdebug -g with an application-defined event in the same timeline as driver events.

#### Syntax

int edt\_ref\_tmstamp(EdtDev \*edt\_p, u\_int val)

#### Arguments

| edt_p | device struct returned from edt_open             |
|-------|--------------------------------------------------|
| val   | an arbitrary value meaningful to the application |

#### Example

#define BEFORE\_WAIT 0x11212aaaa
#define AFTER\_WAIT 0x3344bbbb
u\_char \*buf;
edt\_ref\_tmstamp(edt\_p, BEFORE\_WAIT);
buf=edt\_wait\_for\_buffer(edt\_p);
edt\_reg\_tmstamp(edt\_p, AFTER\_WAIT);
/\* now look at output of setdebug -g \*/

#### Return

0 on success, -1 on failure.

#### See Also

documentation on setdebug

## edt\_get\_burst\_enable

#### Description

Returns the value of the burst enable flag, determining whether the DMA master transfers as many words as possible at once, or transfers them one at a time as soon as the data is acquired. Burst transfers are enabled by default to optimize use of the bus. For more information, see edt\_set\_burst\_enable on page 35.

#### Syntax

#include "edtinc.h"

int edt\_get\_burst\_enable(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

A value of 1 if burst transfers are enabled; 0 otherwise.

## edt\_set\_burst\_enable

#### Description

Sets the burst enable flag, determining whether the DMA master transfers as many words as possible at once, or transfers them one at a time as soon as the data is acquired. Burst transfers are enabled by default to optimize use of the bus; however, you may wish to disable them if data latency is an issue, or for diagnosing DMA problems.

#### Syntax

#include "edtinc.h"
void edt\_set\_burst\_enable(EdtDev \*edt\_p, int onoff);

## Arguments

| edt_p | device handle returned from edt_open or edt_open_channel      |
|-------|---------------------------------------------------------------|
| onoff | A value of 1 turns the flag on (the default); 0 turns it off. |

#### Return

No return value.

## edt\_get\_firstflush

#### Description

Returns the value set by edt\_set\_firstflush(). This is an obsolete function that was only used as a kludge to detect EDT\_ACT\_KBS (also obsolete).

#### Syntax

int edt\_get\_firstflush(EdtDev \*edt\_p)

## Arguments

*edt\_p device struct returned from edt\_open.* 

## Example

int application\_should\_already\_know\_this;

application\_should\_already\_know\_this=edt\_get\_firstflush(edt\_p);

#### Return

Yes

## See Also

edt\_set\_firstflush

## edt\_set\_firstflush

#### Description

Tells whether and when to flush the FIFOs before DMA transfer. By default, the FIFOs are not flushed. However, certain applications may require flushing before a given DMA transfer, or before each transfer.

## Syntax

```
#include "edtinc.h"
```

int \*edt\_set\_firstflush(EdtDev \*edt\_p, int flag) ;

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> . |                                                 |
|-------|--------------------------------------------------------------------------|-------------------------------------------------|
| flag  | Tells whether and when to flush the FIFOs. Valid values are:             |                                                 |
|       | EDT_ACT_NEVER                                                            | don't flush before DMA transfer (default)       |
|       | EDT_ACT_ONCE                                                             | flush before the start of the next DMA transfer |
|       | EDT ACT ALWAYS                                                           | flush before the start of every DMA transfer    |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

## edt\_flush\_fifo

#### Description

Flushes the board's input and output FIFOs, to allow new data transfers to start from a known state.

#### Syntax

#include "edtinc.h"
void edt\_flush\_fifo(EdtDev \*edt\_p);

#### Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

## Return

No return value.

## edt\_get\_goodbits

#### Description

Returns the current number of good bits in the last long word of a read buffer (0 through 31).

## Syntax

```
#include "edtinc.h"
```

int edt\_get\_goodbits(EdtDev \*edt\_p);

## Arguments

*edt\_p* device handle returned from *edt\_open* or *edt\_open\_channel* 

EDT

#### Return

Number 0–31 represents the number of good bits in the 32-bit word of the current read buffer.

#### edt\_set\_event\_func

#### Description

Defines a function to call when an event occurs. Use this routine to send an application-specific function when required; for example, when DMA completes, allowing the application to continue executing until the event of interest occurs.

If you wish to receive notification of one event only, and then disable further event notification, send a final argument of 0 (see the continue parameter described below). This disables event notification at the time of the callback to your function.

#### **Syntax**

```
#include "edtinc.h"
int edt_set_event_func(EdtDev *edt_p, int event, void (*func)(void
*),
                                 void *data, int continue);
```

#### Arguments

edt\_p device handle returned from *edt\_open* or *edt\_open\_channel*.

event The event that causes the function to be called. Valid events are:

| Event                            | Description                                                                                                   | Board                          |
|----------------------------------|---------------------------------------------------------------------------------------------------------------|--------------------------------|
| EDT_PDV_EVENT_ACQUIRE            | Image has been acquired;<br>shutter has closed; subject can<br>be moved if necessary; DMA<br>will now restart | PCI DV,<br>PCI DVK,<br>PCI FOI |
| EDT_PDV_EVENT_FVAL               | Frame Valid line is set                                                                                       | PCI DV,<br>PCI DVK             |
| EDT_EVENT_P16D_DINT              | Device interrupt occurred                                                                                     | PCI 16D                        |
| EDT_EVENT_P11W_ATTN              | Attention interrupt occurred                                                                                  | PCI 11W                        |
| EDT_EVENT_P11W_CNT               | Count interrupt occurred                                                                                      | PCI 11W                        |
| EDT_EVENT_PCD_STAT1              | Interrupt occurred on Status 1<br>line                                                                        | PCI CD                         |
| EDT_EVENT_PCD_STAT2              | Interrupt occurred on Status 2 line                                                                           | PCI CD                         |
| EDT_EVENT_PCD_STAT3              | Interrupt occurred on Status 3 line                                                                           | PCI CD                         |
| EDT_EVENT_PCD_STAT4              | Interrupt occurred on Status 4 line                                                                           | PCI CD                         |
| EDT_EVENT_ENDDMA                 | DMA has completed                                                                                             | ALL                            |
| The function you've defined to c | call when the event occurs.                                                                                   |                                |

func

| data     | Pointer to data block (if any) to send to the function as an argument; usually edt_p.                                                   |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------|
| continue | Flag to enable or disable continued event notification. A value of 0 causes an implied edt_remove_event_func as the event is triggered. |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

#### edt\_remove\_event\_func

#### Description

Removes an event function previously set with edt\_set\_event\_func.

*Note* This routine is implemented on PCI Bus platforms only.

#### Syntax

#include "edtinc.h"

```
int edt_remove_event_func(EdtDev *edt_p, int event);
```

#### Arguments

| edt_p | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i> .                                      |
|-------|---------------------------------------------------------------------------------------------------------------|
| event | The event that causes the function to be called. Valid events are as listed in edt_set_event_func on page 37. |

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

#### edt\_reg\_read

#### Description

Reads the specified register and returns its value. Use this routine instead of using ioctls.

#### Syntax

```
#include "edtinc.h"
```

uint edt\_reg\_read(EdtDev \*edt\_p, uint address);

#### Arguments

| edt_p   | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                    |
|---------|---------------------------------------------------------------------------------------------------------------------------|
| address | The name of the register to read. Use the names provided in the register descriptions in the section entitled "Hardware." |

#### Return

The value of the register.

#### edt\_reg\_write

*Note* Use this routine with care; it writes directly to the hardware. An incorrect value can crash

your system, possibly causing loss of data.

#### Description

Write the specified value to the specified register. Use this routine instead of using ioctls.

#### Syntax

#include "edtinc.h"

void edt\_reg\_write(EdtDev \*edt\_p, uint address, uint value);

#### Arguments

| edt_p   | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                     |
|---------|----------------------------------------------------------------------------------------------------------------------------|
| address | The name of the register to write. Use the names provided in the register descriptions in the section entitled "Hardware." |
| value   | The desired value to write in the register.                                                                                |

#### Return

No return value.

#### edt\_reg\_and

*Note* Use this routine with care; it writes directly to the hardware. An incorrect value can crash your system, possibly causing loss of data.

#### Description

Performs a bitwise logical AND of the value of the specified register and the value provided in the argument; the result becomes the new value of the register. Use this routine instead of using ioctls.

#### Syntax

#include "edtinc.h"

uint edt\_reg\_and(EdtDev \*edt\_p, uint address, uint mask);

#### Arguments

| edt_p   | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                      |
|---------|-----------------------------------------------------------------------------------------------------------------------------|
| address | The name of the register to modify. Use the names provided in the register descriptions in the section entitled "Hardware." |
| mask    | The value to AND with the register.                                                                                         |

#### Return

The new value of the register.

#### edt\_reg\_or

*Note* Use this routine with care; it writes directly to the hardware. An incorrect value can crash your system, possibly causing loss of data.

#### Description

Performs a bitwise logical OR of the value of the specified register and the value provided in the argument; the result becomes the new value of the register. Use this routine instead of using ioctls.

#### Syntax

#include "edtinc.h"

uint edt\_reg\_or(EdtDev \*edt\_p, uint address, uint mask);

#### Arguments

| edt_p   | device handle returned from <i>edt_open</i> or <i>edt_open_channel</i>                                                      |
|---------|-----------------------------------------------------------------------------------------------------------------------------|
| address | The name of the register to modify. Use the names provided in the register descriptions in the section entitled "Hardware." |
| mask    | The value to OR with the register.                                                                                          |

#### Return

The new value of the register.

#### edt\_get\_foicount

#### Description

Returns the number of RCI modules connected to the EDT FOI (fiber optic interface) board.

#### Syntax

int edt\_get\_foicount(EdtDev \*edt\_p)

#### Arguments

*edt\_p* device struct returned from edt\_open

#### Example

```
int num-rcis;
```

num\_rcia=edt\_get\_foicount(edt\_p);

#### Return

Integer

#### See Also

edt\_set\_foiunit(), edt\_get\_foiunit(), edt\_set\_foicount()

#### edt\_set\_foicount

#### Description

Sets which RCI unit to address with subsequent serial and register read/write functions. Used with the PDV FOI.

#### Syntax

```
int edt_set_foicount(EdtDev *edt_p, int unit)
```

#### Arguments

| edt_p | device struct returned from edt_open |
|-------|--------------------------------------|
| unit  | unit number of RCI unit              |

#### Example

```
int nextunit;
nextunit=3;
edt_set_foiunit(edt_p, nextunit);
```

#### Return

0 on success, -1 on failure

#### See Also

pdv\_serial\_write(), edt\_reg\_write(), edt\_reg\_read(), pdv\_serial\_read()

#### edt\_intfc\_write

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_write masks off the offset.

#### Syntax

```
void edt_intfc_write(EdtDev *edt_p, uint_t offset, uchar_t val)
```

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

u\_char fnct1=1;

edt\_intfc\_write(edt\_p, PCD\_FUNCT, fnct1);

#### Return

void

#### See Also

edt\_intfc\_read(), edt\_reg\_write(), edt\_intfc\_write\_short()

#### edt\_intfc\_read

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_read masks off the offset.

#### Syntax

| u_char |  |
|--------|--|
|--------|--|

edt\_intfc\_read(EdtDev \*edt\_p, uint\_t offset)

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

u\_char rfnct=edt\_intfc\_read(edt\_p, PCD\_FUNCT);

#### Return

void

#### See Also

edt\_intfc\_write(), edt\_reg\_read(), edt\_intfc\_read\_short()

#### edt\_intfc\_write\_short

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_write\_short masks off the offset.

#### Syntax

void edt\_intfc\_write\_short(EdtDev \*edt\_p, uint\_t offset, u\_short val)

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

u\_short width=1024;

edt\_intfc\_write\_short(edt\_p, CAM\_WIDTH, width);

#### Return

void

#### See Also

edt\_intfc\_write(), edt\_reg\_write()

#### edt\_intfc\_read\_short

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_read\_short masks off the offset.

#### Syntax

u\_short

edt\_intfc\_read\_short(EdtDev \*edt\_p, unit\_t offset)

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

u\_short r\_camw=edt\_intfc\_read\_short(edt\_p, CAM\_WIDTH);

#### Return

void

#### See Also

edt\_intfc\_read(), edt\_reg\_read()

#### edt\_intfc\_write\_32

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_write\_32 masks off the offset.

#### Syntax

```
void edt_intfc_write_32(EdtDev *edt_p, uint_t offset, unit_t val)
```

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

```
u_int value=0x12345678;
```

edt\_intfc\_write\_32(edt\_p, MAGIC\_OFF1, value);

#### Return

void

#### See Also

edt\_intfc\_read\_32(), edt\_reg\_write()

#### edt\_intfc\_read\_32

#### Description

A convenience routine, partly for backward compatability, to access the XILINX interface registers. The register descriptors used be edt\_reg\_write() can also be used, since edt\_intfc\_read\_32 masks off the offset.

#### Syntax

uint\_t
edt\_intfc\_read\_32(EdtDev \*edt\_p, uint\_t offset)

#### Arguments

| edt_p  | device struct returned from edt_open                         |
|--------|--------------------------------------------------------------|
| offset | integer offset into XILINX interface, or register descriptor |
| val    | unsigned character value to set                              |

#### Example

u\_int r\_actkbs=edt\_intfc\_read\_32(edt\_p, EDT\_ACT\_KBS);

#### Return

void

#### edt\_msleep

#### Description

Causes the process to sleep for the specified number of microseconds.

#### Syntax

#include "edtinc.h"
int edt\_microsleep(u\_int usecs) ;

#### Arguments

*usecs* The number of microseconds for the process to sleep.

#### Return

0 on success; -1 on error. If an error occurs, call edt\_perror() to get the system error message.

#### edt\_alloc

#### Description

Convenience routine to allocate memory in a system-independent way. The buffer returned is page aligned. Uses VirtualAlloc on Windows systems, *valloc* on UNIX-based systems.

#### Syntax

#include "edtinc.h"

int
edt\_alloc(int nbytes)

#### Arguments

*nbytes* number of bytes of memory to allocate.

#### Example

unsigned char \*buf = edt\_alloc(1024);

#### Returns

The address of the allocated memory, or NULL on error. If NULL, use edt\_perror on page 45 to print the error.

#### edt\_free

#### Description

Convenience routine to free the memory allocated with pdv\_alloc (above).

#### Syntax

#include "edtinc.h"

int
edt\_free(unsigned char \*buf)

#### Arguments

Address of memory buffer to free.

#### Example

buf

edt\_free(buf);

#### Returns

0 if successful, -1 if unsuccessful.

#### edt\_perror

#### Description

Formats and prints a system error.

#### Syntax

```
#include "edtinc.h"
void
```

```
edt_perror(char *errstr)
```

#### Arguments

Error string to include in the printed error output.

#### Return

errstr

No return value. See edt\_errno below for an example.

#### edt\_errno

#### Description

Returns an operating system-dependent error number.

#### Syntax

```
#include "edtinc.h"
int
edt_errno(void)
```

#### Arguments

None.

#### Return

32-bit integer representing the operating system-dependent error number generated by an error.

#### Example

```
if ((edt_p = edt_open("p11w",0)) == NULL
{
    int error_num;
    edt_perror("edt_open");
    error_num = edt_errno(edt_p);
}
```

#### edt\_access

#### Description

Determines file access, independent of operating system. This a convenience routine that maps to access() on Unix/Linus systems and \_access() on Windows systems.

#### Syntax

int edt\_access(char \*fname, int perm)

#### Arguments

|       | edt_p | device struct returned from edt_open                                                               |
|-------|-------|----------------------------------------------------------------------------------------------------|
| fname |       | path name of the file to check access permissions                                                  |
| perm  |       | permission flag(s) to test for. See access() (Unix/Linux) or _access() (Windows) for valid values. |

#### Example

if(edt\_access("file.ras", F\_OK))

printf("Warning: overwriting file %s\n");

#### Return

0 on success, -1 on failure

#### edt\_get\_bitpath

#### Description

Obtains pathname to the currently loaded interface bitfile from the driver. The program "bitload" sets this string in the driver when an interface bitfile is successfully loaded.

#### Syntax

#include "edtinc.h"

```
int edt_get_bitpath(EdtDev *edt_p, char *bitpath, int size);
```

#### Arguments

| edt_p   | device handle returned from edt_open or edt_open_channel |
|---------|----------------------------------------------------------|
| bitpath | address of a character buffer of at least 128 bytes      |
| size    | number of bytes in the above character buffer            |

#### Return

0 on success, -1 on failure

## **EDT Message Handler Library**

The edt error library provides generalized error and message handling for the edt and pdv libraries. The primary purpose of the routines is to provide a method for application programs to intercept and handle edtlib and pdvlib error, warning debug messages, but can also be used for application messages.

By default, output goes to the console (stdout), but user defined functions can be substituted. For example, a function that pops up a window and displays the text in that window. Different message levels can be set for different output, and multiple message handles can even exist within an application, with different message handlers associated with them.

## **Message Definitions**

#### User application messages

```
EDTAPP_MSG_FATAL
EDTAPP_MSG_WARNING
EDTAPP_MSG_INFO_1
EDTAPP_MSG_INFO_2
```

#### Edtlib messages

EDTLIB\_MSG\_FATAL EDTLIB\_MSG\_WARNING EDTLIB\_MSG\_INFO\_1 EDTLIB\_MSG\_INFO\_2

#### Pdvlib messages

PDVLIB\_MSG\_FATAL PDVLIB\_MSG\_WARNING PDVLIB\_MSG\_INFO\_1 PDVLIB\_MSG\_INFO\_2

#### Library and application messages

EDT\_MSG\_FATAL (defined as EDTAPP\_MSG\_FATAL | EDTLIB\_MSG\_FATAL | PDVLIB\_MSG\_FATAL)

EDT\_MSG\_WARNING (defined as EDTAPP\_MSG\_WARNING | EDTLIB\_MSG\_WARNING | PDVLIB\_MSG\_WARNING)

EDT\_MSG\_INFO\_1 (defined as EDTAPP\_MSG\_INFO\_1 | EDTLIB\_MSG\_INFO\_2 | PDVLIB\_MSG\_INFO\_2)

EDT\_MSG\_INFO\_2 (defined as EDTAPP\_MSG\_INFO\_2 | EDTLIB\_MSG\_INFO\_2 | PDVLIB\_MSG\_INFO\_2)

Message levels are defined by flag bits, and each bit can be set or cleared individually. So for example if you want a message handler to be called for fatal and warning application messages only, you would specify EDTAPP\_MSG\_FATAL | EDTAPP\_MSG\_WARNING.

As you can see, the edt and pci dv libraries have their own message flags. These can be turned on and off from within an application, and also by setting the environment variables EDTDEBUG and PDVDEBUG, respectively, to values greater than zero.

Application programs would normally specify combinations of either the EDTAPP\_MSG\_ or EDT\_MSG flags for their messages.

### **Files**

edt\_error.h: header file (automatically included if edtinc.h is included)

edt\_error.c: message subroutines

The EdtMsgHandler structure is defined in edt\_error.h. Application programmers should not access structure elements directly; instead always go through the error subroutines.

#### edt\_msg\_init

#### Description

Initializes a message handle to defaults. The message file is initialized to stderr. The output subroutine pointer is set to fprintf (console output). The message level is set to EDT\_MSG\_WARNING | EDT\_MSG\_FATAL.

#### Syntax

void edt\_msg\_init(EdtMsgHandler \*msg\_p)

#### Arguments

*msg\_p* pointer to message handler structure to initialize

#### Return

Void

#### Example

EdtMsgHandler msg\_p;

edt\_msg\_init(&msg\_p);

#### See Also

edt\_msg\_output

#### edt\_msg

#### Description

Submits a message to the default message handler, which will conditionally (based on the flag bits) send the message as an argument to the default message handler function. Uses the default message handle, and is equivalent to calling edt\_msg\_output(edt\_msg\_default\_handle(), ...). To submit a message for handling from other than the default message handle, use edt\_msg\_output.

#### Syntax

int edt\_msg(int level, char \*format, ...)

#### Arguments

| level  | an integer variable that contains flag bits indicating what 'level' message it is. Flag bits are described in the overview.                         |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| format | a string and arguments describing the format. Uses vsprintf to print<br>formatted text to a string, and sends the result to the handler subroutine. |
|        | Refer to the printf manual page for formatting flags and options.                                                                                   |

#### Return

Void

#### Example

```
edt_msg(EDTAPP_MSG_WARNING, "file '%s' not found", fname);
```

#### edt\_msg\_output

#### Description

Submits a message using the msg\_p message handle, which will conditionally (based on the flag bits) send the message as an argument to the handle's message handler function. To submit a message for handling by the default message handle, edt\_msg.

#### Syntax

```
int edt_msg_output(EdtMsgHandler *msg_p, int level, char *format,
...)
```

#### Arguments

| msg_p  | pointer to message handler, initiailzed by edt_msg_init                                                                                                                                                                  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| level  | an integer variable that contains flag bits indicating what 'level' message it is. Flag bits are described in the overview.                                                                                              |
| format | a string and arguments describing the format. Uses vsprintf to print<br>formatted text to a string, and sends the result to the handler subroutine.<br>Refer to the printf manual page for formatting flags and options. |

#### Return

Void

#### Example

EdtMsgHandler msg\_p;

```
edt_msg_init(&msg_p);
```

```
edt_msg_set_function(msg_p, (EdtMsgFunction *)my_error_popup);
```

```
edt_msg_set_level(msg_p, EDT_MSG_FATAL | EDT_MSG_WARNING);
```

```
if (edt_access(fname, 0) != 0)
```

```
edt_msg_output(msg_p, EDTAPP_MSG_WARNING, "file '%s' not
found", fname);
```

### edt\_msg\_close

#### Description

Closes and frees up memory associated with a message handle. Use only on message handles that have been explicitly initialized by edt\_msg\_init. Do not try to close the default message handle.

#### Syntax

int edt\_msg\_close(EdtMsgHandler \*msg\_p)

#### Arguments

*msg\_p* the message handle to close

#### Return

0 on success, -1 on failure

#### edt\_msg\_set\_level

#### Description

Sets the "message level" flag bits that determine whether to call the message handler for a given message. The flags set by this function are ANDed with the flags set in each edt\_msg call, to determine whether the call goes to the message function and actually results in any output.

#### Syntax

```
void edt_msg_set_level(EdtMsgHandler *msg_p, int newlevel)
```

#### Arguments

*msg\_p* the message handle

#### Example

```
edt_msg_set_level(edt_msg_default_level(),
EDT_MSG_FATAL|EDT_MSG_WARNING);
```

#### Return

Void

#### edt\_msg\_set\_function

#### Description

Sets the function to call when a message event occurs. The default message function is printf (outputs to the console); edt\_msg\_set\_function allows programmers to substitute any type of message handler (pop-up callback, file write, etc).

#### Syntax

```
void edt_msg_set_function(EdtErrorFunction f)
```

#### Arguments

*msg\_p* the message handle

#### Example

See edt\_msg

**Return** Void

See Also edt\_msg, edt\_msg\_set\_level

### edt\_msg\_set\_msg\_file

#### Description

Sets the output file pointer for the message handler. Expects a file handle for a file that is already open.

#### Syntax

```
void edt_msg_set_msg_file(EdtMsgHandler *msg_p, FILE *fp)
```

#### Arguments

| msg_p | the message handle                                                                    |
|-------|---------------------------------------------------------------------------------------|
| р     | pointer to a file handle that is already open, to which the messages should be output |

#### Example

```
EdtMsgHandler msg_p;
FILE *fp = fopen("messages.out", "w");
edt_msg_init(&msg_p);
edt_msg_set_file(&msg_p, fp);
```

#### Return

Void

#### edt\_msg\_perror

#### Description

Conditionally outputs a system perror using the default message pointer.

#### Syntax

int edt\_msg\_perror(int level, char \*msg)

#### Arguments

| level | message level, described in the overview   |
|-------|--------------------------------------------|
| msg   | message to concatenate to the system error |

#### Example

if ((fp = fopen ("file.txt", "r")) == NULL)

```
edt_sysperror(EDT_FATAL, "file.txt");
```

#### Return

0 on success, -1 on failure

#### See Also

edt\_perror

The following routines are specific to the PCI 11W:

| Routine          | Description                                   |
|------------------|-----------------------------------------------|
| p11w_set_command | Sets the value of the Command register.       |
| p11w_get_command | Gets the value of the Command register.       |
| p11w_set_config  | Sets the value of the Configuration register. |
| p11w_get_config  | Gets the value in the Configuration register. |
| p11w_set_data    | Sets the value of the Data register.          |
| p11w_get_data    | Gets the value of the Data register.          |
| p11w_get_stat    | Gets the value of the Status register.        |
| p11w_get_count   | Gets the value of the Word Count register.    |

#### p11w\_set\_command

#### Description

Sets the value of the Command register.

#### Syntax

```
#include "edtinc.h"
```

void p11w\_set\_command(EdtDev \*edt\_p, u\_short val);

#### Arguments

| edt_p | device handle returned from edt_open                |
|-------|-----------------------------------------------------|
| val   | value to which you wish to set the Command register |

#### Example

u\_short val;

```
val = p11w_get_command(edt_p);
val |=P11W_INIT;
p11w_set_command(edt_p, val);
```

#### Return

None

#### p11w\_get\_command

#### Description

Gets the value of the Command register.

#### Syntax

#include "edtinc.h"

u\_short p11w\_get\_command(EdtDev \*edt\_p);

#### Arguments

edt\_p device handle returned from edt\_open

#### Return

Unsigned short containing the value currently in the Command register.

### p11w\_set\_config

#### Description

Sets the value of the Configuration register.

#### Syntax

#include "edtinc.h"

void p11w\_set\_config(EdtDev \*edt\_p, u\_short val);

#### Arguments

| edt_p | device handle returned from edt_open                |
|-------|-----------------------------------------------------|
| val   | value to which you wish to set the Command register |

#### Example

```
u_short val;
val = p11w_get_config(edt_p);
val |=P11W_SWAP;
p11w_set_config(edt_p, val);
```

#### Return

None

#### p11w\_get\_config

#### Description

Gets the value of the Configuration register.

#### Syntax

#include "edtinc.h"

u\_short p11w\_get\_config(EdtDev \*edt\_p);

#### Arguments

edt\_p device handle returned from edt\_open

#### Return

Unsigned short containing the value currently in the Configuration register.

#### p11w\_set\_data

#### Description

Sets the value of the Data register.

#### Syntax

#include "edtinc.h"

void p11w\_set\_data(EdtDev \*edt\_p, u\_short val);

#### Arguments

| edt_p | device handle returned from edt_open                |
|-------|-----------------------------------------------------|
| val   | value to which you wish to set the Command register |

#### Example

```
u_short dataval;
dataval = p11w_get_data(edt_p);
val = 0xf00f;
p11w_set_data(edt_p, val);
```

#### Return

None

#### p11w\_get\_data

#### Description

Gets the value of the Data register.

#### Syntax

#include "edtinc.h"

u\_short p11w\_get\_data(EdtDev \*edt\_p);

#### Arguments

edt\_p device handle returned from edt\_open

#### Return

Unsigned short containing the value currently in the Data register.

#### p11w\_get\_stat

#### Description

Gets the value of the Status register.

#### Syntax

#include "edtinc.h"

```
u_short p11w_get_stat(EdtDev *edt_p);
```

#### Arguments

edt\_p device handle returned from edt\_open

#### Example

u\_short stat;

stat = p11w\_get\_stat(edt\_p);

#### Return

Unsigned short containing the value currently in the Status register.

#### p11w\_get\_count

#### Description

Gets the value of the Word Count register.

#### Syntax

#include "edtinc.h"

u\_short p11w\_get\_count(EdtDev \*edt\_p);

#### Arguments

edt\_p device handle returned from edt\_open

#### Example

u\_int countreg;

countreg = p11w\_get\_count(edt\_p);

#### Return

Unsigned short containing the value currently in the Word Count register.

# Hardware

This section describes the PCI 11W interface, registers, connectors, and timing.

## **PCI Local Bus Interface**

The interface to the PCI Local Bus supports data transfer at 2, 4 and bursts up to 64 bytes per request. The interface is implemented using programmable logic.

## FIFO

The PCI 11W uses First-In-First-Out (FIFO) memories to buffer the data flow to and from the PCI Local Bus. These FIFOs can store up to 128 bytes and are implemented in the programmable gate array.

## **Device Interface**

The device interface is implemented with Unibus Driver/Receivers and 180/390 terminators. The receivers have a 1 V hysteresis and a 2 V noise immunity. The drivers are open-collector type. The DR11W handshake, counters, and control are implemented in the programmable gate array with the PCI Local Bus DMA.

See the section entitled "Signals" on page 58 for further details on device signal usage.

## **Logic Levels**

The PCI 11W uses the standard DR11W drivers and receivers. These parts have Schmitt trigger inputs and a switching threshold set to equalize high and low noise margins. You can use TTL devices for short distances, but we do not recommend it. The drivers are open-collector drivers, capable of driving the required  $105-\Omega$  terminating networks at each cable end.

The recommended parts for the drivers are:

- the National Semiconductor DS8838 Quad Driver/Receiver, and
- the National Semiconductor DS8837 Hex Receiver.



The following figure shows the configuration of the PCI 11W drivers.



# Signals

This section describes the kinds of signals the PCI 11W uses, how they are connected, and provides you with a suggestion for using the signals in your application for data input and output.

## **Connector Pinout**

The PCI 11W uses a high-density 80-pin I/O connector. The pinout and construction of this connector adapts easily to standard DR11W 40-pin, .100 x .100 connectors.

The high-density mating connector is an AMP connector, AMP part number 749111-7, with a straightshielded backshell (AMP P/N 749196-1) or right angle backshell (AMP P/N 749205-1). The pinout described in the table below ensures that the high density connector and the P1 and P2 connectors of the EDT cable mate directly with standard 40-pin connectors.

Interpret the connector pinout table below in one of the following ways, depending upon the type of cable you are using.

| EDT Model CAB-A | The column labeled AMP represents the AMP connector at one end of the cable. This end plugs into the AMP connector on the PCI 11W. The columns labeled STD P1 and STD P2 represent standard 40-pin connectors at the ends of the Y on the other end of the cable. These ends plug into the user device.                                                                             |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EDT Model CAB-B | Both ends of the cable have AMP connectors, so the column labeled AMP represents both ends. The columns labeled STD P1 and STD P2 are irrelevant. Cabling is swapped; AMP 1 at one end connects to AMP 41 at the other, AMP 2 to AMP 42, and so on until AMP 40 at one end connects to AMP 80 at the other. This cable can connect two PCI 11W modules, or one PCI 11W to one S16D. |
| EDT Model CAB-D | Both ends of the cable have AMP connectors, so the column labeled AMP represents both ends. The columns labeled STD P1 and STD P2 are irrelevant. Cabling is straight through.                                                                                                                                                                                                      |

| AMP | STD P1 | DEC P1 | Sig           | nal        | DEC P2 | STD P2 | AMP |
|-----|--------|--------|---------------|------------|--------|--------|-----|
| 1   | 1      | VV     | DO15          | DI15       | VV     | 1      | 41  |
| 2   | 2      | UU     | DO00          | D100       | UU     | 2      | 42  |
| 3   | 3      | TT     | DO14          | DI14       | TT     | 3      | 43  |
| 4   | 4      | SS     | DO01          | DI01       | SS     | 4      | 44  |
| 5   | 5      | RR     | DO13          | DI13       | RR     | 5      | 45  |
| 6   | 6      | PP     | DO02          | DI02       | PP     | 6      | 46  |
| 7   | 7      | NN     | DO12          | DI12       | NN     | 7      | 47  |
| 8   | 8      | MM     | DO03          | DI03       | MM     | 8      | 48  |
| 9   | 9      | LL     | DO11          | DI11       | LL     | 9      | 49  |
| 10  | 10     | KK     | DO04          | DI04       | KK     | 10     | 50  |
| 11  | 11     | JJ     | DO10          | DI10       | JJ     | 11     | 51  |
| 12  | 12     | HH     | DO05          | DI05       | HH     | 12     | 52  |
| 13  | 13     | FF     | DO09          | DI09       | FF     | 13     | 53  |
| 14  | 14     | EE     | DO06          | DI06       | EE     | 14     | 54  |
| 15  | 15     | DD     | DO08          | DI08       | DD     | 15     | 55  |
| 16  | 16     | CC     | DO07          | DI07       | CC     | 16     | 56  |
| 17  | 17     | BB     | NC            | NC         | BB     | 17     | 57  |
| 18  | 18     | AA     | GROUND        | GROUND     | AA     | 18     | 58  |
| 19  | 19     | Z      | CYCRQ B       | GROUND     | Z      | 19     | 59  |
| 20  | 20     | Y      | GROUND        | GROUND     | Y      | 20     | 60  |
| 21  | 21     | Х      | END CYCLE     | GO H       | Х      | 21     | 61  |
| 22  | 22     | W      | GROUND        | GROUND     | W      | 22     | 62  |
| 23  | 23     | V      | STATUS C      | FNCT1      | V      | 23     | 63  |
| 24  | 24     | U      | GROUND        | GROUND     | U      | 24     | 64  |
| 25  | 25     | Т      | STATUS C      | C1 CNTROL  | Т      | 25     | 65  |
| 26  | 26     | S      | GROUND        | GROUND     | S      | 26     | 66  |
| 27  | 27     | R      | STATUS B      | FNCT2      | R      | 27     | 67  |
| 28  | 28     | Р      | GROUND        | GROUND     | Р      | 28     | 68  |
| 29  | 29     | N      | INIT          | C0 CNTRL   | Ν      | 29     | 69  |
| 30  | 30     | М      | GROUND        | GROUND     | М      | 30     | 70  |
| 31  | 31     | L      | STATUS A      | FNCT3      | L      | 31     | 71  |
| 32  | 32     | K      | BURST RQ      | FNCT3      | K      | 32     | 72  |
| 33  | 33     | J      | WC INC ENB    | BC INC ENB | J      | 33     | 73  |
| 34  | 34     | Н      | GROUND        | GROUND     | Н      | 34     | 74  |
| 35  | 35     | F      | READY         | A00        | F      | 35     | 75  |
| 36  | 36     | E      | GROUND        | GROUND     | Е      | 36     | 76  |
| 37  | 37     | D      | ACLO<br>FNCT2 | ATTN       | D      | 37     | 77  |
| 38  | 38     | С      | GROUND        | GROUND     | С      | 38     | 78  |
| 39  | 39     | В      | CYCRQ A       | BUSY       | В      | 39     | 79  |
| 40  | 40     | Α      | GROUND        | GROUND     | А      | 40     | 80  |

Table 1. PCI 11W (p11w\_3v.bit, p11w\_5v.bit)

The following tables describe each signal by name, I/O type, and polarity. An I in the table indicates the signal is an input to the PCI 11W, and an O indicates a PCI 11W output. An H indicates the signal performs the function described in the table at a logic high (or +3 V). An L indicates the signal performs the named function at a logic low. A P indicates the signal is programmable.

## **Synchronous Control Signals**

The table below describes the eight signals controlling the synchronous DMA transfer cycle. These signals are sampled only during a BUSY cycle while READY is not asserted. Devices can implement these signals as required for device applications.

| Name     | I/O | Assert | Description                                                                                                                                                                                                                                                                  |  |  |
|----------|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| C0 CNTRL | Ι   | Н      | Not supported by PCI 11W. DR11W uses this signal to indicate writing a byte.                                                                                                                                                                                                 |  |  |
| C1 CNTRL | Ι   | Н      | If this signal is enabled by the DIRS0 and DIRS1 bits of the Command register, C1 is used by a device to control the direction of DMA. C1 overrides the direction of data transfers indicated in application software, such that a read system call becomes a write instead. |  |  |
| FNCT1    | 0   | Р      | This signal is used to control the device as the user defines. It is typically used as a DMA direction indicator from the host to the device. When used in this way, the device loops FUNCT1 back to C1, which indicates the direction.                                      |  |  |
| FNCT2    | 0   | Р      | This signal is used to control the device as the user defines. It is typically used to idicate that the device requires attention. In host-to-host applications, FUNCT2 is tied to the ATTN input of the other PCI 11W.                                                      |  |  |
| FNCT3    | 0   | Р      | This signal is used to control the device as the user defines.                                                                                                                                                                                                               |  |  |
| STATUS A | I   | Н      | Input for device status, read with STATA in Status register.                                                                                                                                                                                                                 |  |  |
| STATUS B | I   | Н      | Input for device status, read with STATB in Status register.                                                                                                                                                                                                                 |  |  |
| STATUS C | Ι   | Н      | Input for device status, read with STATC in Status register.                                                                                                                                                                                                                 |  |  |

 Table 2. Synchronous Control Signals

## Handshake Signals

These five signals perform the DR11W transfer cycle. GO and EOC are optional.

| Name    | I/O | Assert | Description                                                                                                                                                                                                                                                                                                                                                                   |  |
|---------|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| READY   | 0   | Н      | Indicates that the PCI 11W is ready for a DMA cycle to be initiated. The<br>signal is low when a DMA cycle is in progress. Use this signal to qualif<br>all other control signals, and take no other action when READY is<br>asserted. Wait until the final BUSY edge before storing data, because<br>an application can assert READY before the last DMA cycle is completed. |  |
| GO      | 0   | Н      | A 100 ns pulse occurring at the beginning of the DMA cycle, when<br>READY is asserted. This signal is provided for compatibility with<br>DR11W. We recommend that your application use READY.                                                                                                                                                                                 |  |
| CYCRQ A | Ι   | Ρ      | To initiate a transfer, the device asserts CYCRQ A after READY has<br>cleared. By default, the rising edge of CYCRQ A starts the transfer; the<br>high pulse on CYCRQ A must be at least 100 ns to do start the transfer.<br>The user device ordinarily initiates CYCRQ A when READY is false,<br>BUSY is false, and the device requires data. CYCRQ A clears when the        |  |

|           |   |   | PCI 11W sets BUSY and the requested transfer is in progress. You can configure the PCI 11W so that the falling edge of CYCRQ A starts the transfer using bit D1 of the configuration register.                                                                                                                                                                                                                                                                 |
|-----------|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CYCRQ B   | Ι | Р | Similar to CYCRQ A. The PCI 11W combines CYCRQ A and B using<br>the logical OR operation. Most applications use only CYCFA A or drive<br>both signals simultaneously. If the device does not use CYCFA B, you<br>must disable it or set it to low using the Configuration register.                                                                                                                                                                            |
| BUSY      | 0 | Ρ | The primary data transfer strobe. The PCI 11W asserts BUSY in response to a CYCRQ. After a delay specified by the input skew, the PCI 11W latches control signals and input data from the rising edge of BUSY. On output cycles, data is valid on the falling edge of BUSY. The polarity of BUSY is reversed in link mode applications and loopback, in order for the configuration register to reverse the polarity of BUSY and to program input/output skew. |
| END CYCLE | 0 | Н | A 100 ns pulse occurring on the falling edge of the last BUSY. This signal is provided for compatibility with DR11W. You can use the rising edge of EOC to signal the end of DMA, but this is not recommended as some DR11W emulators do not implement EOC.                                                                                                                                                                                                    |

Table 3. Handshake Signals

## Asynchronous Control Signals

The table below describes the two signals controlling the DR11W device and host operating state, asynchronous with the control signals. These signals affect the PCI 11W when they are asserted.

| Name | I/O | Assert | Description                                                                                                                                                                                                                                                                                               |  |
|------|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| ATTN | I   | Н      | Interrupt the PCI Local Bus host if this signal is asserted. By default,<br>ATTN also terminates a DMA in progress, as does DR11W. Using the<br>PCI 11W Configuration register, you can make this interrupt<br>independent of DMA so that devices can signal the host without<br>disturbing DMA activity. |  |
| INIT | 0   | Ρ      | A programmable signal from the PCI 11W used to reset the device. You can implement this signal as a fourth function bit if your application does not require complete DR11W compatibility.                                                                                                                |  |

Table 4. Asynchronous Control Signals

## **Unimplemented DR11W Signals**

The following signals are provided for compatibility with DR11W but are not implemented by the PCI 11W.

- BURST RQ An input to the DR11W for optimizing bus usage. The PCI 11W optimizes PCI Local Bus cycles automatically.
- WC INC ENB Allows a user device to control the DR11W word counter. Implementing this signal would interfere with PCI 11W bus usage optimization.
- BC INC ENB Allows a user device to control the DR11W byte counter. Implementing this signal would interfere with PCI 11W bus usage optimization.
- A00 Formerly used in conjunction with the C0 and C1 signals to implement byte writes. Implementing this signal is impractical for high-speed DMA transfers.

## Timing

Figure 2 shows the timing diagram for the PCI 11W interface. The timing parameters shown in the diagram refer to the PCI 11W during DMA transfers, in response to read or write system calls.



\* Signals are from S11W

Figure 5. Timing Diagram



# Registers

The PCI 11W has two memory spaces: the memory-mapped registers and the configuration space. Expansion ROM and I/O space are not implemented.

Applications can access the PCI 11W registers through the DMA library routines edt\_reg\_read or edt\_reg\_write using the name specified under "Access," or if necessary by means of *ioctl()* calls with PCI 11W-specific parameters, as defined in the file p11w.h.

## **Configuration Space**

The configuration space is a 64-byte portion of memory required to configure the PCI Local Bus and to handle errors. Its structure is specified by the PCI Local Bus specification. The structure as implemented for the PCI 11W is as shown in Figure 6 and described below.

| Address Bits | 31                                     | 16                    | 15                           | 0                                    |  |
|--------------|----------------------------------------|-----------------------|------------------------------|--------------------------------------|--|
| 0x00         | Device ID:                             | 0x00                  | Vendor ID = $0x123$          | D                                    |  |
| 0x04         | Status (see below)                     |                       | Command (see belo            | ow)                                  |  |
| 0x08         | Class Code = 0x088                     | 3000                  |                              | Revision ID = 0<br>(will be updated) |  |
| 0x0C         | BIST = 0x00                            | Header Type =<br>0x00 | Latency Timer<br>(set by OS) | Cache Line Size<br>(set by OS)       |  |
| 0x10         | DMA Base Address Register* (set by OS) |                       |                              |                                      |  |
|              | not implemented                        |                       |                              |                                      |  |
| 0x3C         | $Max\_Lat = 0x04$                      | $Min_Gnt = 0x04$      | Interrupt Pin =<br>0x01      | Interrupt Line (set by OS)           |  |

#### Figure 6. Configuration Space Addresses

Values for the status and command fields are shown in the following two tables. For complete descriptions of the bits in the status and command fields, see the *PCI Local Bus Specification*, Revision 2.1, 1995, available from:

PCI Special Interest Group 5440 SW Westgate Drive Suite 217 Portland, OR 97221 Phone: 800/433-5177 (United States) or 425/803-1191 (international) Fax: 503/222-6190

www.pcisig.com

| Bit | Name                          | Value       | Bit | Name                  | Value       |
|-----|-------------------------------|-------------|-----|-----------------------|-------------|
| 0–4 | reserved                      | 0           | 10  | DEVSEL Timing         | 0           |
| 5   | 66 MHz Capable                | 0           | 11  | Signaled Target Abort | implemented |
| 6   | UDF Supported                 | 0           | 12  | Received Target Abort | implemented |
| 7   | Fast Back-to-back<br>Capable  | 0           | 13  | Received Master Abort | implemented |
| 8   | Data Parity Error<br>Detected | implemented | 14  | Signaled System Error | implemented |
| 9   | DEVSEL Timing                 | 1           | 15  | Detected Parity Error | implemented |

**Table 7. Configuration Space Status Field Values** 

| Bit | Name                                  | Value       | Bit                    | Name                        | Value       |
|-----|---------------------------------------|-------------|------------------------|-----------------------------|-------------|
| 0   | IO Space                              | 0           | 6                      | Parity Error Response       | implemented |
| 1   | Memory Space                          | implemented | 7 Wait Cycle Control 0 |                             | 0           |
| 2   | Bus Master                            | implemented | 8                      | SERR# Enable                | implemented |
| 3   | Special Cycles                        | 0           | 9                      | Fast Back-to-back<br>Enable | implemented |
| 4   | Memory Write and<br>Invalidate Enable | 0           | 10–<br>15              | reserved                    | 0           |
| 5   | VGA Palette Snoop                     | 0           |                        |                             |             |

 Table 8. Configuration Space Command Field Values

## **PCI Local Bus Addresses**

The following figure describes the PCI 11W interface registers in detail. The addresses listed are offsets from the gate array boot ROM base addresses. This base address is initialized by the host operating system at boot time.

**Note:** The addresses 0x80 and 0x84 are used by the pciload utility to update the gate array. User applications must not modify use these registers. Results of running pciload do not take effect until after the board has been turned off and then on again.

| Address Bits | 31 16              | 15 0         |  |
|--------------|--------------------|--------------|--|
| 0xCC         | DR11 wo            | ord count    |  |
| 0xC8         | DR11W data         | DR11 status  |  |
| 0xC4         | DR11 configuration | DR11 command |  |

| 0x84      | not used flash ROM data                 |        |   |  |  |  |
|-----------|-----------------------------------------|--------|---|--|--|--|
| 0x80      | flash ROM address                       |        |   |  |  |  |
| 0x20      | not used                                |        |   |  |  |  |
| 0x1C      | scatter-gather DMA next count and contr | ol     |   |  |  |  |
| 0x18      | scatter-gather DMA current count and co | ontrol |   |  |  |  |
| 0x14      | scatter-gather DMA next address         |        |   |  |  |  |
| 0x10      | scatter-gather DMA current address      |        |   |  |  |  |
| 0x0C      | main DMA next count and control         |        |   |  |  |  |
| 0x08      | main DMA current count and control      |        |   |  |  |  |
| 0x04      | main DMA next address                   |        |   |  |  |  |
| 0x00      | main DMA current address                |        |   |  |  |  |
|           |                                         |        |   |  |  |  |
| Byte Word | 3 2 1 0                                 |        |   |  |  |  |
|           | 1                                       |        | 0 |  |  |  |

Table 9. PCI Local Bus Addresses

## **Scatter-gather DMA**

PCI Direct Memory Access (DMA) devices in Intel-based computers access memory using physical addresses. Because the operating system uses a memory manager to connect the user program to memory, memory pages that appear contiguous to the user program are actually scattered throughout physical memory. Because DMA accesses physical addresses, a DMA read operation must *gather* data from noncontiguous pages, and a write must *scatter* the data back to the appropriate pages. The EDT Product driver uses information from the operating system to accomplish this. The operating system passes the driver a list of the physical addresses for the user program memory pages. With this information, the driver builds a scatter-gather (SG) table, which the DMA device uses sequentially.

Most other PCI computers offer memory management for the PCI bus as well, so the operating system needs to pass only the address and count for DMA. The addresses appear contiguous to the PCI bus.

The scatter-gather DMA list is stored in memory. The scatter-gather DMA channel copies it as required into the main DMA registers. The format of the DMA list in memory is as follows (illustrated in the following table):

- Each page entry takes eight bytes. Therefore, the scatter-gather DMA count is always evenly divisible by eight.
- The first word consists of the 32-bit start address of a memory page.
- The most significant 16 bits of the second word contain control data.
- The least significant 16 bits of the second word contain the count.

As of the current release, only bit 16 contains control information. When set to one, and when enabled by setting bit 28 of the Scatter-gather DMA Next Count and Control register, this bit causes the main DMA interrupt to be set when the marked page is complete.

| Bits       | 63      | 32 | 31               | 16      | 0     |
|------------|---------|----|------------------|---------|-------|
| Each entry | address |    | control (unused) | DMA int | count |

#### Table 10. Scatter-gather DMA List Format

## **Performing DMA**

All main DMA registers are read-only. Only the corresponding scatter-gather DMA registers must write to them. To initiate a DMA transfer:

- 1. Set up one or more scatter-gather DMA lists in host memory, using the format described above and illustrated in the table above.
- 2. Write the address of the first entry in the list to the Scatter-gather Next DMA Address register.
- 3. Write the length of the scatter-gather DMA list to the Scatter-gather Next DMA Count and Control register, setting the interrupts as you require. Ensure that bit 29 of this register is set to 1—this starts the DMA.
- 4. If the DMA list is greater than one page, load the address of the first entry of the next page and its length, as described in steps 2 and 3, when bit 29 of the Scatter-gather Next DMA Count and Control register is asserted.

#### Main DMA Current Address Register

| Size     | 32-bit                                                                                 |
|----------|----------------------------------------------------------------------------------------|
| I/O      | read-only                                                                              |
| Address  | 0x00                                                                                   |
| Access   | EDT_DMA_CUR_ADDR                                                                       |
| Comments | Automatically copied from the main DMA next address register after main DMA completes. |

| Bit   | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| A31–0 | The address of the current DMA or the last used address if no DMA is currently active. |

#### Main DMA Next Address Register

| Size    | 32-bit                           |
|---------|----------------------------------|
| I/O     | read-only                        |
| Address | 0x04 + (channel number x 20 hex) |

| Comments The scatter-gather DMA fills this register when required from the scatter-<br>gather DMA list. | Access   | EDT_DMA_NXT_ADDR |
|---------------------------------------------------------------------------------------------------------|----------|------------------|
|                                                                                                         | Comments |                  |

| Bit   | Description                                |
|-------|--------------------------------------------|
| A31–0 | Read the starting address of the next DMA. |

### Main DMA Current Count and Control Register

| Size     | 32-bit                                                                                                         |
|----------|----------------------------------------------------------------------------------------------------------------|
| I/O      | read-only                                                                                                      |
| Address  | 0x08                                                                                                           |
| Access   | EDT_DMA_CUR_CNT                                                                                                |
| Comments | This register automatically copied from the main DMA next count and control register after main DMA completes. |

| Bit    | Description                                                                                    |
|--------|------------------------------------------------------------------------------------------------|
| A31–16 | Read-only versions of bits 31–16 of the scatter-gather DMA current count and control register. |
| D15–0  | The number of words still to be transferred in the current DMA.                                |

### Main DMA Next Count and Control Register

| Size     | 32-bit                                                                                         |
|----------|------------------------------------------------------------------------------------------------|
| I/O      | read-only                                                                                      |
| Address  | 0x0C                                                                                           |
| Access   | EDT_DMA_NXT_CNT                                                                                |
| Comments | The scatter-gather DMA fills this register when required from the scatter-<br>gather DMA list. |

| Bit    | Description                                                                                 |
|--------|---------------------------------------------------------------------------------------------|
| A31–16 | Read-only versions of bits 31–16 of the scatter-gather DMA next count and control register. |
| D15–0  | The number of words still to be transferred in the current DMA.                             |

### Scatter-gather DMA Current Address Register

| Size     | 32-bit                                                                                                                                              |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O      | read-only                                                                                                                                           |
| Address  | 0x10                                                                                                                                                |
| Access   | EDT_SG_CUR_ADDR                                                                                                                                     |
| Comments | Automatically copied from the scatter-gather DMA next address register<br>when that register is valid and the current scatter-gather DMA completes. |

| Bit   | Description                                                                            |
|-------|----------------------------------------------------------------------------------------|
| A31–0 | The address of the current DMA or the last used address if no DMA is currently active. |

### Scatter-gather DMA Next Address Register

| Size     | 32-bit                                                                                                                                                  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O      | read-write                                                                                                                                              |
| Address  | 0x14                                                                                                                                                    |
| Access   | EDT_SG_NXT_ADDR                                                                                                                                         |
| Comments | The driver software writes this register as described in step 2 of the list in the Performing DMA section on page <b>Error! Bookmark not defined.</b> . |

| Bit   | Description                           |  |
|-------|---------------------------------------|--|
| A31–0 | The starting address of the next DMA. |  |



### Scatter-gather DMA Current Count and Control Register

| Size     | 32-bit                                                                               |
|----------|--------------------------------------------------------------------------------------|
| I/O      | read-only                                                                            |
| Address  | 0x18                                                                                 |
| Access   | EDT_SG_CUR_CNT                                                                       |
| Comments | The driver software can read this register for debugging or to monitor DMA progress. |

| Bit    | Description                                                                                 |
|--------|---------------------------------------------------------------------------------------------|
| A31–16 | Read-only versions of bits 31–16 of the scatter-gather DMA next count and control register. |
| D15–0  | The number of words still to be transferred in the current DMA.                             |

#### Scatter-gather DMA Next Count and Control Register

| Size     | 32-bit                                                                                                                |
|----------|-----------------------------------------------------------------------------------------------------------------------|
| I/O      | read-write                                                                                                            |
| Address  | 0x1C                                                                                                                  |
| Access   | EDT_SG_NXT_CNT                                                                                                        |
| Comments | The driver software writes this register as described in step 2 of the list in the Performing DMA section on page 66. |

| Bit | EDT_      | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D31 | EN_RDY    | Enable scatter-gather next empty interrupt. A value of 1<br>enables DMA_START (bit 29 of this register) to set<br>DMA_INT (bit 12 of the Status register), thus causing an<br>interrupt if the PCI_EN_INTR bit is set (bit 15 of the Main<br>DMA Command and Configuration register).                                                                                                                                              |
|     |           | A value of 0 disables the DMA_START from causing an<br>interrupt.                                                                                                                                                                                                                                                                                                                                                                  |
| D30 | DMA_DONE  | Read-only: a value of 0 indicates that a scatter-gather DMA transfer is currently in progress. A value of 1 indicates that the current scatter-gather DMA is complete.                                                                                                                                                                                                                                                             |
| D29 | DMA_START | Write a 1 to this bit to indicate that the values of this<br>register and the SG DMA Next Address register are valid;<br>this sets this bit to 0, indicating either that the copy is in<br>progress, or that the device is waiting for the current DMA<br>to complete. In either case, this register and the SG DMA<br>Next Address register are not available for writing.<br>Reading a value of 1 indicates that the SG DMA Next |

|        |             | Count and SG DMA Next Address registers have been<br>copied into the SG DMA Current Count and SG DMA<br>Current Address registers and that the Next Count and<br>Next Address registers are once more available for writing.                                                                                                                                                                                               |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D28    | EN_MN_DONE  | A value of 1 enables the main DMA page done interrupt (bit 18).                                                                                                                                                                                                                                                                                                                                                            |
| D27    | EN_SG_DONE  | Enable scatter-gather DMA done interrupt. A value of 1<br>enables DMA_DONE (bit 30 of this register) to set<br>DMA_INT (bit 12 of the Status register), thus causing an<br>interrupt if the PCI_EN_INTR bit is set (bit 15 of the Main<br>DMA Command and Configuration register).<br>A value of 0 disables the DMA_DONE from causing an<br>interrupt.                                                                     |
| D26    | DMA_ABORT   | A value of 1 stops the DMA transfer in progress and cancels the next one, clearing bits 29 and 30. Always 0 when read.                                                                                                                                                                                                                                                                                                     |
| D25    | DMA_MEM_RD  | A value of 1 specifies a read operation; 0 specifies write.                                                                                                                                                                                                                                                                                                                                                                |
| D24    | BURST_EN    | A value of 0 means bytes are written to memory as soon as<br>they are received. A value of 1 means bytes are saved to<br>write the most efficient number at once.                                                                                                                                                                                                                                                          |
| D23    | MN_DMA_DONE | Read only: a value of 1 indicates that the main DMA is not active.                                                                                                                                                                                                                                                                                                                                                         |
| D22    | MN_NXT_EMP  | Read only: a value of 1 indicates that the main DMA next address and next count registers are empty.                                                                                                                                                                                                                                                                                                                       |
| D21–19 |             | Reserved for EDT internal use.                                                                                                                                                                                                                                                                                                                                                                                             |
| D18    | PG_INT      | Read-only: a value of 1 indicates that the page interrupt is<br>set (enabled by bit 28 of this register), and that the main<br>DMA has completed transferring a page for which bit 16<br>(the page interrupt bit) was set in the scatter-gather DMA<br>list (see Figure 6). If the PCI interrupt is enabled (bit 15 of<br>the PCI interrupt and remote Xilinx configuration register),<br>this bit causes a PCI interrupt. |
|        |             | Clear this bit by disabling the page done interrupt (bit 28 of this register).                                                                                                                                                                                                                                                                                                                                             |
| D17    | CURPG_INT   | Read-only: a value of 1 indicates that bit 16, the page interrupt bit, was set in the scatter-gather DMA list entry for the current main DMA page.                                                                                                                                                                                                                                                                         |
| D16    | NXTPG_INT   | Read-only: a value of 1 indicates that bit 16, the page interrupt bit, was set in the scatter-gather DMA list entry for the next main DMA page.                                                                                                                                                                                                                                                                            |
| D15–0  |             | The number of bytes in the next scatter-gather DMA list.                                                                                                                                                                                                                                                                                                                                                                   |
|        |             |                                                                                                                                                                                                                                                                                                                                                                                                                            |

## Flash ROM Access Registers

### Flash ROM Address Register

| Size    | 32-bit                                                                                                                                                  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O     | read-write                                                                                                                                              |
| Address | 0x80                                                                                                                                                    |
| Access  | EDT_FLASHROM_ADDR                                                                                                                                       |
| Comment | Use this register and the flash ROM data register (below) to update the program in the field-programmable gate array that implements the PCI interface. |

| Bit    | Description                                                                                                                                           |  |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| D31–25 | Reserved for EDT internal use.                                                                                                                        |  |
| D24    | A value of 1 causes the data in the flash ROM data register to be written to the address specified by bits 0 through 23. A value of 0 reads the data. |  |
| D23-0  | Address of location in flash ROM that the next read or write will access.                                                                             |  |

### Flash ROM Data Register

| Size    | 32-bit                                                                                                                                                     |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O     | read-write                                                                                                                                                 |
| Address | 0x84                                                                                                                                                       |
| Access  | EDT_FLASHROM_DATA                                                                                                                                          |
| Comment | Use this register and the flash ROM address register (above) to update the program in the field-programmable gate array that implements the PCI interface. |

| Bit   | Description                                                                                                                                                                                                                  |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D31–9 | Not used                                                                                                                                                                                                                     |
| D8    | A read-only bit indicating the position of the jumper that enables access to the protected area of the ROM that contains the executable program. A value of 1 indicates that the board can load a new program.               |
| D7-0  | The new program to load into flash ROM with a write operation (specified by setting bit A24 in the flash ROM address register), or the data that was read (specified by clearing bit A24 in the flash ROM address register). |

## **Device Control Registers**

### **Command Register**

| Size    | 16-bit      |
|---------|-------------|
| I/O     | read-write  |
| Address | 0xC4        |
| Access  | P11_COMMAND |

| Bit    | P11W_                   | Description                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D15    | EN_INT                  | Enable PCI interrupt, to set the interrupt on a board-wide basis. Write 0 to clear the interrupt.                                                                                                                                                                                                                                                                                                                       |
| D14    | EN_CNT                  | Enable end of DR11 count interrupt. Write 0 to clear the interrupt.                                                                                                                                                                                                                                                                                                                                                     |
| D13    | EN_ATTN                 | Enable attention interrupt. Write 0 to clear the interrupt.                                                                                                                                                                                                                                                                                                                                                             |
| D12    | FCYC                    | Force Cycle Request, used in link applications to initiate cycle request handshakes between PCI 11W devices. To achieve the same effect as an external cycle request, set this bit after setting the GO bit. The PCI 11W driver takes care of this automatically in response to a read or write command, when the application sets the FCYC bit in the command word using PCI11S_READJ_COMMAND or PCI11S_WRITE_COMMAND. |
| D11-10 |                         | Not used.                                                                                                                                                                                                                                                                                                                                                                                                               |
| D9     | ODDSTART                | Set to 1 when DMA starts on an odd-word boundary. In order for ODDSTART to behave correctly, first clear the FIFOs with BCLR.                                                                                                                                                                                                                                                                                           |
| D8     | BCLR                    | Board Clear. Set BCLR to abort the DMA in process and clear the PCI 11W FIFOs. This operation does not send INIT to the DR11W device. This has the same effect as setting DMA_ABORT in the DMA Command register.                                                                                                                                                                                                        |
| D7     | INIT                    | Initialize device. The PCI 11W asserts the INIT signal on<br>the interface as long as INIT is set to 1. The INIT signal<br>is not a pulse; the software determines the length of INIT<br>according to the requirements of the device.                                                                                                                                                                                   |
| D6-4   | FNCT3<br>FNCT2<br>FNCT1 | These function control bits are passed directly to the device<br>interface. If the PFCT2 bit is asserted in the configuration<br>register, the FNCT2 signal pulses when you assert the<br>FNCT2 bit, allowing ATTN to be pulsed toward the device.                                                                                                                                                                      |

EDT

| D3-2 | DIRS1<br>DIRS0 | Select the direction of the DMA transfer according to this table. $read$ refers to a read operation from the PCI Local Bus to the DR11W device.   |
|------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                | DIRS1 DIRS0 Direction                                                                                                                             |
|      |                | 0 0 Use DR11W-C1 input signal (0=read,<br>1=write)                                                                                                |
|      |                | 1 0 Use FNCT1 bit (0=read, 1=write)                                                                                                               |
|      |                | don't1Use DMA_MEM_RD bit in the DMAcareCommand register.                                                                                          |
| D1   | BLKM           | Provided for compatibility with S11W, but setting this bit has no effect. Use BURST_EN (bit 24) of the DMA Command register to enable burst mode. |
| D0   | GO             | Not used.                                                                                                                                         |

### **Configuration Register**

| Size    | 16-bit      |
|---------|-------------|
| I/O     | read-write  |
| Address | 0xC6        |
| Access  | EP11_CONFIG |

| Bit    | P11W_ | Description                                                                                                                                                                                                                                                                                                                            |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D15-13 |       | Not used.                                                                                                                                                                                                                                                                                                                              |
| D12    | PFCT2 | When set, the PCI 11W FUNCT2 output pulses high for<br>300 ns for each time the FUNCT2 bit in the Command<br>register transitions between 0 and 1. Otherwise, the<br>FUNCT2 output reflects the state of the FUNCT2 bit. Set<br>this bit when using FunCT2 in link mode in order to pulse<br>the ATTN input of the other DR11W device. |
| D11    | NCOA  | When No Clear on Attention is set, an incoming ATTN signal does not abort a DMA in progress. Set this bit if your application requires an ATTN interrupt independent of DMA transfers.                                                                                                                                                 |
| D10    | SSWAP | When set to 1, Short SWAP swaps 16-bit words within a 32-bit memory word, for hosts that require this reordering.                                                                                                                                                                                                                      |
| D9     | INV   | When set to 1, inverts the data.                                                                                                                                                                                                                                                                                                       |
| D8     | SWAP  | SWAP determines which byte of a PCI Local Bus half-word<br>ends up on which half of the PCI 11W 16-bit bus. When<br>SWAP is 0, the byte order is the DR11W standard, which is<br>the opposite of the Sun short order.                                                                                                                  |
| D7     | RDYT  | The READY timing bit determines when the PCI 11W asserts READY on the last transfer of a DMA cycle. When this bit is 0, the PCI 11W asserts READY during BSY of the last cycle. When this bit is 1, the PCI 11W asserts READY                                                                                                          |

|      |                  | at the end of BSY and coincident with EOC.<br>The DR11W standard asserts READY during BSY; but<br>many devices function better with READY asserted after<br>BSY if their strobe is strictly a combinatorial AND of<br>READY and BSY.                                                                                                                                              |
|------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D6-5 | INSK1<br>INSK0   | Input skew sets the time from the start of BSY until the PCI 11W samples input data and control. An input skew of 0 is 40 ns. Each increment adds 40 ns.                                                                                                                                                                                                                          |
| D4-3 | OUTSK1<br>OUTSK0 | Output skew sets the time between valid output data and<br>the BSY transition that terminates the cycle. An output<br>skew of 0 represents a data setup minimum of 10 ns. Each<br>increment adds 40 ns.                                                                                                                                                                           |
| D2   | ENBB             | When set, this bit enables the CYCRQ B input as required<br>for strict DR11 compatibility. If your application does not<br>use CYCRQ B, clear this bit, because an open CYCRQ B<br>input is pulled to an active state by the terminator and<br>masks CYCFA A, thereby inhibiting all transfers.                                                                                   |
| D1   | CYCP             | The Cycle Request Polarity bit determines which edge of<br>the CYCRQ A or CYCRA B input initiates dta transfer. If<br>this bit is set to 0, a falling edge initiates transfer. If this bit<br>is set to 1, a rising edge initiates transfer. The DR11W<br>standard requires a rising edge. Some devices use a falling<br>edge so that disconnected inputs are inactive.           |
|      |                  | In new designs, we recommend using the negative edge to initiate transfers, so that unplugging the device cable does not produce a clock edge.                                                                                                                                                                                                                                    |
| D0   | BSYP             | BSYP determines the PCI 11W external signal BSYH polarity. If BSYP is 0, the external BSY is asserted high (positive is true); this is the default.                                                                                                                                                                                                                               |
|      |                  | If you remove the hardware jumper on the PCI 11W, the<br>BSYP polarity is forced to negative true and this bit is<br>ignored. Use the jumper for devices that require a negative-<br>true buys as a strobe, and don't qualify BSY with READY.<br>In this case, setting the configuration register with the<br>jumper installed causes an active BSY transition for the<br>device. |

EDT

### **Status Register**

| Size    | 16-bit     |
|---------|------------|
| I/O     | read-only  |
| Address | 0xC8       |
| Access  | P11_STATUS |

| Bit   | P11W_                         | Description                                                                                                                                                                                                            |
|-------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D15   | INT                           | A value of 1 indicates the PCI interrupt is asserted.                                                                                                                                                                  |
| D14   | CNTINT                        | A value of 1 indicates the DR11 count interrupt is asserted.                                                                                                                                                           |
| D13   | ATTNINT                       | A value of 1 indicates the attention interrupt is asserted.                                                                                                                                                            |
| D12   | DMA_INT                       | A value of 1 indicates the end of DMA interrupt is asserted.                                                                                                                                                           |
| D11   | ATTN                          | Reflects the state of the external PCI 11W ATTN input.                                                                                                                                                                 |
| D10-8 | STATC_S<br>STATB_S<br>STATA S | Reflects the state of the external PCI 11W inputs STATA, STATB, and STATC.                                                                                                                                             |
| D7    | INIT S                        | Reads back the state of the Command register INIT bit.                                                                                                                                                                 |
| D6-4  | FNCT3_S<br>FNCT2_S<br>FNCT1_S | Reads back the state of Command register bits FNCT3, FNCT2, and FNCT1.                                                                                                                                                 |
| D3-2  |                               | Always set to 0 on the current PCI 11W.                                                                                                                                                                                |
| D1    | BLKM_S                        | Provided for compatibility with S11W, but reads back a bit that has no effect. Instead, read back the state of BURST_EN (bit 24) of the DMA Command register.                                                          |
| D0    | RDY_S                         | Indicates when PCI Local Bus DMA is in progress. This bit<br>is set whenever the PCI 11W READY signal is not asserted<br>(low), which indicates a transfer is occurring. This bit is<br>clear when the system is idle. |

### **Data Register**

| Size    | 16-bit     |
|---------|------------|
| I/O     | read-write |
| Address | 0xCA       |
| Access  | P11_DATA   |

| Bit   | Description                                                                                                                                          |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| D15-0 | When DMA is in progress, DMA writes to this register; otherwise, data written to this register appears on the DR11 output data bus to this register. |

### Word Count Register

-

| Size    | 32-bit    |
|---------|-----------|
| I/O     | read-only |
| Address | 0xCC      |
| Access  | P11_COUNT |
|         |           |

| Bit    | Description                                                                                                                                                            |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WC31-0 | The word count bits specify how many bytes to transfer to or from the DR11W interface. Each transfer is one 16-bit word, or two bytes, so WC0 always has a value of 0. |



# **Specifications**

#### **PCI Local Bus Compliance**

| Number of Slots                                               | 1                                                                                                                                                                                                                                                                             |
|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transfer Size                                                 | 2, 4, and bursts up to 64 bytes                                                                                                                                                                                                                                               |
| PCI Local Bus width                                           | 32 bits                                                                                                                                                                                                                                                                       |
| Clock rate                                                    | 33 MHz maximum                                                                                                                                                                                                                                                                |
| Signaling                                                     | Universal: +5V or 3.3V                                                                                                                                                                                                                                                        |
| Address space                                                 | Configuration space: 64 bytes                                                                                                                                                                                                                                                 |
|                                                               | Memory space: 1 page of 4 KB, 256 bytes used                                                                                                                                                                                                                                  |
|                                                               | I/O space and Expansion ROM: not used                                                                                                                                                                                                                                         |
|                                                               | Device Data Transfer                                                                                                                                                                                                                                                          |
| Format                                                        | 16-bit parallel word                                                                                                                                                                                                                                                          |
| Handshake                                                     | 2-wire asynchronous handshake                                                                                                                                                                                                                                                 |
| Transfer types                                                | Programmed I/O, DMA block transfer, configurable DMA direction                                                                                                                                                                                                                |
| Transfer rate                                                 | Dependent upon attached device, host load, and block size.<br>Maximum 8 MB/second                                                                                                                                                                                             |
| Signal polarity                                               | Data is true.                                                                                                                                                                                                                                                                 |
|                                                               | Control signals are programmable; the default is specified by DR11W.                                                                                                                                                                                                          |
| Signal Timing                                                 | Programmable handshake timing.                                                                                                                                                                                                                                                |
| Buffers                                                       | 128-byte FIFO for input, 128-byte FIFO for output                                                                                                                                                                                                                             |
|                                                               |                                                                                                                                                                                                                                                                               |
|                                                               |                                                                                                                                                                                                                                                                               |
| Software                                                      | Drivers for Solaris 2.6+ (Intel and                                                                                                                                                                                                                                           |
| Software                                                      | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version                                                                                                                                                                                                                 |
| Software                                                      | Υ.                                                                                                                                                                                                                                                                            |
| Software<br>Power                                             | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version                                                                                                                                                                                                                 |
|                                                               | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version 4.3, Irex 6.5, and Linux Red Hat Version 5.1                                                                                                                                                                    |
|                                                               | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version 4.3, Irex 6.5, and Linux Red Hat Version 5.1                                                                                                                                                                    |
| Power                                                         | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version 4.3, Irex 6.5, and Linux Red Hat Version 5.1                                                                                                                                                                    |
| Power<br>Environmental                                        | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version 4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A                                                                                                                                                      |
| Power<br>Environmental                                        | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version<br>4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A<br>Operating: 10 to 40° C                                                                                                                         |
| Power<br>Environmental<br>Temperature                         | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version<br>4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A<br>Operating: 10 to 40° C<br>Nonoperating: -20 to 60° C                                                                                           |
| Power<br>Environmental<br>Temperature                         | <ul> <li>SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version 4.3, Irex 6.5, and Linux Red Hat Version 5.1</li> <li>5V at 1.5A</li> <li>Operating: 10 to 40° C</li> <li>Nonoperating: -20 to 60° C</li> <li>Operating: 20 to 80% noncondensing at 40° C</li> </ul>   |
| Power<br>Environmental<br>Temperature                         | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version<br>4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A<br>Operating: 10 to 40° C<br>Nonoperating: -20 to 60° C<br>Operating: 20 to 80% noncondensing at 40° C                                            |
| Power<br>Environmental<br>Temperature<br>Humidity             | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version<br>4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A<br>Operating: 10 to 40° C<br>Nonoperating: -20 to 60° C<br>Operating: 20 to 80% noncondensing at 40° C                                            |
| Power<br>Environmental<br>Temperature<br>Humidity<br>Physical | SPARC platforms), Windows NT/2000/XP Version 4.0, AIX Version<br>4.3, Irex 6.5, and Linux Red Hat Version 5.1<br>5V at 1.5A<br>Operating: 10 to 40° C<br>Nonoperating: -20 to 60° C<br>Operating: 20 to 80% noncondensing at 40° C<br>Nonoperating: 95% noncondensing at 40°C |



# References

*DR11W Direct Memory Interface Module User's Guide*, available from Digital Equipment Corporation, Maynard, Mass. Ask for part number EK-DR11W-UG-001.

See the UNIX manual pages for *ioctl*(2), *select*(2), *read*(2), *open*(2), *write*(2), *aioread*(2), *aiowrite*(2), and *aiowait*(2) for specific information about these system calls.

PCI Local Bus Specification, Revision 2.1, 1995, is available from:

PCI Special Interest Group P.O. Box 14070 Portland, OR 97214 Phone:

800/433-5177 (United States) 503/797-4207 (International) Fax: 503/234-6762

