# INTERBUS

User Manual

Device Driver Development Kit for Controller Boards in PC Systems With PCI Bus

Designation: IBS PCI DDK UM E Order No.: 26 98 16 4



onlinecomponents.com

# INTERBUS

## User Manual

# Device Driver Development Kit for Controller Boards in PC Systems With PCI Bus

20

Designation: IBS PCI DDK UM E

Revision: A

Order No.: 26 98 16 4

This user manual is valid for: IBS PCI SC/I-T IBS PCI SC/RI/I-T IBS PCI SC/RI-LK

Order No. 27 25 26 0 Order No. 27 30 08 0 Order No. 27 30 18 7

© Phoenix Contact 08/2001



6189A

onlinecomponents.com

# Please Observe the Following Notes:

In order to guarantee the safe use of your device, we recommend that you read this manual carefully. The following notes give you information on how to use this manual.

#### **Requirements of the User Group**

The use of products described in this manual is oriented exclusively to qualified application programmers and software engineers, who are familiar with automation safety concepts and applicable national standards. Phoenix Contact assumes no liability for erroneous handling or damage to products from Phoenix Contact or external products resulting from disregard of information contained in this manual.

#### **Explanation of Symbols Used**



The *attention* symbol refers to an operating procedure which, if not carefully followed, could result in damage to equipment or personal injury.



The *note* symbol informs you of conditions that must strictly be observed to achieve error-free operation. It also gives you tips and advice on hardware and software optimization to save you extra work.



The *text* symbol refers to detailed sources of information (manuals, data sheets, literature, etc.) on the subject matter, product, etc. This text also provides helpful information for the orientation in the manual.

#### We Are Interested in Your Opinion

We are constantly attempting to improve the quality of our manuals.

Should you have any suggestions or recommendations for improvement of the contents and layout of our manuals, we would appreciate it if you would send us your comments. Please use the universal fax form at the end of the manual for this.



#### Statement of Legal Authority

This manual, including all illustrations contained herein, is copyright protected. Use of this manual by any third party in departure from the copyright provision is forbidden. Reproduction, translation, or electronic or photographic archiving or alteration requires the express written consent of Phoenix Contact. Violations are liable for damages.

Phoenix Contact reserves the right to make any technical changes that serve the purpose of technical progress.

All product names used are trademarks of the respective organizations.

#### Internet

<text> Up-to-date information on Phoenix Contact products can be found on the



#### Terms of Delivery and Payment for Software

Using the DDK sources indicates your acceptance of the following Terms and Conditions. If you do not wish to accept these Terms and Conditions, please send the complete unopened diskette package and all accompanying material (including written material and packing) against reimbursement of the payment made. Phoenix Contact points out that no General Terms of Contract of the customer (hereinafter referred to as the Registered User) can be recognized. The inclusion of such General Terms of Contract is hereby explicitly contradicted.

#### Terms of Contract

#### § 1 Subject matter

The subject matter of this contract is the program stored on the data carrier including the written material also supplied (program description, operating instructions etc.), hereinafter referred to as "Software".

#### § 2 Scope of the license

1.In the event of acquisition of a single license, the following paragraph regulates the scope of the license.

- Phoenix Contact grants the Registered User the single, non-exclusive right (hereinafter referred to as license) to use the Software on one single computer. The Registered User may also install the Software on more than one computer. However, the Software may only be used on one computer at a time. Any use exceeding this scope is not permitted unless agreements have been reached concerning the acquisition of supplementary licenses or a company license (cf. Items 2 and 3). The license is a single license if described as such in acknowledgement of order and invoice.
- 2. In the event of acquisition of supplementary licenses, the following paragraph regulates the scope of the license.

The Registered User is granted the right to make copies of previously acquired Software (single license) and to use these copies. The number of permitted copies is derived from the number of supplementary licenses acquired by the Registered User. The Registered User undertakes to identify the Software products placed at his disposal and put into circulation by him. To identify the data carriers, the Registered User shall receive a set of appropriate serial numbers. The number of serial numbers corresponds to the number of permitted copies. Each copy may only be used once at a time (cf. § 2 Item 1). Supplementary licenses may only be acquired by Registered Users that are in possession of a basic license for the Software in question. The Registered User is obliged to keep records of the whereabouts of all copies and to allow Phoenix Contact to inspect these records on request.

The license is a supplementary license if described as such in acknowledgement of order and invoice. 3. In the event of acquisition of a company license, the following paragraph regulates the scope of the license.

Registered Users that have acquired a company license are granted the right to make any number of copies of the Software placed at their disposal in their own company, and to use it on any number of computers at the same time.

The license is a company license if described as such in acknowledgement of order and invoice. Use is only permitted in one location.

#### § 3 Copyright

The Software is the property of Phoenix Contact. The acquisition of rights to the Software itself going beyond the license regulated in this contract is not associated with this. In particular, Phoenix Contact reserves all rights to copying, publication, processing and exploitation.

The Registered User recognizes that he acquires no rights whatsoever to the Software products described going beyond this agreement, in particular that he acquires no commercial rights to source code.

2. The Software is legally protected against copying. The Registered User may make up to three backup copies for archiving purposes. No alphanumerical identification marks, brand names, trademarks or copyright notices may be removed; these must be transferred to the copies. Neither manuals nor written materials may be copied, unless Phoenix Contact has explicitly authorized the Registered User to do so within the framework of a supplementary or company license. With the exception of the provisions stated in the following paragraph, the Software may be neither loaned, hired nor otherwise passed on to third parties.



- 3. The rights ensuing from this licensing agreement may be transferred to a third party on condition that the terms and conditions of this licensing agreement are explicitly recognized in writing and that the Registered User hands over the complete program package including all diskettes (and including any backup copies made) and written materials, and that the Registered User completely deletes the program version from all hard disks in his computer. The transfer must comprise the current version (update) and all previous versions. Phoenix Contact must be notified of the transfer of the licensing rights, with the name and address of the recipient. A copy of the declaration of acceptance must be enclosed with the notification. Insofar as no other written agreement has been reached, this obligation also extends to subsidiary companies, other locations, other places of business and other companies of the Registered User.
- The Registered User must not make any information of a technical or commercial nature obtained from Phoenix Contact, hereinafter referred to as "Information", or any development results accessible to third parties.

Documentation supplied by Phoenix Contact, as well as the Software and the products derived from said Software may only be passed on within the framework of the above licensing agreement. The confidentiality obligation also applies after termination of the contract. However, it does not apply to information which is generally known or which on receipt could be proved to be part of the internal state of technology of the Registered User or which became incorporated later in this internal state of technology, irrespective of the present contract.

#### § 4 Decompilation and modifications to the program

- 1. The decompilation of the program code provided into other code forms as well as other means of retracing the various programming stages of the Software (reverse engineering), including a program modification, are permitted for the Registered User's own use, in particular for purposes of fault correction, for establishing the interoperability and compatibility or expansion of the range of functions. Within the meaning of this provision, own use includes in particular private use by the Registered User. Own use, however, also includes use for professional or profit-making purposes, insofar as this is restricted to the Registered User's or his employees' own use and is not commercially exploited externally in any way.
- 2. The appropriate actions may only be carried out by commercial third parties in potential competition with Phoenix Contact if Phoenix Contact does not wish to carry out the required program modifications against reasonable compensation. Phoenix Contact must be given an adequate period of time to check the acquisition of the order by the third party, and must be informed of the name of the third party.
- 3. Insofar as the stated actions are carried out for commercial reasons, they are only permitted if they are essential for the creation, maintenance or proper functioning of an independently created interoperable
- program and the necessary information has not yet been published and is not otherwise accessible.
  Under no circumstances may copyright notices, serial numbers or other characteristics for identifying the program be removed or modified.

#### § 5 Guarantee

- 1. This Software has been produced with the greatest possible care. It is, however, known to the Registered User that with the present state of technology it is not possible to produce Software in such a way that it works without errors in all applications and combinations.
- 2. The guarantee period is six months, beginning with the delivery of the Software.
- 3. Phoenix Contact guarantees that at the time of delivery, the material of the data carriers on which the Software is stored and the documentation supplied are free from faults. Should the data carriers or the documentation supplied be faulty, the Registered User can demand a replacement delivery during the agreed guarantee period as stated above, on condition that he returns the defective material, including any backup copies made, and the written material.
- 4. If during the use of the Software by the Registered User for the contractually agreed and intended purpose considerable deviations from the performance description prepared by Phoenix Contact should result, Phoenix Contact has, at its own discretion, the right to rectify faults twice or to provide replacements twice. If Phoenix Contact does not succeed in eliminating the considerable deviations from the performance description within a reasonable period of time through rectification or replacement, or in avoiding them in such a way that the Registered User can use the Software in accordance with the contract, the Registered User can demand a reduction of payment (price reduction) or cancellation of this contract (rescission). In the latter case the Registered User must hand back any copies he may have made. \_Failure of the rectification or oreplacement can only be presumed if the Registered User provides Phoenix Contact with verifiable documentation concerning the type and occurrence of deviations from the performance description (reproducible fault log) and if in spite of this documentation rectification is not possible, is refused by Phoenix Contact or is unreasonably delayed, if there are justified doubts concerning the prospects of success or if unacceptability prevails for other reasons.



- 5. Fault diagnosis and rectification within the framework of the guarantee shall be effected on the premises of the Registered User or of Phoenix Contact, at the discretion of Phoenix Contact. If a repair or service agreement has been reached between the Registered User and Phoenix Contact, the fault diagnosis and rectification may also be effected at the installation site of the computer on which the Software is being run in accordance with § 2 and § 3, by arrangement with the Registered User.\_Phoenix Contact shall be given the documentation and information which is in the possession of the Registered User and which is required to rectify the fault. If Phoenix Contact is to rectify the fault on the premises of the Registered User, the Registered User shall provide, free of charge, the necessary hardware and software as well as the other necessary operating conditions together with suitable operating personnel in such a way that the work can be carried out quickly. If no repair or service agreement has been reached, the Registered User shall reimburse Phoenix Contact for expenses for travelling and board for personnel sent to the installation site of the computer on which the licensed Software is being run.\_No other guarantee claims can be accepted.
- 6. Notwithstanding the above agreements, it is agreed that software identified as "BETA" or "ALPHA" is completely excluded from the guarantee, since this is only a preliminary or test version which does not correspond to the final product.

#### § 6 Liability

- 1. Phoenix Contact accepts no liability for the Software meeting the requirements of the Registered User or working together with other programs selected by him.
- 2. Phoenix Contact accepts unlimited liability for damage due to deficiencies in title and absence of warranted qualities. Liability for initial inability is restricted to the purchase price as well as to such damage, which can typically be expected within the framework of a software transfer. In other respects, Phoenix Contact only accepts liability for intention and gross negligence, unless an obligation whose observance is of particular importance for the achievement of the contractual purpose (cardinal obligation) is violated. In the event of violation of a cardinal obligation, the limitation of liability for initial inability is applicable.

If damage has been caused intentionally or through gross negligence, the amount of our liability is limited to the damage foreseeable under normal circumstances as a consequence of this obligation violation.

 Notwithstanding the above agreements, it is agreed that no liability whatsoever can be accepted for software identified as "BETA" or "ALPHA" (cf. § 5.6)

#### § 7 Prices

- 1. In accordance with its current price list, Phoenix Contact shall charge separately for
  - support in commissioning the Software
  - support in the analysis and rectification of faults arising through improper handling or for other reasons not arising from the Software.

#### § 8 Compensation

The Registered User is fully liable to Phoenix Contact for all damage resulting from violations of this licensing agreement or of copyright.

#### § 9 Termination

- 1. The Registered User can terminate the contract, insofar as it is unlimited in time, in whole or in part, with a period of notice of six months as from the end of each month. If a single license fee was paid for the transfer of the Software, this is not returnable.
- 2. On termination of the contract, the Registered User is obliged to return to Phoenix Contact the original as well as all copies and part-copies, as well as modified copies and copies combined with other program material, or verifiably to destroy them. The same applies for the program documentation and other documents provided.
- 3. The retention of an archive copy for backup purposes requires a separate written agreement.

#### § 10 Export

1

The export of software, including the relevant data and documents, may require official approval - e.g. because of its type or its intended purpose. In the event of the sale of software to third parties, the Registered User shall in each case obtain the required export authorization on his own responsibility and effect delivery only in accordance with such authorization.

#### § 11 Ancillary agreements

Ancillary agreements and alterations to the licensing conditions must be made in writing.



#### § 12 Place of jurisdiction, choice of applicable law

- 1. For all disputes arising from the contractual relationship, the court at the headquarters of Phoenix Contact is competent if the Registered User is a merchant registered in the Commercial Register, a legal person under public law or if a special fund under public law is concerned.
- 2. The law of the Federal Republic of Germany applies for all legal relationships between the parties

<text>



# Table of Contents

| 1 Introduction             |                                                 | 1-3     |
|----------------------------|-------------------------------------------------|---------|
| 1.1                        | Files on the Disk                               | 1-4     |
| 1.2                        | Conditions of Support                           | 1-7     |
|                            | 1.2.1 Chargeable Support Services               | 1-8     |
| 2 Structure and Interfaces | s of INTERBUS Controller Boards                 | 2-3     |
| 2.1                        | PCI Register                                    | 2-4     |
| 2.2                        | Host Interface for INTERBUS Controller Boards   | 2-6     |
|                            | 2.2.1 Hardware Settings of Controller Boards    | 2-6     |
|                            | 2.2.2 I/O Register                              | 2-8     |
| 2.3                        | Multi-Port Memory (MPM)                         | 2-16    |
|                            | 2.3.1 MPM Address Area                          | 2-19    |
|                            | 2.3.2 Segmentation of the SRAM in the MPM       | 2-20    |
|                            | 2.3.3 MPM Communication Options                 | 2-21    |
|                            | 2.3.4 MPM Hardware Register                     | 2-24    |
|                            | 2.3.5 MPM Software Register                     | 2-48    |
| 3 Data Exchange via the I  | Data Area                                       | 3-3     |
| 3.1                        | Operating Modes                                 |         |
|                            | 3.1.1 Asynchronous Mode                         | 3-5     |
|                            | 3.1.2 Asynchronous Mode With Synchronization Pu | ılse3-5 |
| 4 Communication via the    | Mailbox Interface                               | 4-3     |
| 5 Architecture and Structu | ure of a Device Driver                          | 5-3     |
| 5.1                        | General                                         | 5-3     |
| 5.2                        | Basic Structure of the Driver                   | 5-4     |
| 5.3                        | Description of Functions                        | 5-8     |
|                            | 5.3.1 Initialization (initBoard)                |         |



|                           |       | 5.3.2    | Open Data Channel (openDevice)5-11                  |
|---------------------------|-------|----------|-----------------------------------------------------|
|                           |       | 5.3.3    | Close Data Channel (closeDevice)5-12                |
|                           |       | 5.3.4    | Write Process Data (writeDTI)5-13                   |
|                           |       | 5.3.5    | Read Process Data (readDTI)5-14                     |
|                           |       | 5.3.6    | Send Message (writeMXI)5-15                         |
|                           |       | 5.3.7    | Read Message (readMXI)5-16                          |
|                           |       | 5.3.8    | Interrupt Service Routine (intrServiceFunction)5-18 |
|                           |       | 5.3.9    | Device IO Control (devIOCtrl)5-19                   |
|                           |       | 5.3.10   | Utilities5-21                                       |
|                           |       | 5.3.11   | Data Structures Used5-29                            |
|                           |       |          |                                                     |
| <b>6</b> ToDo (Adaptation | to Op | erating  | Systems)                                            |
|                           | 6.1   | File Str | uctures in the Driver 6-3                           |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |
|                           |       |          |                                                     |



# Section 1

This section informs you about

|              |         | ,       | ives and structure of this user manual. |  |
|--------------|---------|---------|-----------------------------------------|--|
| Introduction | <br>1.1 | Files c | on the Disk                             |  |
|              | 1.2     |         | tions of Support                        |  |
|              |         | 1.2.1   | Chargeable Support Services             |  |
|              |         |         | Chargeable Support Services             |  |
|              |         |         |                                         |  |
|              |         |         |                                         |  |
|              |         |         |                                         |  |
|              |         |         |                                         |  |
|              |         |         |                                         |  |





DPHŒNIX CONTACT

6189A

minecomponents.com

## **1** Introduction

This manual and the associated C driver source code can be used to develop specific device drivers to link Generation 4 INTERBUS controller boards to any PC operating system. IBS PCI SC/I-T, IBS PCI SC/RI/I-T, and IBS PCI SC/RI-LK controller boards (referred to as IBS PCI controller boards in the following) are used to interface the open fieldbus system (standardized as IEC 61158) to PC systems (referred to as host system in the following) with PCI bus.

The host system and INTERBUS are coupled by means of a shared memory area designed as a 2-device Multi-Port Memory (MPM). An independent INTERBUS master, based on a MC68332 microcontroller and a protocol chip, is incorporated on the controller board.

This document first explains the basic, specific functions of the controller boards, and goes on to explain the general architecture of the MPM. It concludes with some notes on creating a device driver.



## 1.1 Files on the Disk

The disk contains the following directories:





| Table 1-1 | Directory contents |
|-----------|--------------------|
|-----------|--------------------|

| Directory Name | Contents                                              |
|----------------|-------------------------------------------------------|
| IBPCIMPM.SYS   | Contains the C source code for the driver.            |
| SYS            | Contains adaptations to various systems               |
| USR            | Contains include files for various systems            |
| DDI            | Contains the Device Driver Interface for VxWorks      |
| SYSTEM         | VxWorks system initialization for the IBS PCI SC/     |
| EXAMPLE        | Contains example programs that use a finished driver. |



#### Introduction

| File Name  | Contents                                                          |
|------------|-------------------------------------------------------------------|
| startup.c  | Initialization of hardware and software                           |
| drvinits.c | Driver initialization routines                                    |
| vxwsys.c   | Operating system functions/routines for VxWorks                   |
| lbpcidrv.c | Functions/routines for PCI access                                 |
| evthndg.c  | Functions/routines for event handling                             |
| drvlimit.h | Limitation constants (maximum values, etc.)                       |
| errlog.h   | Macros, constants, etc. for error logging and debugging           |
| lbpcidrv.c | Functions/routines for PCI access                                 |
| os_adapt.h | Operating system-dependent data structures, macros, and constants |
| os_inc.h   | Load operating system-dependent headers                           |
| pci_drv.h  | Constants and structures for working with PCI devices             |
| pcimsg.h   | Constants for error messages                                      |
| vxw_data.h | Constants and data structures for VXWorks tasks and priorities    |

#### Files in the "IBPCIMPM.SYS" directory Table 1-2

# Table 1-3 Files in the "IB\_INC\SYS" directory

| Table 1-3 Files in the "IB_INC\SYS" directory |                                                               |  |
|-----------------------------------------------|---------------------------------------------------------------|--|
| File Name                                     | Contents                                                      |  |
| compiler.h                                    | Compiler setting definitions                                  |  |
| mpm40.h                                       | Definitions of the MPM register addresses and their bit masks |  |
| loctl40.h                                     | Definitions for the devIOCtrl driver function                 |  |
| drv_dbg.h                                     | Defines, typedef, and prototypes for DriverDebugInfo commands |  |

| File Name  | Contents                                                                                      |
|------------|-----------------------------------------------------------------------------------------------|
| stdtypes.h | Generally valid standard type definitions                                                     |
| ddi_err.h  | Definitions of possible driver error messages                                                 |
| ddi_usr.h  | Defines, typedef, prototypes for DDI basic functions (without I/O control and management)     |
| ibs_util.h | Declarations of the additional DDI functions, e.g., watchdog, read diagnostic registers, etc. |
| ibddivxw.h | DDI for VxWorks                                                                               |
| ddi_macr.h | Macros for messages/data conversion                                                           |
| Svc_code.h | IBS service codes (send/receive)                                                              |

#### Table 1-4 Files in the "IB\_INC\USR" directory

#### Table 1-5 Files in the "VXWORX\EXAMPLE" directory

| File Name | Contents                                         |
|-----------|--------------------------------------------------|
| simple.c  | Example program for application of DDI functions |

#### Table 1-6 Files in the "VXWORX\SYSTEM" directory

| File Name    | Contents                      |
|--------------|-------------------------------|
| ibspciinit.c | VxWorks system initialization |

#### Table 1-7 Files in the "VXWORX\DDI" directory

| File Name  | Contents                                  |
|------------|-------------------------------------------|
| ibddivxw.c | Device Driver Interface (DDI) for VxWorks |



## 1.2 Conditions of Support

Upon purchasing this product, you are entitled to comprehensive support during implementation. This support is available to you free of charge, if required, for 30 days following registration of the product. This free support will only be provided via a personal e-mail address, which will be created for you.

#### How Can You Obtain This Support?

- 1. Register at the following Internet address: http://request.phoenixcontact.com/req\_eldo/pciddk\_d/ddkreg.htm
- 2. Please complete the registration form in full.
- 3. As soon as we receive your registration, you will receive confirmation together with your personal support e-mail address via e-mail.

#### Points to Note

Our free support is available during normal office hours (Germany) and only via your personal e-mail address.

Free support is available for 30 calendar days, commencing on the date of the confirmation of your registration. The support period may be extended for a fee. For details, please refer to Section "Chargeable Support Services" on page 1-8.



Please ensure that you only register the product when you wish to work continuously on the implementation.

In general, a fee is charged for telephone and on-site support. For details, please refer to Section "Chargeable Support Services" on page 1-8.

In some individual cases, it may be necessary for Phoenix Contact to telephone you, however, you will not be charged for this.

Our support can only be provided for sources supplied by Phoenix Contact. As we are not familiar with, and generally do not have access to, your development environment, Phoenix Contact does not accept any responsibility or liability for any implementation work affected by this environment.

Phoenix Contact only accepts liability for products supplied within the scope of legal requirements for product liability or according to the general delivery and payment conditions. Phoenix Contact does not accept any liability for driver implementation developed by you or by a third party.



Phoenix Contact does not accept any responsibility for development, testing, validation, release, and support of your driver implementation.

#### 1.2.1 Chargeable Support Services

Using the free support service available via your personal e-mail address, you can, if necessary, take advantage of other support services. A fee is charged for these services and we require you to place a written or verbal order.

Please contact the relevant person in the sales department or your representative. A direct order cannot be made via your e-mail address.

Extension of the e-mail account for an additional 30 days
 Order No. 27 10 26 2
 Order Designation IBS PCI DDK SUPPORT EXT

If necessary, we can offer you additional support services tailored to your requirements. Please contact the relevant person in the sales department or your representative. We will then be happy to supply you with a personal quotation.

# Section 2

This section informs you about

- the PCI register,

- the host interface and
- the MPM for INTERBUS controller boards. \_

| Structure and Interfaces of | INTEF           | RBUS Controller Boards2-3                 |  |
|-----------------------------|-----------------|-------------------------------------------|--|
| 2.1                         | PCI Register2-4 |                                           |  |
| 2.2                         | Host In         | terface for INTERBUS Controller Boards2-6 |  |
|                             | 2.2.1           | Hardware Settings of Controller Boards2-6 |  |
|                             | 2.2.2           | I/O Register2-8                           |  |
| 2.3                         | Multi-P         | ort Memory (MPM)2-16                      |  |
|                             | 2.3.1           | MPM Address Area2-19                      |  |
|                             | 2.3.2           | Segmentation of the SRAM in the MPM2-20   |  |
|                             | 2.3.3           | MPM Communication Options2-21             |  |
|                             | 2.3.4           | MPM Hardware Register2-24                 |  |
|                             | 2.3.5           | MPM Software Register2-48                 |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |
|                             |                 |                                           |  |





DPHŒNIX CONTACT

6189A

minecomponents.com

# 2 Structure and Interfaces of INTERBUS Controller Boards

PCI controller boards are directly connected with the host system using PCI connectors. This hardware interface has (according to the PCI bus specification 2.2) a 32-bit address and data bus. It has control lines in addition to the address and data lines. The controller boards support interrupt operation.



A detailed description of the controller board hardware and its installation in the host system can be found in the *IBS PCI SC QS UM E* Quick Start Guide (Order No. 26 98 14 8).

The software interface of the controller boards to the host system consists of a 16-byte window in the I/O area and a 256-kbyte window in the standard address area (memory area). The base addresses of both windows are specified by the system BIOS.



Figure 2-1 Controller board address windows in the host system

6189A



## 2.1 PCI Register

PCI registers integrate the controller boards into a PCI bus system. The following table shows the arrangement of the PCI registers and their controller board-specific settings.

| Contact)<br>ster<br>ision ID<br>W Rev)<br>che line<br>size |  |  |  |  |  |  |
|------------------------------------------------------------|--|--|--|--|--|--|
| ster<br>ision ID<br>V Rev)<br>che line                     |  |  |  |  |  |  |
| <mark>ision ID</mark><br><mark>V Rev)</mark><br>che line   |  |  |  |  |  |  |
| <mark>V Rev)</mark><br>che line                            |  |  |  |  |  |  |
| che line                                                   |  |  |  |  |  |  |
|                                                            |  |  |  |  |  |  |
| size                                                       |  |  |  |  |  |  |
|                                                            |  |  |  |  |  |  |
| Base address register 0                                    |  |  |  |  |  |  |
| (here: I/O address for the host interface register)        |  |  |  |  |  |  |
| Base address register 1                                    |  |  |  |  |  |  |
| (here: addresses for MPM and NV-RAM, 256 kbytes)           |  |  |  |  |  |  |
| Base address register 2 (not used)                         |  |  |  |  |  |  |
| Base address register 3 (not used)                         |  |  |  |  |  |  |
| Base address register 4 (not used)                         |  |  |  |  |  |  |
| Base address register 5 (not used)                         |  |  |  |  |  |  |
| Reserved (not used)                                        |  |  |  |  |  |  |
| Reserved (not used)                                        |  |  |  |  |  |  |
| Base address expansion memory (expansion ROM)              |  |  |  |  |  |  |
| (not used)                                                 |  |  |  |  |  |  |
| Reserved (not used)                                        |  |  |  |  |  |  |
|                                                            |  |  |  |  |  |  |
| rupt line                                                  |  |  |  |  |  |  |
| •                                                          |  |  |  |  |  |  |
|                                                            |  |  |  |  |  |  |

Comments for the table

The **vendor ID**  $1442_{hex}$  is the approved manufacturer identifier for Phoenix Contact.

The device ID of boards with the file designation IBS PCI SC... is  $0002_{hex}$ .

**PHŒNIX** CONTACT

#### Structure and Interfaces of INTERBUS Controller Boards

The revision ID indicates the hardware revision of the controller board.

Class code 0C<sub>hex</sub> indicates a serial bus controller.

The PCI interface uses two base address registers:

Base address register 0 contains the I/O addresses for the host interface register. The length of the I/O address area is 16 bytes.

Base address register 1 is used for the MPM address area of the master and NV-RAM. A 128-kbyte memory address area is provided for the MPM and NV-RAM respectively.

<text><text> The MPM acts as a data interface between the host system and the INTERBUS master (see also Section 2.3, "Multi-Port Memory (MPM)").



## 2.2 Host Interface for INTERBUS Controller Boards

The host interface forms the interface between the host system and the controller board MPM. The host interface also contains several registers.

### 2.2.1 Hardware Settings of Controller Boards

IBS PCI controller boards have DIP switches for setting controller board numbers (board number) and the test mode (ON/OFF). The transmission rate (500 kbaud/2 Mbaud) can also be set for the IBS PCI SC/RI-LK controller board.



Figure 2-2 DIP switch assignment



As default upon delivery, all DIP switches are in the OFF position. DIP switches 4 to 6 are reserved for later function expansions and should be left in the OFF position.



#### Structure and Interfaces of INTERBUS Controller Boards

# **Board number** The controller board number (board number) is specified using DIP switches **1** to **3**. Table 2-2 indicates possible settings:

| Board Number | DIP Switch 1 | DIP Switch 1 DIP Switch 2 |     |  |
|--------------|--------------|---------------------------|-----|--|
| 1            | 1 OFF OFF    |                           | OFF |  |
| 2            | OFF          | OFF                       | ON  |  |
| 3            | OFF          | ON                        | OFF |  |
| 4            | OFF          | ON                        | ON  |  |
| 5            | 5 ON OFF     |                           | OFF |  |
| 6            | 6 ON OFF     |                           | ON  |  |
| 7            | ON           | ON                        | OFF |  |
| 8            | 8 ON         |                           | ON  |  |

 Table 2-2
 Possible settings for controller board numbers

Test mode

If DIP switch **8** is in the ON position, after startup the controller board will automatically switch to test mode and start up any connected bus. In test mode, data exchange is not possible in either direction between the host system and the MPM. No outputs are set.



Test mode may only be used for checking the INTERBUS system connected to the controller board. Test mode should not be used in normal system operation.

#### For the IBS PCI SC/RI-LK only:

Transmission rate

The transmission rate of the INTERBUS system is set, during operation via optical fiber cable, using DIP switch **7**. If the DIP switch is in the OFF position, the transmission rate is 500 kbaud. If the DIP switch is in the ON position, INTERBUS data is transmitted at 2 Mbaud.

This switch has no significance for controller boards IBS PCI SC/I-T and IBS PCI SC/RI/I-T and should remain in the OFF position. The baud rate setting is made automatically.

6189A



## 2.2.2 I/O Register

The controller board occupies 16 I/O addresses of the host system. The first eight addresses are occupied with control registers, which can be both read and written. After the control registers come the I/O registers for direct inputs and outputs.

Table 2-3 Addresses of the I/O registers

| Offset | Name               | Function                                             |
|--------|--------------------|------------------------------------------------------|
| 0      | Board_Number       | Read current set controller board number             |
| 1      | Not_Used           | Reserved                                             |
| 2      | IRQ_Control_Host   | Interrupt enable                                     |
| 3      | WDT_Control_Host   | Status, enabling, and reset of the watchdog timer    |
| 4      | Reset_Control_Host | Master software reset                                |
| 5      | Not_Used           | Reserved                                             |
| 6      | Not_Used           | Reserved                                             |
| 7      | Status             | Read and write status register                       |
| 8      | Direct_IN          | Read inputs Direct IN 1 to Direct IN 6               |
| 9      | Direct_OUT         | Read and write outputs Direct OUT 1 and Direct OUT 2 |
| 10     | Not_Used           | Reserved                                             |
| 11     | Not_Used           | Reserved                                             |
| 12     | Not_Used           | Reserved                                             |
| 13     | Not_Used           | Reserved                                             |
| 14     | Not_Used           | Reserved                                             |
| 15     | Not_Used           | Reserved                                             |



#### Structure and Interfaces of INTERBUS Controller Boards

#### 2.2.2.1 Board\_Number



**PHŒNIX** CONTACT

#### 2.2.2.3 WDT\_Control\_Host

Write access

The host interface watchdog timer can be switched on, operated, and reset using the WDT\_Control\_Host register. The reserved bits must contain the value "0".



Figure 2-5 Structure of the WDT\_Control\_Host register during write access

Setting the WDT\_Enable bit activates the watchdog timer. This timer is active and runs until it overflows or is switched off by a hardware reset of the host system. It **cannot** be deactivated by resetting the WDT\_Enable bit. The monitoring time is determined by a bit combination in the "WDT\_interval" (D2 to D4). The contents of this field are saved when the watchdog timer is switched on and can be modified while the timer is active. The watchdog timer is triggered by the read and write access of the WDT\_Control\_Host register. The WDT\_Clear status is not saved, i.e., the watchdog timer cannot be switched off by setting this bit. WDT\_Clear only resets the WDT\_Status bit and the HF LED on the controller board after a watchdog timer has been triggered.



#### Structure and Interfaces of INTERBUS Controller Boards

In the WDT\_Interval (data bits 2 to 4) the following monitoring times can be set:

| Table 2-4 |    | WDT_Interval |                 |  |
|-----------|----|--------------|-----------------|--|
| D4        | D3 | D2           | Monitoring Time |  |
| 0         | 0  | 0            | 8.2 ms          |  |
| 0         | 0  | 1            | 16.4 ms         |  |
| 0         | 1  | 0            | 32.8 ms         |  |
| 0         | 1  | 1            | 65.5 ms         |  |
| 1         | 0  | 0            | 131.1 ms        |  |
| 1         | 0  | 1            | 262.1 ms        |  |
| 1         | 1  | 0            | 524.3 ms        |  |
| 1         | 1  | 1            | 1048.6 ms       |  |





2-6 Structure of the WDT\_Control\_Host register during read access

During a read access, the WDT\_Enable bit indicates whether the watchdog timer is running. This bit cannot be reset by a write access. The WDT\_Status bit indicates the status of the monitoring output. If the bit has the value "0", the watchdog timer has always been triggered appropriately since power up. If the bit has the value "1", the watchdog timer was not reset in the specified time. In this case, the interrupt SRQ2L(0) is

6189A

generated. The HF LED on the controller board indicates a SysFail of the host system. This bit remains set until WDT\_Clear is set or the timer is restarted. The set time interval WDT\_Interval can be read back.

#### 2.2.2.4 Reset\_Control\_Host

Write access





A reset of the controller board master is triggered by writing the reset bit field using the bit pattern in Table 2-5. This means that both the firmware and INTERBUS are reset. After a reset the master starts a selftest with a "power on". The MPM is not immediately reset with a reset. The data remains in the MPM until the master checks the MPM during its test routine. Only then will the data be cleared and the register reset.

|  | Table 2-5 | Bit pattern for the master reset |
|--|-----------|----------------------------------|
|--|-----------|----------------------------------|

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|----|----|----|----|----|----|----|----|
| 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  |



#### Structure and Interfaces of INTERBUS Controller Boards

#### **Read access**

Write access



During read access, data bit D0 indicates that the master is currently in the selftest mode and therefore cannot enable the MPM. If the bit is set to "0", the master is again ready to operate.

#### 2.2.2.5 Status



Setting the SysFail bit indicates to the MPM and the INTERBUS master that an error has occurred in the host system.

This bit is set after startup. If the bit is set, no output data can be sent to the bus. Therefore this bit must be reset by the driver software.



#### **Read access**



Figure 2-10 Structure of the status register during read access

The SysFail bit and MPM\_ReadyL bit can be read back. All other bits are reserved and reported with a "0".

2.2.2.6 Direct\_IN



The status of the direct inputs can be read back using this register.



Read access

#### Structure and Interfaces of INTERBUS Controller Boards

#### 2.2.2.7 Direct\_OUT



6189A



## 2.3 Multi-Port Memory (MPM)

Along with the INTERBUS master and the host interface, the multi-port memory (MPM) is a central component of INTERBUS controller boards. As described above, all information exchanged between the host system and the INTERBUS master is routed through the MPM.



6189A012

Figure 2-13 The MPM as the central interface of the controller board

The MPM control logic ensures prioritized assignment of access to the MPM. Time monitoring is started in parallel with accessing of the MPM. If a device takes too long to access or fails to access, a timeout is generated. This is indicated in an MPM register and access to the MPM is simultaneously re-enabled for other devices.



All data in the MPM is stored in Intel format ("little-endian" or "low-high" format). Appropriate conversion is therefore required on host system access.



|                             | <ul> <li>In addition to the hardware registers, the MPM has a series of software registers, which are used specifically to control mailbox communication between the individual devices. The number and location of these registers are not predetermined by the hardware.</li> <li>From the viewpoint of the user, the MPM therefore consists of the following functional components: <ul> <li>Static RAM (SRAM)</li> <li>Memory manager</li> <li>Status and control register</li> <li>Serial data channel</li> </ul> </li> </ul>                                                                     |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Static RAM                  | The static RAM (SRAM) uses MPM address area 0000hex through FFFFhex<br>and therefore occupies a special position within the MPM. This area is<br>always available and cannot be blocked by the MPM memory manager.<br>The SRAM contains the data area (DTA) and the mailbox area (MXA), i.e.,<br>all data exchanged between the individual nodes is routed via the SRAM.<br>The segmentation and size of the individual areas is specified by the MPM<br>firmware manager rather than being predetermined by the hardware.                                                                             |
| Memory manager              | The entire MPM address area is a maximum of 512 kbytes. Address area 00000hex through 0FFFhex (64 kbytes) occupies a special position. This area contains the static RAM (SRAM) and the hardware registers. Up to 256 pages of any size can be displayed in the remaining area (10000hex –7FFFhex). It is possible to switch between the individual pages using a special hardware register in the MPM. Each node can display the relevant page independently of the other nodes. Address area 0000hex through FFFFhex (64 kbytes) is not switched with the rest and is thus available for every page. |
| Status and control register | MPM address area 3F90hex through 3FFFhex (i.e., within the SRAM area) contains a series of hardware registers. These registers contain, for example, MPM status information or are used to evaluate and generate signals (interrupts) between the individual nodes. The registers are available to all nodes. Registers that present the same contents to all nodes are distinguished from those that are dedicated to each individual node. However, the same number of registers at the same addresses are always available to all nodes.                                                            |

6189A



# Serial data channel

I/O shift registers and a serial EEPROM can be connected to the MPM serial data channel. The serial data channel is used to read and save or , etc. , output configuration data. A distinction is made between access to the serial EEPROM and access to the shift registers. For example, the switches, the motherboard ID, and the MPM configuration are read via the shift registers. The serial data channel is accessed using four hardware



# 2.3.1 MPM Address Area



Figure 2-14 MPM address area

The diagnostic registers, for example, have the following addresses:

| Register                           | Address             |
|------------------------------------|---------------------|
| Diagnostic status register         | 3520 <sub>hex</sub> |
| Diagnostic parameter register      | 3522 <sub>hex</sub> |
| Ext. diagnostic parameter register | 37E6 <sub>hex</sub> |
| Slave diagnostic status register   | 37EC <sub>hex</sub> |

| E  |  |
|----|--|
| Ш  |  |
| Ш  |  |
| Ш  |  |
| Ш  |  |
| 24 |  |

For additional information on the diagnostic registers, please refer to the *Firmware Services and Error Messages* User Manual *IBS SYS FW G4 UM E, Order No. 27 45 18 5*.



# 2.3.2 Segmentation of the SRAM in the MPM

The SRAM is located from address  $\rm 0000_{hex}$  through address  $\rm FFFF_{hex}$  in the MPM.



Figure 2-15 Segmentation of the SRAM



This document provides a general description of the MPM, i.e., the registers and MPM functions of a complete MPM with **four** nodes are described.

The IBS PCI controller board MPM is only designed for two nodes:

| Node 0: | Host CPU (application program) |
|---------|--------------------------------|
| Node 1: | INTERBUS master (firmware)     |

All MPM registers and bits are only available to nodes 0 and 1. Accessing the registers for nodes 2 and 3 has no effect.



# 2.3.3 MPM Communication Options

The MPM is used to exchange information between devices (nodes). This communication can be related to the exchange of data or notification of an event. Both options are offered by the MPM and are supported by corresponding mechanisms. The MPM SRAM is available for exchanging data. For exchanging events, there are four sources of interrupts for each node, which can be evaluated independently of each other. It is also possible for both forms to be used in combination, as, for example, in the mailbox interface.

#### **Communication Methods Used:**

- Data interface
- Mailbox interface
- SysFail requests
- Signal interface
- Synchronization requests



Figure 2-16 Diagram of the various MPM communication options



#### 2.3.3.1 Data Interface (DTI)

Process data is exchanged with the INTERBUS master via the data interface.

Various areas are defined within the data area (DTA). The data interface (DTI) consists of both the "normal" data area, which contains process data and the extended data area, in which user-specific data can be stored.



No handshake is specified for exchanging data via the DTI. This means that in contrast to message exchange via the mailbox interface, data may be overwritten by one node while it is being read by another. The user must use their own transmission protocol. For IBS PCI controller boards, a protocol of this type is activated by default by the firmware, and is supported by the driver.



A detailed description of the data interface can be found in Section 3, "Data Exchange via the Data Area".

#### 2.3.3.2 Mailbox Interface (MXI)

The mailbox interface (MXI) is a protocol-oriented interface via which messages can be exchanged between the nodes.

The mailbox interface consists of the mailbox area (MXA) and a number of hardware and software registers for each node. The area occupied by the mailbox area and the register addresses is predefined and must not be changed by the user. The size and location of the mailbox area and the software registers are specified in the MPM descriptor, which is created by the MPM master for each node (see Section "Structure of the MPM Descriptor" on page 2-49).

The mailbox area in turn is divided into a number of blocks ("mailboxes"). Each of these can take one message. When sending, the address of the mailbox containing the message is placed in a software register in the MPM and the receiving node is notified (see also Section 4, "Communication via the Mailbox Interface"). The mailbox is managed by the node driver. The length of one mailbox is 1 kbyte.

MPM registers used:

- Set HS Ax/Bx register
- Status register 1
- Handshake register A / handshake register B
- Send vector and acknowledge vector registers (software registers)





A detailed description of the mailbox interface and the handshake protocol used can be found in Section 4, "Communication via the Mailbox Interface".

#### 2.3.3.3 SysFail Request

The SysFail logic can be used to immediately notify other nodes of serious system errors. The SysFail signal can be triggered either by hardware, via the corresponding MPM control lines or by software, by writing to a special MPM register. An interrupt is always generated at all nodes (apart from the initiating one) and indicated in an MPM register (status register 1). In the case of a SysFail initiated by the hardware, the logical status of the initiating line is indicated in a different MPM register (status SysFail register). The response to a SysFail interrupt depends on the particular node. In the event of a SysFail interrupt, the INTERBUS master, for example, sets all output data to zero. A node must acknowledge that it has detected a SysFail interrupt by writing to an MPM register (clear status bit register). This resets the corresponding bit in status register 1.

MPM registers used:

- Status register 1
- Status SysFail register
- Clear-status-bit register
- Set SysFail request register



# 2.3.4 MPM Hardware Register

MPM hardware registers are displayed in the MPM SRAM address area in  $3F90_{hex}$  through  $3FFF_{hex}$ . A distinction is made between read and write hardware registers.

**Write registers** The write registers are word registers that can initiate or pass on information or actions. The contents of the write registers can only be read back in summarized form in the read registers.

**Read registers** The read registers are word registers. They can be used to read both the written data in the write registers and additional status and configuration data.

|                     | -                        | -    |                     |            |      |
|---------------------|--------------------------|------|---------------------|------------|------|
| Address             | Register                 | Page | Address             | Register   | Page |
| 3F90 <sub>hex</sub> | Set MPM node par ready 0 | 2-31 | 3FCA <sub>hex</sub> | Set HS A15 | 2-37 |
| 3F92 <sub>hex</sub> | Set MPM node par ready 1 | 2-31 | 3FCC <sub>hex</sub> | Set HS B7  | 2-37 |
| 3F94 <sub>hex</sub> | Set MPM node par ready 2 | 2-31 | 3FCE <sub>hex</sub> | Set HS B15 | 2-37 |
| 3F96 <sub>hex</sub> | Set MPM node par ready 3 | 2-31 | 3FD0 <sub>hex</sub> | Set HS A2  | 2-37 |
| 3F98 <sub>hex</sub> | Switch memory            | 2-42 | 3FD2 <sub>hex</sub> | Set HS A10 | 2-37 |
| 3F9C <sub>hex</sub> | Set sync req             | 2-41 | 3FD4 <sub>hex</sub> | Set HS B2  | 2-37 |
| 3FA0 <sub>hex</sub> | Set SysFail req          | 2-33 | 3FD6 <sub>hex</sub> | Set HS B10 | 2-37 |
| 3FA2 <sub>hex</sub> | Program bits             | 2-45 | 3FD8 <sub>hex</sub> | Set HS A6  | 2-37 |
| 3FA4 <sub>hex</sub> | Serial data              | 2-44 | 3FDA <sub>hex</sub> | Set HS A14 | 2-37 |
| 3FA6 <sub>hex</sub> | Serial address           | 2-43 | 3FDC <sub>hex</sub> | Set HS B6  | 2-37 |
| 3FA8 <sub>hex</sub> | Clear status bit 0       | 2-34 | 3FDE <sub>hex</sub> | Set HS B14 | 2-37 |
| 3FAA <sub>hex</sub> | Clear status bit 1       | 2-34 | 3FE0 <sub>hex</sub> | Set HS A1  | 2-37 |
| 3FAC <sub>hex</sub> | Clear status bit 2       | 2-34 | 3FE2 <sub>hex</sub> | Set HS A9  | 2-37 |
| 3FAE <sub>hex</sub> | Clear status bit 3       | 2-34 | 3FE4 <sub>hex</sub> | Set HS B1  | 2-37 |
| 3FB0 <sub>hex</sub> | Set MPM node SG int 0    | 2-38 | 3FE6 <sub>hex</sub> | Set HS B9  | 2-37 |

Table 2-6 Write register addresses in the MPM



| Structure and Interfaces of INTERBUS Controller Be | oards |
|----------------------------------------------------|-------|
|----------------------------------------------------|-------|

| Address             | Register              | Page | Address             | Register   | Page |
|---------------------|-----------------------|------|---------------------|------------|------|
| 3FB2 <sub>hex</sub> | Set MPM node SG int 1 | 2-38 | 3FE8 <sub>hex</sub> | Set HS A5  | 2-37 |
| 3FB4 <sub>hex</sub> | Set MPM node SG int 2 | 2-38 | 3FEA <sub>hex</sub> | Set HS A13 | 2-37 |
| 3FB6 <sub>hex</sub> | Set MPM node SG int 3 | 2-38 | 3FEC <sub>hex</sub> | Set HS B5  | 2-37 |
| 3FB8 <sub>hex</sub> | Set MPM node ready0   | 2-30 | 3FEE <sub>hex</sub> | Set HS B13 | 2-37 |
| 3FBA <sub>hex</sub> | Set MPM node ready1   | 2-30 | 3FF0 <sub>hex</sub> | Set HS A0  | 2-37 |
| 3FBC <sub>hex</sub> | Set MPM node ready2   | 2-30 | 3FF2 <sub>hex</sub> | Set HS A8  | 2-37 |
| 3FBE <sub>hex</sub> | Set MPM node ready3   | 2-30 | 3FF4 <sub>hex</sub> | Set HS B0  | 2-37 |
| 3FC0 <sub>hex</sub> | Set HS A3             | 2-37 | 3FF6 <sub>hex</sub> | Set HS B8  | 2-37 |
| 3FC2 <sub>hex</sub> | Set HS A11            | 2-37 | 3FF8 <sub>hex</sub> | Set HS A4  | 2-37 |
| 3FC4 <sub>hex</sub> | Set HS B3             | 2-37 | 3FFA <sub>hex</sub> | Set HS A12 | 2-37 |
| 3FC6 <sub>hex</sub> | Set HS B11            | 2-37 | 3FFC <sub>hex</sub> | Set HS B4  | 2-37 |
| 3FC8 <sub>hex</sub> | Set HS A7             | 2-37 | 3FFE <sub>hex</sub> | Set HS B12 | 2-37 |

Table 2-6 Write register addresses in the MPM

 Table 2-7
 Read register addresses in the MPM

| Address             | Register          | Page | Address             | Register             | Page |
|---------------------|-------------------|------|---------------------|----------------------|------|
| 3F90 <sub>hex</sub> | MPM configuration | 2-26 | 3FB2 <sub>hex</sub> | Status SysFail       | 2-32 |
| 3F98 <sub>hex</sub> | Read memory page  | 2-43 | 3FB4 <sub>hex</sub> | Status node SG inf   | 2-40 |
| 3FA2 <sub>hex</sub> | RDY bits          | 2-46 | 3FB6 <sub>hex</sub> | Status register 2    | 2-29 |
| 3FA4 <sub>hex</sub> | Serial data       | 2-44 | 3FC0 <sub>hex</sub> | Handshake register A | 2-35 |
| 3FB0 <sub>hex</sub> | Status register 1 | 2-27 | 3FC2 <sub>hex</sub> | Handshake register B | 2-35 |



## 2.3.4.1 MPM Configuration Register

The MPM configuration register enables the nodes to read the board configuration. The register contains information about the size of the MPM and the status of the nodes.



Figure 2-17 Bit assignment for the MPM configuration register (address 3F90<sub>hex</sub>)

MPM\_Size

Bits 14 and 15 in the MPM configuration register indicate the size of the SRAM available for the MPM:

Table 2-8Setting the MPM size

| Address Area | Bit 14 | Bit 15 |
|--------------|--------|--------|
| 16 kbytes    | 0      | 0      |
| 64 kbytes    | 0      | 1      |
| 256 kbytes   | 1      | 0      |
| 512 kbytes   | 1      | 1      |

MPM\_Node\_Par\_-Ready\_x The *MPM\_Node\_Ready\_x* bit indicates that the node has successfully completed its selftest (bit = 1: selftest successful). These bits are set by the nodes by writing the value  $8000_{hex}$  to the set MPM node ready x register and reset with the value  $0000_{hex}$ .



#### 2.3.4.2 Status Register 1

Status register 1 contains information about the status of the individual nodes. It contains four bits for each node:

| Node 0: | Bit 12 - bit 15 |
|---------|-----------------|
| Node 1: | Bit 8 - bit 11  |
| Node 2: | Bit 4 - bit 7   |
| Node 3: | Bit 0 - bit 3   |



MPM\_Node\_Ready\_x The MPM\_Node\_Ready\_x bit indicates that the node has successfully
completed its selftest (bit = 1: selftest successful). These bits are set by the
nodes by writing the value 8000<sub>hex</sub> to the set MPM node ready x register
and reset with the value 0000<sub>hex</sub>.

6189A

**DPHŒNIX** CONTACT

HS\_Int\_x Setting the HS\_Int\_x bit in status register 1 indicates to the node that there is a message ready for it in the MPM (see Section 4, "Communication via the Mailbox Interface"). The bit can be used in polling mode or in an interrupt routine to locate the cause of the interrupt more precisely and is a summary of the handshake bits for the node.

Sys\_Fail\_x The Sys\_Fail\_x bit is used to indicate a serious malfunction of a node. The Sys\_Fail\_x bit is set by the hardware or the set SysFail register and has to . system er. . ot indicate the s be reset by the nodes by writing the value 0000<sub>hex</sub> to the clear status SysFail x registers. The status SysFail register can be used to determine



The Sys\_Fail\_x bits do not indicate the status of the line that has initiated



#### 2.3.4.3 Status Register 2

Status register 2 contains additional information about the status of the individual nodes. For each node, four bits are provided in the register:

| Node 0: | Bit 12 - bit 15 |
|---------|-----------------|
| Node 1: | Bit 8 - bit 11  |
| Node 2: | Bit 4 - bit 7   |
| Node 3: | Bit 0 - bit 3   |



Figure 2-19 Bit assignment for status register 2 (address 3FB6hex)

Sync\_Req\_x

Setting the  $Sync\_Req\_x$  bit (bit = 1) in status register 2 indicates that the sync interrupt has been generated for the associated node. It is not possible to determine which node has caused the sync interrupt. The sync\\_req bit is reset by writing set bit 14 to the clear status bit register. Each node can only clear its own bit, i.e., node 1, for example, can only reset the  $Sync\_Req\_1$  bit.





### 2.3.4.4 The Set MPM Node Ready x Register

Writing the value  $8000_{hex}$  (most significant bit = 1) to a Set MPM node ready x register sets the corresponding *MPM\_Node\_Ready\_x* bit in MPM status register 1. The bit is reset by writing the value  $0000_{hex}$  (most significant bit = 0) to the register. By setting the bit, the node signals that it is ready to operate. Each node has its own set MPM node ready x register.



Figure 2-20 Bit assignment for the set MPM node ready x register

| Address             | Register             |
|---------------------|----------------------|
| 3FB8 <sub>hex</sub> | Set MPM node ready 0 |
| 3FBA <sub>hex</sub> | Set MPM node ready1  |
| 3FBC <sub>hex</sub> | Set MPM node ready2  |
| 3FBE <sub>hex</sub> | Set MPM node ready3  |
|                     |                      |

#### Table 2-9The set MPM node ready x register addresses

#### 2.3.4.5 The Set MPM Node Par Ready x Register

After successful parameterization, a node sets the corresponding *MPM\_Node\_Par\_Ready\_x* bit in the MPM configuration register. This is achieved by writing a value with a set most significant bit, e.g., the value 8000<sub>hex</sub>, to the set MPM node par ready x register. Writing a reset bit 15 (bit = 0) to the register also resets the corresponding *MPM\_Node\_Par\_Ready\_x* bit in the MPM configuration register. Each node has its own register, which corresponds to the node number (for example, node 1 uses the set MPM node par ready 1 register).



#### Figure 2-21 Bit assignment for the set MPM node par ready x register

| Address             | Register                 |
|---------------------|--------------------------|
| 3F90 <sub>hex</sub> | Set MPM node par ready 0 |
| 3F92 <sub>hex</sub> | Set MPM node par ready 1 |
| 3F94 <sub>hex</sub> | Set MPM node par ready 2 |
| 3F96 <sub>hex</sub> | Set MPM node par ready 3 |
|                     |                          |

Table 2-10 The set MPM node par ready x register addresses

**PHŒNIX** CONTACT

### 2.3.4.6 Status SysFail Register

The status SysFail register can be used to determine which node has signaled a system error (bit = 1: node system error). The bits in the register correspond to the status of the corresponding SysFail line.



#### 2.3.4.7 The Set SysFail Request Register

The SysFail signal can be generated in two different ways: a hardware signal to the MPM control logic or the software writing to the set SysFail request register. As with other registers, writing with bit 15 (the most significant bit) set initiates the signal. This generates a SysFail interrupt on all other nodes.





#### 2.3.4.8 The Clear Status Bit x Registers

The clear status bit x registers are used to reset certain signals sent between the nodes. Each node has its own clear status bit x register, i.e., for a complete MPM there are four clear status bit x registers.





| Address             | Register           |  |
|---------------------|--------------------|--|
| 3FA8 <sub>hex</sub> | Clear status bit 0 |  |
| 3FAA <sub>hex</sub> | Clear status bit 1 |  |
| 3FAC <sub>hex</sub> | Clear status bit 2 |  |

Clear status bit 3

Table 2-11 Clear status bit x register addresses

As can be seen in Figure 2-24, the following signals can be reset using the clear status bit x register:

MPM timeout

3FAE<sub>hex</sub>

- Sync signal
- Status SysFail signal

For each signal to be reset, enter a "1" in the corresponding bit position. This enables the signals to be reset individually or simultaneously.



#### 2.3.4.9 Handshake Register A and Handshake Register B

32 handshake bits are defined for exchanging acknowledged messages between the nodes. The handshake bits are used by the mailbox handshake protocol for sending, receiving, and acknowledging messages between the nodes.

By evaluating handshake registers A and B, a node can determine which other node has caused which handshake interrupt (see also Section 4, "Communication via the Mailbox Interface").



Handshake register A

Figure 2-25 Bit assignment for handshake register A (address 3FC0<sub>hex</sub>)





Figure 2-26 Bit assignment for handshake register B (address 3FC2<sub>hex</sub>)



minecon

### 2.3.4.10 The Set HS Ax Register and the Set HS Bx Register

These 32 registers are used for implementing the mailbox handshake protocol. The assignment and meaning of the registers are described in detail in the mailbox handshake protocol. Writing set bit 15 (bit = 1) to a set HS Ax/Bx register activates an interrupt at the corresponding node, the  $HS\_INT\_x$  bit in status register 1 changes to "1", and the associated bit is set in one of the two handshake registers. Writing reset bit 15 (bit = 0) to a set HS Ax/Bx register resets the associated bit in the handshake register and terminates the interrupt request.



Figure 2-27 Bit assignment for the set HS Ax register and set HS register

| Table 2-12 | The set HS Ax registe | r and the set HS | Bx register | addresses |
|------------|-----------------------|------------------|-------------|-----------|
|            |                       |                  |             |           |

| Address             | Register   | Address             | Register   | Address             | Register   | Address             | Register   |
|---------------------|------------|---------------------|------------|---------------------|------------|---------------------|------------|
| 3FC0 <sub>hex</sub> | Set HS A3  | 3FD0 <sub>hex</sub> | Set HS A2  | 3FE0 <sub>hex</sub> | Set HS A1  | 3FF0 <sub>hex</sub> | Set HS A0  |
| 3FC2 <sub>hex</sub> | Set HS A11 | 3FD2 <sub>hex</sub> | Set HS A10 | 3FE2 <sub>hex</sub> | Set HS A9  | 3FF2 <sub>hex</sub> | Set HS A8  |
| 3FC4 <sub>hex</sub> | Set HS B3  | 3FD4 <sub>hex</sub> | Set HS B2  | 3FE4 <sub>hex</sub> | Set HS B1  | 3FF4 <sub>hex</sub> | Set HS B0  |
| 3FC6 <sub>hex</sub> | Set HS B11 | 3FD6 <sub>hex</sub> | Set HS B10 | 3FE6 <sub>hex</sub> | Set HS B9  | 3FF6 <sub>hex</sub> | Set HS B8  |
| 3FC8 <sub>hex</sub> | Set HS A7  | 3FD8 <sub>hex</sub> | Set HS A6  | 3FE8 <sub>hex</sub> | Set HS A5  | 3FF8 <sub>hex</sub> | Set HS A4  |
| 3FCA <sub>hex</sub> | Set HS A15 | 3FDA <sub>hex</sub> | Set HS A14 | 3FEA <sub>hex</sub> | Set HS A13 | 3FFA <sub>hex</sub> | Set HS A12 |
| 3FCC <sub>hex</sub> | Set HS B7  | 3FDC <sub>hex</sub> | Set HS B6  | 3FEC <sub>hex</sub> | Set HS B5  | 3FFC <sub>hex</sub> | Set HS B4  |
| 3FCE <sub>hex</sub> | Set HS B15 | 3FDE <sub>hex</sub> | Set HS B14 | 3FEE <sub>hex</sub> | Set HS B13 | 3FFE <sub>hex</sub> | Set HS B12 |



# 2.3.4.11 The Set MPM Node SG Int x Register

The set MPM node SG int x registers can be used to send a signal (interrupt) to any other nodes. The meaning of this signal is left entirely to the user. Each node has its own register, which corresponds to the node number (for example, node 1 uses the set MPM node par ready 1 register).



Figure 2-28 Bit assignment for the set MPM node SG int x register

| Address             | Register              |  |
|---------------------|-----------------------|--|
| 3FB0 <sub>hex</sub> | Set MPM node SG int 0 |  |
| 3FB2 <sub>hex</sub> | Set MPM node SG int 1 |  |
| 3FB4 <sub>hex</sub> | Set MPM node SG int 2 |  |
| 3FB6 <sub>hex</sub> | Set MPM node SG int 3 |  |

Table 2-13The set MPM node SG int x register addresses

The nodes to which a signal is to be sent are selected by the bit pattern written to the register. A set bit (bit = 1) activates an interrupt at the corresponding node and sets the associated bit in the status node SG inf register (see also Section 2.3.4.12, "Status Node SG Inf Register"). A signal can be sent to one or more nodes simultaneously.

The bits in the status node SG int x register are reset and the interrupt request cleared by writing a reset bit (bit = 0) to the bit position of the required node.



| Bit        | Function Executed       |  |
|------------|-------------------------|--|
| Bit 15 = 1 | Signal to node 0        |  |
| Bit 14 = 1 | Signal to node 1        |  |
| Bit 13 = 1 | Signal to node 2        |  |
| Bit 12 = 1 | Signal to node 3        |  |
| Bit 15 = 0 | Delete signal to node 0 |  |
| Bit 14 = 0 | Delete signal to node 1 |  |
| Bit 13 = 0 | Delete signal to node 2 |  |
| Bit 12 = 0 | Delete signal to node 3 |  |

Table 2-14 Assignment of register bits to nodes



A node cannot send a signal to itself.



# 2.3.4.12 Status Node SG Inf Register

The status node SG inf register (status node signal interface register), can be used to determine from the bit(s) set which node has sent the MPM node SG int signal to which other node(s).



B

In Figure 2-29 the data bits are "Node SG int x y", where "y" designates the originator and "x" the receiver of the MPM node SG int signal.



#### 2.3.4.13 The Set Sync Register

The set sync register can be used to send a further signal (interrupt) to any other nodes. The meaning of this signal is left entirely to the user. One possible application, as implied by the name, is synchronization during data exchange between the nodes. (In firmware version 4.x this signal is already used for synchronous mode.) In addition to activating an interrupt, the corresponding *Sync\_Req\_x* bits in status register 2 are set. The *Sync\_Req\_x* bits in status register 2 are reset using the clear status bit x registers.



There is only one register of this type in the MPM. The nodes are, therefore, always accessed through the same register.



The set sync register

Figure 2-30 Bit assignment for the set sync register (address 3F9C<sub>hex</sub>)

#### Set\_Sync\_Req

Setting this bit to "1" causes the sync signal (interrupt) to be sent to the nodes according to the sync req bit mask set. The *Set\_Sync\_Req* bit can be set at the same time as the selection bit pattern, i.e., one write access to the register is sufficient. When the signal is initiated the *Set\_Sync\_Req* bit is automatically withdrawn, whereas the selection mask (bit 15 - bit 12) remains unchanged.



**Sync\_Req\_Bit\_x** The nodes to which a signal is to be sent are selected by the bit pattern in the four most significant bits of the register. A set bit (bit = 1) activates a sync interrupt at the corresponding node and sets the associated bit in status register 2 (see also Section 2.3.4.3). A signal can be sent to one or more nodes simultaneously.

| Bit        | Function Executed |
|------------|-------------------|
| Bit 12 = 1 | Signal to node 0  |
| Bit 13 = 1 | Signal to node 1  |
| Bit 14 = 1 | Signal to node 2  |
| Bit 15 = 1 | Signal to node 3  |

| Table 2-15 | Assignment of the sync req bits to the nodes |
|------------|----------------------------------------------|
|            |                                              |

#### 2.3.4.14 The Switch Memory Register

The MPM address area above FFFF<sub>hex</sub> can be switched between several pages. The switch memory register is used to specify which page is displayed. The pages can be displayed by each node independently of the other nodes. Thus, for example, node 1 can display page 3, while node 0 works with page 0. It is possible to select from a maximum of 256 pages. The number of pages depends on the controller board.





The function decoder is also displayed using the switch memory register.



#### 2.3.4.15 The Read Memory Page Register

As described above, the MPM address area above  $\text{FFFF}_{hex}$  can be switched between several pages. For each node, the read memory page register indicates which page is currently displayed. Each individual node can display different pages. Thus, for example, node 1 can display page 3, while node 0 works with page 0.



#### 2.3.4.16 Serial Address Register

The serial address register is a write register. The register contains the address for the next serial access. It can be an EEPROM or serial IN/OUT address. The address is entered as a byte address. When accessing the serial EEPROM the least significant address bit (0) is not evaluated, as EEPROM data exchange is word-oriented. However, byte addresses are always used for serial IN or serial OUT access.



(address 3FA6<sub>hex</sub>)

6189A

CONTACT

The following serial address registers are available:

| Table 2-16 | Serial address register |
|------------|-------------------------|
|------------|-------------------------|

| Address             | Register           | Page |
|---------------------|--------------------|------|
| 0002 <sub>hex</sub> | Configuration data | 2-46 |



Only the register address is entered in the serial address register. The value of the register entered in the serial address register is given in the serial data register (see page 2-44).

## 2.3.4.17 Serial Data Register

The serial data register is used for both write and read access to the MPM serial channel. It is, therefore, a read/write register. The register contains either the data to be written or the data that has been read. All 16 bits are valid when accessing the serial EEPROM. However, when serial IN or serial OUT is accessed, only the low-order byte (bit 0 to bit 7) is valid.



Figure 2-34 Bit assignment for the serial data register (address 3FA4<sub>hex</sub>)

#### 2.3.4.18 The Program Bits Register

The program bits register is a write register whose four most significant bits indicate how the serial data channel is to be accessed.



Figure 2-35 Bit assignment for the program bits register (address  $3FA2_{hex}$ )

| Bit        | Function Executed        |
|------------|--------------------------|
| Bit 15 = 1 | Read data from serial IN |
| Bit 14 = 1 | Write data to serial OUT |
| Bit 13 = 1 | Read data from EEPROM    |
| Bit 12 = 1 | Write data to EEPROM     |



Several bits can be set simultaneously. In this case, the individual accesses are processed according to a specified **priority list**:

- 1. Read serial IN (highest priority)
- 2. Read EEPROM
- 3. Write EEPROM
- 4. Write serial OUT (lowest priority)



#### 2.3.4.19 Ready Bits Register

The ready bits register is a read register whose bits indicate which accesses to the MPM serial interface (for example, serial EEPROM) have been completed. A distinction is made between access to the EEPROM and access to the serial IN/OUT interface. Each set bit (bit = 1) indicates that the access has been completed.



Figure 2-36 Bit assignment for the ready bits register (address 3FA2<sub>hex</sub>)

#### 2.3.4.20 Configuration Data Register

Information about which nodes are present can be obtained by reading the serial IN data channel. Information about the current system configuration can be found at address 2 in the serial IN data channel.







| Write_Protected        | Indicates whether write protection is activated on a memory card.                                                                               |                                                                                       |              |       |       |       |  |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------|-------|-------|-------|--|
|                        | Bit 1 = 1:                                                                                                                                      | Write protection active                                                               |              |       |       |       |  |
|                        | Bit 1 = 0:                                                                                                                                      | Write protection deactivated                                                          |              |       |       |       |  |
| Ready/busy             | Indicates wh                                                                                                                                    | hether a write access to a memory card has been completed.                            |              |       |       |       |  |
|                        | Bit 2 = 1:                                                                                                                                      | Access                                                                                | completed (F | RDY)  |       |       |  |
|                        | Bit 2 = 0:                                                                                                                                      | Access not yet completed (BSY)                                                        |              |       |       |       |  |
| EEPROM_Card<br>Present |                                                                                                                                                 | ndicates whether there is a memory card (EEPROM, Flash, etc.) on the ontroller board. |              |       |       |       |  |
|                        | Bit 3 = 1:                                                                                                                                      | Bit 3 = 1: No memory card present                                                     |              |       |       |       |  |
|                        | Bit 3 = 0:                                                                                                                                      | Memory card present                                                                   |              |       |       |       |  |
| Board_Present_x        | These four bits indicate which nodes are present. A deleted bit indicates that the relevant node is available.<br>Table 2-18 Board present bits |                                                                                       |              |       |       |       |  |
|                        | Node<br>0                                                                                                                                       |                                                                                       | Bit 7        | Bit 6 | Bit 5 | Bit 4 |  |
|                        |                                                                                                                                                 |                                                                                       | 0            | х     | х     | Х     |  |
|                        | 1                                                                                                                                               |                                                                                       | Х            | 0     | Х     | Х     |  |
|                        | 2                                                                                                                                               |                                                                                       | Х            | х     | 0     | Х     |  |
|                        | 3                                                                                                                                               |                                                                                       | Х            | Х     | Х     | 0     |  |
|                        |                                                                                                                                                 |                                                                                       |              |       |       |       |  |



# 2.3.5 MPM Software Register

In addition to the hardware registers, the MPM contains a series of software registers, whose meaning and function are closely related to the INTERBUS master and the mailbox handshake protocol. The number and location of these registers are not predetermined by the hardware, but are managed by the INTERBUS master.

Information about the available registers and their locations is stored in the MPM descriptor, which is created for each node.

Information about the following classifications is stored in the MPM descriptor:

- Data Area (DTA)
- Extended Data Area (ExDTA)
- Mailbox Area (MXA)
- Send vector and acknowledge vector registers

**Data area** Each node has a data area, which it uses to exchange data with the other nodes without using a protocol. The start address and length of the node data area are specified in the MPM descriptor. Here, each node can also find the start addresses of the data areas for other nodes to which it has read access here.

- **Extended data area** The extended data area is similar in structure to the "standard" data area. The entries in the MPM descriptor for the extended data area also contain information about its start address and its length.
- Mailbox area The entries relating to the mailbox area also contain information about its start address in the MPM and its length. They do not contain any information about the division of the mailbox area into individual mailboxes. This division is left entirely to the user or creator of the device driver.

Send vector and acknowledge vector registers A total of eight registers are assigned to each node: four send vector registers and four acknowledge vector registers. Each node has its own register at different addresses. The addresses of the send vector and acknowledge vector registers are entered in the MPM descriptor. These defaults are obligatory and must not be changed by the user.

**Sub node register** The sub node can be used for additional addressing of various applications of **one** node.



#### 2.3.5.1 Structure of the MPM Descriptor

The MPM descriptor is generated by the MPM manager for every node and is stored in the MPM. Each node uses its slot number to determine where its valid MPM descriptor is stored.

Address of the MPM descriptor for node 0:  $3200_{hex}$  + (node no. \*  $320_{hex}$ ) +  $240_{hex}$ 

Address of the MPM descriptor for nodes 1, 2, and 3:  $3200_{hex}$  + (node no. \*  $320_{hex}$ ) +  $26A_{hex}$ 

This equation can be used for each node to calculate and evaluate the address of the MPM descriptor. This task is generally carried out by the device driver during initialization.

#### Start Addresses of the MPM Descriptor for the Nodes:

- Node 0: 3440<sub>hex</sub>
- Node 1: 378A<sub>hex</sub>
- Node 2: 3AAA<sub>hex</sub>
- Node 3: 3DCA<sub>hex</sub>



The application program (host CPU) is defined as node 0 for IBS PCI controller boards. The INTERBUS master is implemented as node 1.



#### Implementation of the MPM Descriptor:

```
typedef struct {
                                      /* Start address of the data area
                                                                                */
     USIGN16
                startAddrDTA;
                                      /* Length of the data area in bytes
                                                                                */
     USIGN16 lengthDTA;
                                      /* Start address of the extended data area
                                                                                */
     USIGN16 startAddrExDTA;
                                      /* Length of the extended data area in bytes
                                                                                */
     USIGN16 lengthExDTA;
                                      /* Start address of the mailbox area
                                                                                */
     USIGN16 startAddrMXA;
                                      /* Length of the mailbox area in bytes
                                                                                */
     USIGN16
                lengthMXA;
     T DTA ENTRY DATA[2][4]
                                      /* Division of the data area
                                                                                */
                                      /* Addresses of the send vector registers
                                                                                */
     USIGN16
                SVR[2][4];
                                      /* Addresses of the acknowledge vector registers
     USIGN16
                AVR[2][4];
                                      */
                                      /* Addresses of the subnode registers
                                                                                */
     USIGN16
                SNR[2][4];
} T NODE INFO;
typedef struct {
                                      /* Start address of a DTA subrange
                                                                                */
     USIGN16
                startAddrDTA;
                                      /* Length of a DTA subrange
                                                                                */
     USIGN16
               lengthDTA;
} T_DTA_ENTRY;
```



The MPM descriptor only contains the start addresses (offsets) of the different areas and vector registers.

# MPM Descriptor Node 0 (3440hex):

| star<br>star<br>data<br>data | tAddrDTA<br>tAddrExDTA<br>tAddrMXA<br>[0][0] startAd<br>[0][1] startAd<br>[0][2] startAd | 5C00<br>4000<br>drDTA<br>drDTA | 0000 -> length 1024                             |
|------------------------------|------------------------------------------------------------------------------------------|--------------------------------|-------------------------------------------------|
| data                         | [0][3] startAd                                                                           | ldrDTA                         | 0000 -> length 1024                             |
|                              | [1][0] startAd<br>[1][1] startAd                                                         |                                |                                                 |
|                              | [1][2] startAd                                                                           |                                | 5                                               |
|                              | [1][3] startAd<br>Node                                                                   | ldrDTA<br>0                    | <u> </u>                                        |
| /                            |                                                                                          | 0000                           | 342A 342C 0000<br>/* SVR sending nodes 0-3 */   |
| svr[                         | 1][0-3] ->                                                                               |                                | 3772 3A92 0000<br>/* SVR receiving nodes 0-3 */ |
| avr[                         | 0][0-3] ->                                                                               |                                | 3432 3434 0000<br>/* AVR sending nodes 0-3 */   |
| avr[                         | 1][0-3] ->                                                                               |                                | 377A 3A9A 0000<br>/* AVR receiving nodes 0-3 */ |
| snr[                         | 0][0-3] ->                                                                               |                                | 343A 343C 0000<br>/* SNR sending nodes 0-3 */   |
| snr[                         | 1][0-3] ->                                                                               |                                | 3782 3AA2 0000<br>/* SNR receiving nodes 0-3 */ |
|                              |                                                                                          |                                |                                                 |



MPM Descriptor Node 1 (378Ahex):

1000 -> length 1024 startAddrDTA startAddrExDTA 8C00 -> length 5120 7000 -> length 7168 startAddrMXA 1000 -> length 0000 data[0][0] startAddrDTA data[0][1] startAddrDTA FFFF -> length 1024 data[0][2] startAddrDTA 0400 -> length 1024 data[0][3] startAddrDTA 1C00 -> length 1024 data[1][0] startAddrDTA 0000 -> length 0000 data[1][1] startAddrDTA FFFF -> length 1024 1400 -> length 1024 data[1][2] startAddrDTA 0C00 -> length 1024 data[1][3] startAddrDTA 3 /\* Node 0 1 2 \*/ svr[0][0-3] -> 3772 0000 37760000 /\* SVR sending nodes 0-3 \*/ svr[1][0-3] -> 342A 0000 3A94 0000 /\* SVR receiving nodes 0-3 \*/ avr[0][0-3] -> 377A 0000 377E 0000 /\* AVR sending nodes 0-3 \*/ avr[1][0-3] 3432 0000 3A9C 0000 -> /\* AVR receiving nodes 0-3 \*/ 3782 00003786 0000 snr[0][0-3] -> /\* SNR sending nodes 0-3 \*/ 343A 0000 3AA4 0000 snr[1][0-3] -> /\* SNR receiving nodes 0-3 \*/



#### Structure and Interfaces of INTERBUS Controller Boards

#### 2.3.5.2 DTA, Extended DTA, and MXA

For the data area, extended data area, and mailbox area, the start address and the length in bytes are indicated. Within these areas, the corresponding node has write access.

The data area is further subdivided into subranges set aside for communication with the other nodes. The location and number of these subranges are stored in the two-dimensional *Data* array.

| Array      | Assignment                 |
|------------|----------------------------|
| Data[0][0] | Data area node n to node 0 |
| Data[0][1] | Data area node n to node 1 |
| Data[0][2] | Data area node n to node 2 |
| Data[0][3] | Data area node n to node 3 |
|            |                            |
| Data[1][0] | Data area node 0 to node n |
| Data[1][1] | Data area node 1 to node n |
| Data[1][2] | Data area node 2 to node n |
| Data[1][3] | Data area node 3 to node n |

Table 2-19Assignment of the array elements



The extended data area is not further subdivided and it is fully available to the user. The mailbox area is also coherent, but should be divided by the user into several mailboxes. The recommended minimum mailbox size is 1 kbyte. However, division and management are left entirely to the user or the device driver.



#### 2.3.5.3 Send Vector Registers (SVR)

The send vector and acknowledge vector registers are software registers with a data word width of 16 bits. These registers are used for communication via the mailbox interface. The address (offset) of the MPM mailbox that contains the actual message is entered in the send vector register (SVR). The address is calculated as an offset, beginning with the starting point of the MPM (see also "MPM Address Area" on page 2-19).

Every node has an SVR for every other node (including for itself). This makes four SVRs per node.

The two-dimensional array contains both the addresses of the SVRs that the nodes use for sending and the addresses of the SVRs that the other nodes use for communication with it.

| Array     | Assignment           | Abbreviation |
|-----------|----------------------|--------------|
| SVR[0][0] | SVR node n to node 0 | SVR_n_0      |
| SVR[0][1] | SVR node n to node 1 | SVR_n_1      |
| SVR[0][2] | SVR node n to node 2 | SVR_n_2      |
| SVR[0][3] | SVR node n to node 3 | SVR_n_3      |
|           |                      |              |
| SVR[1][0] | SVR node 0 to node n | SVR_0_n      |
| SVR[1][1] | SVR node 1 to node n | SVR_1_n      |
| SVR[1][2] | SVR node 2 to node n | SVR_2_n      |
| SVR[1][3] | SVR node 3 to node n | SVR_3_n      |

Table 2-20 Assignment of the array elements for SVR[ ][ ]



The abbreviation SVR\_0\_1 therefore stands for a send vector register that is used to enable nodes 0 and 1 to communicate, in the direction from node 0 to node 1.



#### Structure and Interfaces of INTERBUS Controller Boards

#### 2.3.5.4 Acknowledge Vector Registers (AVR)

The acknowledge vector registers are also software registers with a data word width of 16 bits. These registers are used for communication via the mailbox interface. The AVR contains the address of a MPM mailbox that has been read by the communication partner and can therefore be re-enabled. Like the SVR, the address is a 16-bit offset, calculated in relation to the starting point of the MPM. Four AVRs are also available for each node.

The two-dimensional array contains both the addresses of the AVRs that the nodes use for sending and the addresses of the AVRs that the other nodes use for communication with it.

| Array     | Assignment           | Abbreviation |  |  |
|-----------|----------------------|--------------|--|--|
| AVR[0][0] | AVR node n to node 0 | AVR_n_0      |  |  |
| AVR[0][1] | AVR node n to node 1 | AVR_n_1      |  |  |
| AVR[0][2] | AVR node n to node 2 | AVR_n_2      |  |  |
| AVR[0][3] | AVR node n to node 3 | AVR_n_3      |  |  |
|           |                      |              |  |  |
| AVR[1][0] | AVR node 0 to node n | AVR_0_n      |  |  |
| AVR[1][1] | AVR node 1 to node n | AVR_1_n      |  |  |
| AVR[1][2] | AVR node 2 to node n | AVR_2_n      |  |  |
| AVR[1][3] | AVR node 3 to node n | AVR_3_n      |  |  |

 Table 2-21
 Assignment of the array elements for AVR[ ][ ]



The abbreviation AVR\_0\_1 therefore stands for an acknowledge vector register that is used to enable nodes 0 and 1 to communicate, in the direction from node 0 to node 1.

6189A



#### 2.3.5.5 Subnode Register (SNR)

Subnode registers are only required if, for example, an INTERBUS master and an INTERBUS slave operate on the same node (MPM slot). These registers then contain information about the controller board (INTERBUS master or INTERBUS slave) to which the message is to be sent.

Table 2-22 Assignment of the array elements for SNR[ ][ ]

| Array     | Assignment                                    | Abbreviation       |  |
|-----------|-----------------------------------------------|--------------------|--|
| SNR[0][0] | SNR node n to node 0                          | SNR_n_0            |  |
| SNR[0][1] | SNR node n to node 1                          | SNR_n_1            |  |
| SNR[0][2] | SNR node n to node 2                          | SNR_n_2            |  |
| SNR[0][3] | SNR node n to node 3                          | SNR_n_3            |  |
|           |                                               |                    |  |
| SNR[1][0] | SNR node 0 to node n                          | SNR_0_n            |  |
| SNR[1][1] | SNR node 1 to node n SNR_1_n                  |                    |  |
| SNR[1][2] | SNR node 2 to node n SNR_2_n                  |                    |  |
| SNR[1][3] | SNR node 3 to node n SNR_3_n                  |                    |  |
| <b>L</b>  | The subnode registers are not used on IBS PCI | controller boards. |  |





# Section 3

|                         |           | nforms you about<br>ange via the data area (DTA). |     |
|-------------------------|-----------|---------------------------------------------------|-----|
| Data Exchange via the D | )ata Area | a                                                 | 3-3 |
| 3.1                     | Opera     | ting Modes                                        |     |
|                         | 3.1.1     | Asynchronous Mode                                 |     |
|                         | 3.1.2     | Asynchronous Mode With Synchronization Pulse      | 3-5 |
|                         |           |                                                   |     |
|                         |           |                                                   |     |
|                         |           |                                                   |     |
|                         |           |                                                   |     |
|                         |           |                                                   |     |







minecomponents.com PHENIX

Data Exchange via the Data Area

## 3 Data Exchange via the Data Area

|           | The data area (DTA) is used to facilitate data exchange via the MPM. As<br>already mentioned, each node only has write permission within its data<br>area and extended data area, i.e., the sending node writes the data to a<br>certain area within its DTA and the receiving node reads the data from<br>there. To enable data to be exchanged independently between individual<br>nodes, the data area is divided into several subranges belonging<br>exclusively to a destination node. This segmentation is a software solution<br>and has no effect on the MPM hardware architecture. Each data area to a<br>different node is 1 kbyte. Also available is an extended data area, which the<br>user can implement as required. The MPM descriptor specifies the length<br>of this extended data area. |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Example 1 | Node 0 sends data via the DTA to node 1:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|           | <ol> <li>Node 0 writes the data to be sent to DTA area DTA Node 0 to Node 1,<br/>i.e., it starts entering the data at offset 0000<sub>hex</sub> (the offset address can<br/>be determined using the MPM descriptor).</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | <ol> <li>Starting at address 0000<sub>hex</sub>, node 1 reads the data from the DTA of<br/>node 0.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Example 2 | Data is sent from node 1 to node 0 in the following sequence:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|           | <ol> <li>Node 1 writes the data to be sent to its DTA area<br/>DTA Node 1 to Node 0. Working from the start of the MPM, the start<br/>address is 1000<sub>hex</sub>.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|           | 2. Starting at MPM address 1000 <sub>hex</sub> , node 0 reads the data from the DTA of node 1 (the offset address can be determined using the MPM descriptor).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| R S       | As no hardware restrictions are used for data exchange via the DTA, there<br>is always a risk of simultaneous or overlapping read/write access to the<br>same memory location. This means that a data block is already being<br>overwritten by the other node during reading. The reading node, therefore,<br>might receive data from two different write cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                          |

6189A



Depending on the type of access (read or write), different areas (blocks) are accessed in the MPM. A write access always takes place in the area of the writing node, i.e., if node 0 wants to send data to node 2, it writes the data to its own area. If, however, data is to be read from a different node, access takes place in the corresponding block of the node that has stored the data there. This also enables a node to read its own DTA (see Figure 3-1).

"Asynchronous mode" is not supported by the driver for IBS PCI SC/... controller boards. "Asynchronous mode with synchronization pulse" is used here to prevent any data consistency problems (see Section "Operating Modes" on page 3-5)

Access options when reading from and writing to the DTA (node 0):



Figure 3-1 Read and write access to the DTA



Data Exchange via the Data Area

## 3.1 Operating Modes

### 3.1.1 Asynchronous Mode

Asynchronous to the INTERBUS data cycles, a node accesses the I/O data stored in the DTA. This means that a data block is already being overwritten by node 1 (master firmware) during reading (node n). The reading node, therefore, might receive data from two different write cycles, because data from the current INTERBUS data cycle and the previous data cycle can be accessed. This can result in an inconsistency in the read data. Consequently, this operating mode is not the standard operating mode for the controller board and driver. Figure 3-2 "Asynchronous access of the application to INTERBUS data" shows 2 critical points, which illustrate the problem of "simultaneous access".





### 3.1.2 Asynchronous Mode With Synchronization Pulse

Node 1 (master firmware) generates a synchronization pulse after the completion of the INTERBUS cycle. From this point on, INTERBUS process data can be transmitted consistently from, e.g., node 0. The next INTERBUS cycle is started by a synchronization pulse generated from node 0.



This operating mode is set as default by the master firmware and also supported by the driver. Using this operating mode, INTERBUS I/O data is consistently transmitted.

#### 3.1.2.1 Asynchronous With Synchronization Pulse (Implementation in the Driver)

3 buffers (IN and OUT) are implemented in the driver, which ensure that any access by an application, which is always asynchronous, is made to the most recent IN buffer and to the next free OUT buffer. The driver controls which buffer is made available to the application.





Figure 3-4 Asynchronous, consistent access of the application to INTERBUS data





shinecome



## Section 4

This section informs you about

- data exchange via the mailbox interface (MXI).







**Communication via the Mailbox Interface** 

## 4 Communication via the Mailbox Interface

All messages (including commands) are generally exchanged between the individual nodes via the mailbox interface (MXI). This involves a peer to peer exchange process. A message can be sent from any node to any other node.

The messages are transferred to mailboxes, each of which represents a memory area within the MPM. The structure of these messages corresponds to the mailbox syntax specified by the INTERBUS master.

To ensure messages are transmitted correctly, the hardware and software registers in the MPM are used to provide a handshake protocol. Both the presence of a message in a mailbox and a mailbox becoming free in the MPM are signaled to the other MPM nodes.

The following MPM registers are used during handshaking:

- Set HS Ax register and set HS Bx register (hardware registers)
- Handshake registers A and B (hardware registers)
- Status register (hardware register)
- Send vector register (software register)
- Acknowledge vector register (software register)

The 32 handshake registers are hardware registers displayed in the MPM address area (see also "Handshake Register A and Handshake Register B" on page 2-35 and "The Set HS Ax Register and the Set HS Bx Register" on page 2-37). A distinction is made between "Message present" and "Mailbox free" in these registers.



| $\square$ |              |              |     |       |        | De  | stinati | on |         |         |     |   |
|-----------|--------------|--------------|-----|-------|--------|-----|---------|----|---------|---------|-----|---|
|           | $\backslash$ |              |     |       |        | MPM | node    |    |         |         |     |   |
|           |              | $\backslash$ | 0   | 1     | 2      | 3   |         | 0  | 1       | 2       | 3   |   |
|           |              | 0            | A0  | A8    | B0     | B8  |         | A4 | A12     | B4      | B12 |   |
| Source    | e            | 1            | A1  | A9    | B1     | B9  |         | A5 | A13     | B5      | B13 |   |
| Sou       | node         | 2            | A2  | A10   | B2     | B10 |         | A6 | A14     | B6      | B14 |   |
|           | MPM          | 3            | A3  | A11   | B3     | B11 |         | A7 | A15     | B7      | B15 |   |
|           | Σ            |              | "Me | ssage | presen | t"  |         |    | "Mailbo | ox free |     |   |
|           |              |              |     |       |        |     |         |    |         |         |     | - |

Assignment of the individual bits of handshake registers A and B, and the 32 set HS Ax/Bx registers to the individual nodes and their meanings:

5802A029

Figure 4-1 Assignment of the handshake bits

#### Key for Figure 4-1:

| Source            | Node that wants to send a message                                    |
|-------------------|----------------------------------------------------------------------|
| Destination       | Node that should receive this message                                |
| "Message present" | Message ready in a mailbox                                           |
| "Mailbox free"    | Message has been read from the mailbox and the mailbox is free again |

| MPM status register | In status register 1, the <i>HS_Int_x</i> bits should be evaluated to determine which node has reported something. |
|---------------------|--------------------------------------------------------------------------------------------------------------------|
|                     |                                                                                                                    |

MPM handshake<br/>registers A and BHandshake registers A and B summarize the 32 set HS Ax/Bx registers.<br/>These two registers can be evaluated to precisely determine the node and<br/>the type of message ("Message present" or "Mailbox free"). The bits in the<br/>two registers also indicate whether a send vector register or an<br/>acknowledge vector register is occupied (bit = 1) or free (bit = 0).



#### **Communication via the Mailbox Interface**

| Send vector register<br>(SVR)        | The address (offset) of the MPM mailbox that contains the actual message is entered in the send vector register. The address is calculated as an offset, beginning with the starting point of the MPM (see also "Multi-Port Memory (MPM)" on page 2-16).                                                                         |
|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acknowledge vector<br>register (AVR) | The acknowledge vector register contains the address of the MPM mailbox<br>that has been read by the communication partner and can therefore be re-<br>enabled. Like the SVR, the address is a 16-bit offset, calculated in relation<br>to the starting point of the MPM. Four AVR registers are available for each<br>MPM node. |
|                                      | The process involved and the use of the different registers will now be explained in greater detail using two examples.                                                                                                                                                                                                          |
| Example 1                            | Send message from node 0 to node 1:                                                                                                                                                                                                                                                                                              |
|                                      | $\begin{array}{c} 1 \\ Bit HS_{A8} \\ \hline \\ Bit HS_{A5} \\ \hline \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ \\ $                                                                                                                                                                                                       |
|                                      |                                                                                                                                                                                                                                                                                                                                  |



The mailbox handshake protocol used for this has four significant events:

#### 1. "Message present":

Node 0 sets bit  $HS_A8$  (meaning: message present; source = node 0; destination = node 1). This indicates that there is a message from node 0 to node 1. Its address has been entered by node 0 in the relevant send vector register (SVR [0] [1]).

#### 2. "Message present detected":

Node 1 resets bit  $HS_A8$ . It has detected the presence of a message and read the mailbox address from the send vector register (SVR [0] [1]). The SVR can then be reused by node 0.

Resetting bit HS\_A8 does not mean that the mailbox is free.

#### 3. "Mailbox free":

Node 1 sets bit  $HS_A5$  (meaning: message free; source = node 1; destination = node 0). In this way, node 1 informs node 0 that it has read the message from the mailbox and the mailbox is now free. The mailbox address is in the acknowledge vector register (AVR [1] [0]).

#### 4. "Mailbox free detected":

Node 0 resets bit  $HS_A5$ . In this way, node 0 informs node 1 that the mailbox is free. At the same time node 1 recognizes that it can reuse the acknowledge vector register (AVR\_1\_0).

As explained above, the handshake bits are set by writing a data item with the most significant bit set (bit = 1) to the corresponding set HS Ax/Bx registers. Conversely, the handshake bits are reset by writing a data item with the most significant bit reset (bit = 0) to the corresponding set HS Ax/ Bx registers. Handshake registers A and B can be read to determine which handshake bits are set or reset.



Setting a handshake bit generally leads to an interrupt at the destination node. This offers the opportunity of enabling the mailboxes in an interrupt routine. The send vector registers can also be read within the interrupt routine.





#### **Communication via the Mailbox Interface**

|                                          | De | tailed Process for Transmitting a Message From Node 0 to Node 1:                                                                                                                                                                                                                                                             |
|------------------------------------------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Node 0                                   |    | Node 0 checks whether send vector register "SVR [0] [1]" is free. To do this it reads MPM handshake register A and checks whether bit $HS_A8$ is zero. If the bit is set, the SVR is occupied and cannot be used.                                                                                                            |
|                                          |    | The mailbox address (offset) is entered in the SVR in the MPM.                                                                                                                                                                                                                                                               |
|                                          | 3. | The value 8000 <sub>hex</sub> is written to the set HS A8 register (thereby initiating an interrupt at node 1).                                                                                                                                                                                                              |
| Node 1 (interrupt routine)               | 1. | Node 1 uses the set bit <i>HS_Int_1</i> in the MPM status register to detect that the cause of the interrupt is a mailbox handshake protocol interrupt.                                                                                                                                                                      |
|                                          | 2. | It reads handshake register A to determine which node initiated the interrupt. From the bit set there, <i>HS_A8</i> , the receiver (node 1) recognizes it as a message from node 0. At the same time it recognizes that a "Message present" event is involved (see also Figure 2-18 "Bit assignment for status register 1"). |
|                                          | 3. | Node 1 determines the SVR address of the sender (SVR [0] [1]), reads<br>the register and "notes" its contents, which represent the address of the<br>mailbox with the message. (The address is in Motorola format.)                                                                                                          |
|                                          | 4. | It resets the bit in handshake register A by writing the value $0000_{hex}$ to the set HS A8 register.                                                                                                                                                                                                                       |
|                                          | 5. | Having "noted" its address, the receiver (node 1) can now read the mailbox. As soon as the message has been copied from the mailbox, it should inform the sender (node 0) that the mailbox is free and can be reused.                                                                                                        |
| Node 1 (routine for reading the message) | 1. | Node 1 determines whether the acknowledge vector register is free. To do this it reads handshake register A and checks whether bit $HS_A5$ is zero. If it is not, it waits until bit $HS_A5$ has been reset or outputs an error message. Otherwise, it continues with step 2.                                                |
| 0                                        | 2. | Node 1 enters the mailbox address in the AVR (AVR [1] [0]) from which the message has been read.                                                                                                                                                                                                                             |
|                                          | 3. | Node 1 writes the value $8000_{hex}$ to the set HS A5 register, initiating an interrupt at node 0. This indicates to node 0 that the mailbox is free again.                                                                                                                                                                  |
|                                          |    |                                                                                                                                                                                                                                                                                                                              |



| Node 0 (interrupt routine) | 1.              | Node 0 uses the set bit <i>HS_Int_0</i> in status register 1 to detect that the cause of the interrupt is a mailbox handshake protocol interrupt.                 |
|----------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | 2.              | It reads handshake register A to determine which node initiated the interrupt. At the same time it recognizes that a "Mailbox free" event is involved.            |
|                            | 3.              | Node 0 determines the AVR address of the receiver (AVR [1] [0]), reads the register and "notes" its contents (address of the mailbox that has become free again). |
|                            | 4.              | It resets the bit $HS_A5$ in handshake register A by writing the value $0000_{hex}$ to the set HS A5 register.                                                    |
|                            | 5.              | In its internal mailbox management system, it marks the mailbox as free.                                                                                          |
| Example 2:                 | Se              | nd message from node 1 to node 0:                                                                                                                                 |
|                            | B<br>Fig<br>The | $\frac{1}{2}$                                                                                                                                                     |



#### **Communication via the Mailbox Interface**

The mailbox handshake protocol used for this has four significant events:

1. "Message present":

Node 1 sets bit HS\_A1 (meaning: message present; source = node 1; destination = node 0). This indicates that there is a message from node 1 to node 0. Its address has been entered by node 1 in the relevant send vector register (SVR [1] [0]).

#### 2. "Message present detected":

Node 0 resets bit HS\_A1. It has detected the presence of a message and read the mailbox address from the send vector register (SVR [1] [0]). The SVR can then be reused by node 1. Resotting bit HS\_A1 does not mean that the mailbox is free

Resetting bit HS\_A1 does not mean that the mailbox is free.



Node 0 sets bit HS\_A12 (meaning: message free; source = node 0; destination = node 1). In this way, node 0 informs node 1 that it has read the message from the mailbox and the mailbox is now free. The mailbox address is in the acknowledge vector register (AVR [0] [1]).

#### 4. "Mailbox free detected":

Node 1 resets bit HS\_A12. In this way, node 1 informs node 0 that the mailbox is free. At the same time node 0 recognizes that it can reuse the acknowledge vector register (AVR [0] [1]).

As explained above, the handshake bits are set by writing a data item with the most significant bit set (bit = 1) to the corresponding set HS Ax/Bx registers. Conversely, the handshake bits are reset by writing a data item with the most significant bit reset (bit = 0) to the corresponding set HS Ax/ Bx registers. Handshake registers A and B can be read to determine which handshake bits are set or reset.



Setting a handshake bit leads to an interrupt at the destination node. This offers the opportunity of enabling the mailboxes in an interrupt routine. The send vector registers can also be read within the interrupt routine.

PHENIX



|                                          | De | etailed Process for Transmitting a Message From Node 1 to Node 0:                                                                                                                                                                                                                          |
|------------------------------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Node 1                                   | 1. | Node 1 checks whether the send vector register SVR [1] [0] is free. To do this it reads MPM handshake register A and checks whether bit HS_A1 is zero. If the bit is set, the SVR is occupied and cannot be used.                                                                          |
|                                          | 2. | The mailbox address (offset) is entered in the SVR in the MPM.                                                                                                                                                                                                                             |
|                                          | 3. | The value 8000hex is written to the set HS A1 register (thereby initiating an interrupt at node 1).                                                                                                                                                                                        |
| Node 0 (interrupt routine)               | 1. | Node 0 uses the set bit HS_Int_0 in MPM status register 1 to detect that the cause of the interrupt is a mailbox handshake protocol interrupt.                                                                                                                                             |
|                                          | 2. | It reads handshake register A to determine which node initiated the interrupt. From the bit set there, HS_A1, the receiver (node 0) recognizes it as a message from node 1. At the same time it recognizes that a "Message present" event is involved (see also Figure 2-18 on page 2-27). |
|                                          | 3. | Node 0 determines the SVR address of the sender (SVR [1] [0]), reads<br>the register and "notes" its contents, which represent the address of the<br>mailbox with the message. (The address is in Motorola format.)                                                                        |
|                                          | 4. | It resets the bit in handshake register A by writing the value 0000hex to the set HS A1 register.                                                                                                                                                                                          |
|                                          | 5. | Having "noted" its address, the receiver (node 0) can now read the mailbox. As soon as the message has been copied from the mailbox, it must inform the sender (node 1) that the mailbox is free and can be reused.                                                                        |
| Node 0 (routine for reading the message) | 1. | Node 0 determines whether the acknowledge vector register is free. To do this it reads handshake register A and checks whether bit HS_A12 is zero. If it is not, it waits until bit HS_A12 has been reset or outputs an error message. Otherwise, it continues with step 2.                |
|                                          | 2. | Node 0 enters the mailbox address in the AVR (AVR [0] [1]) from which the message has been read.                                                                                                                                                                                           |
|                                          | 3. | Node 0 writes the value 8000hex to the set HS A12 register, initiating an interrupt at node 1. This indicates to node 1 that the mailbox is free again.                                                                                                                                    |



#### **Communication via the Mailbox Interface**

| Node 1 (interrupt<br>routine) | 1.<br>2.               | Node 1 uses the set bit HS_Int_1 in status register 1 to detect that the cause of the interrupt is a mailbox handshake protocol interrupt.<br>It reads handshake register A to determine which node initiated the interrupt. At the same time it recognizes that a "Mailbox free" event is involved.                                                                                              |  |  |
|-------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                               | 3.                     | Node 1 determines the AVR address of the receiver (AVR [0] [1]), reads<br>the register and "buffers" its contents (address of the mailbox that has<br>become free again).                                                                                                                                                                                                                         |  |  |
|                               | 4.                     | It resets bit HS_A12 in handshake register A by writing the value 0000hex to the set HS A12 register.                                                                                                                                                                                                                                                                                             |  |  |
|                               | 5.                     | In its internal mailbox management system, it marks the mailbox as free.                                                                                                                                                                                                                                                                                                                          |  |  |
|                               | Ti                     | ps and Notes                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                               | be<br>firs<br>re<br>ph | As the above examples show, the process of exchanging a message<br>between two nodes via the mailbox interface is split into two phases. In the<br>first, the receiver is informed that there is a message. In the second, the<br>receiver informs the sender that the mailbox used is free again. Each<br>phase requires its own set HS Ax/Bx, send vector, and acknowledge vector<br>registers. |  |  |
|                               | ca<br>the              | the two events do not have to be processed using interrupt routines. They<br>an also be detected by cyclically checking (polling) the status register and<br>be handshake registers. However, a solution with interrupts should be<br>aven preference, since it creates much less load on the system.                                                                                             |  |  |
|                               | re<br>als              | though the protocol may appear complex, it provides a faster and more<br>liable method of exchanging messages between the individual nodes. It<br>so enables the use of several mailboxes for each node, provided the<br>iver has functions for managing multiple mailboxes.                                                                                                                      |  |  |
|                               | Č                      |                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |



minecomponents.com

**TPHENIX** 

## Section 5

This section informs you about

- the basic structure of a device driver
- the creation of necessary functions.

| Architecture and Structure of a | Device Driver                                   | 5-3  |
|---------------------------------|-------------------------------------------------|------|
| 5.1 Gene                        | ral                                             | 5-3  |
| 5.2 Basic                       | Structure of the Driver                         | 5-4  |
| 5.3 Desc                        | ription of Functions                            | 5-8  |
| 5.3.1                           | Initialization (initBoard)                      | 5-10 |
| 5.3.2                           | Open Data Channel (openDevice)                  | 5-11 |
| 5.3.3                           | Close Data Channel (closeDevice)                | 5-12 |
| 5.3.4                           | Write Process Data (writeDTI)                   | 5-13 |
| 5.3.5                           | Read Process Data (readDTI)                     | 5-14 |
| 5.3.6                           | Send Message (writeMXI)                         | 5-15 |
| 5.3.7                           | Read Message (readMXI)                          | 5-16 |
| 5.3.8                           | Interrupt Service Routine (intrServiceFunction) | 5-18 |
| 5.3.9                           | Device IO Control (devIOCtrl)                   | 5-19 |
| 5.3.1                           | 0 Utilities                                     | 5-21 |
| 5.3.1                           | 1 Data Structures Used                          | 5-29 |
|                                 |                                                 |      |





DPHŒNIX CONTACT

6189A

Architecture and Structure of a Device Driver

## 5 Architecture and Structure of a Device Driver

The previous sections only describe the hardware used. In the following, the basic structure of the driver software for the IBS PCI controller boards will be described with reference to examples. The resulting interface corresponds to the specified device driver interface (DDI).

### 5.1 General

To cover the range of driver applications, the description of the device driver for the IBS PCI controller boards is simplified by limiting it to reading and writing data using the relevant protocol. If possible, the parameters transferred are also checked for validity and plausibility. The structure and design of the device driver interface enable relatively problem-free porting to different operating systems. Device drivers for various operating systems have already been created using the basic structure described below. Each of these drivers has the same interface conforming to the DDI specification, and is supplemented by some additional functions for the particular operating system. However, the basic functions are always identical, thus enabling the easy porting of application programs.

The basic tasks of a driver can be defined as follows:

- Initializing the INTERBUS controller board
- Reading and writing data
- Using the mailbox to send and receive messages (services)
- Checking the validity and plausibility of the parameters transferred
- Transferring INTERBUS diagnostic data to the application program.



### 5.2 Basic Structure of the Driver

A device driver for the INTERBUS controller boards for all operating systems supported by Phoenix Contact is based on seven elementary functions:

- DDI\_DevOpenNode (openDevice)
- DDI\_DevCloseNode (closeDevice)
- DDI\_DTI\_WriteData (writeDTI)
- DDI\_DTI\_ReadData (readDTI)
- DDI\_MXI\_SndMessage (writeMXI)
- DDI\_MXI\_RcvMessage (readMXI)
- DDI\_DevIOCtrl (devIOCtrl)

These functions are used to access all of the functions provided by the driver. The drivers in the core are accessed by the application program either directly via the DDI functions or via the standard "open", "close", "read", "write", and "devIOCtrl" operating system functions.

In addition to the above functions, the driver contains three important routines that are not directly accessible to the user.

- Init device driver routine (initDDI)
- Interrupt deferred routine (intrServiceFunction)
- Release device driver routine (releaseDDI)

The init device driver routine must be called when the driver is started or loaded. The interrupt service routine, however, implements an important part of the mailbox handshake protocol under interrupt control, but remains completely invisible to the user. The release device driver routine must be called when the driver is stopped.



#### Architecture and Structure of a Device Driver

| <u>User interface (DDI)</u> | Driver functions       |          |
|-----------------------------|------------------------|----------|
| DDI_DevOpenNode             | <br>openDevice         |          |
| DDI_DevCloseNode            | closeDevice            |          |
| DDI_DTI_ReadData            | <br>readDTI            |          |
| DDI_DTI_WriteData           | <br>writeDTI           |          |
| DDI_MXI_SndMessage          | writeMXI               |          |
| DDI_MXI_RcvMessage          | <br>readMXI            |          |
| DDI_SetMsgNotification      | <br>setMsgNotification |          |
| DDI_CIrMsgNotification      | <br>clrMsgNotification |          |
| DDI_DevIOCtrl               | <br>devIOCtrl          | 5802A031 |
|                             |                        | 3002A031 |

Figure 5-1 Integrating the device driver into any operating system

The device driver can be divided into two distinct parts:

- The actual driver with its functions for accessing the hardware (this part can be fully integrated into the core of the operating system)
- A small library for adapting the calls to the actual driver functions according to the DDI specification

Sullinect





When porting to operating systems such as UNIX, the library with the function calls according to the DDI specification can contain an adaptation to the standard calls ("open", "close", "read", "write", etc.) (see Figure 5-2).

#### Example of Integration Into an Operating System Such as UNIX

| User interface (DDI)                                                                                                                                          | Standard operating system functions                                                    | Driver functions                                                                                                                                                                                     |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| DDI_DevOpenNodeDDI_DevCloseNodeDDI_DTI_ReadDataDDI_DTI_WriteDataDDI_MXI_SndMessageDDI_MXI_RcvMessageDDI_SetMsgNotificationDDI_CIrMsgNotificationDDI_DevIOCtrl | open<br>close<br>read<br>write<br>write<br>read<br>devIOCtrl<br>devIOCtrl<br>devIOCtrl | <ul> <li>openDevice</li> <li>closeDevice</li> <li>readDTI</li> <li>writeDTI</li> <li>writeMXI</li> <li>readMXI</li> <li>setMsgNotification</li> <li>clrMsgNotification</li> <li>devIOCtrl</li> </ul> |  |  |
| Figure 5-2 Integrating the device driver under UNIX                                                                                                           |                                                                                        |                                                                                                                                                                                                      |  |  |

Figure 5-2 Integrating the device driver under UNIX

#### Architecture and Structure of a Device Driver



# Example of Integration Into an Operating System Such as Windows NT

Figure 5-3 Integrating the device driver under Windows NT



ninecom

|                            | 5.3 Description of Functions                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            | Before considering each of these functions in greater detail in the following sections, the basic tasks they perform are outlined below.                                                                                                                                                                                                                                                                             |
| openDevice                 | Opens a data channel to the mailbox or data interface. The node handle obtained is required for all further services.                                                                                                                                                                                                                                                                                                |
| closeDevice                | Closes the data channel to a node, preventing further access via this channel.                                                                                                                                                                                                                                                                                                                                       |
| writeDTI                   | Writes data to the data area of the IBS PCI controller board MPM.                                                                                                                                                                                                                                                                                                                                                    |
| readDTI                    | Reads data from the MPM data area.                                                                                                                                                                                                                                                                                                                                                                                   |
| writeMXI                   | Sends a message via the mailbox interface or mailbox area to another MPM node, following the mailbox handshake protocol.                                                                                                                                                                                                                                                                                             |
| readMXI                    | Reads a message from another MPM node from the mailbox interface or<br>the mailbox area of the MPM, following the mailbox handshake protocol.                                                                                                                                                                                                                                                                        |
| devIOCtrl                  | Used to perform all services that are not provided by the functions listed<br>above. This includes setting and resetting notification mechanisms,<br>reading and writing the entire MPM, reading the INTERBUS master<br>diagnostic words, etc. Some of the services, e.g., notification handling and<br>reading diagnostic words, are also made available to the user. Other<br>services are "hidden" from the user. |
| Init device driver routine | This function initializes the device driver structures and variables and performs the basic initialization of the IBS PCI controller boards.                                                                                                                                                                                                                                                                         |
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                      |



#### Architecture and Structure of a Device Driver

The interrupt service routine performs the majority of tasks needed for the

routine mailbox handshake protocol. It receives the "Message present" and , in and is in these everal in the original in "Mailbox free" events, i.e., it also manages the mailbox. Furthermore, the interrupt service routine receives the SysFail and MPM node SG int x **Release device** driver routine

Interrupt service



#### 5.3.1 Initialization (initBoard)

Initialization depends on the operating system used and takes place when the computer or the operating system is started. However, it can also take place during normal operation. Initialization must always be completed successfully before other driver functions can be used by application programs.

Actions during the initialization phase:

- Checking that the board parameters transferred (e.g., short page \_ address, interrupt level, and MPM memory address) are valid and that there is a controller board at the address specified.
- \_ Initialization of the device driver internal structures and variables, evaluation of the MPM descriptor and transfer of the information it contains to internal structures.
- Entering basic settings for the IBS PCI controller boards. \_

Initialization will be aborted with an error message if an error occurs in one .stec of the actions listed above. In this case, the driver cannot be used.



#### Architecture and Structure of a Device Driver

### 5.3.2 Open Data Channel (openDevice)

The openDevice function is used to set up a data channel for a particular IBS PCI controller board, a particular node (0 to 3), and a particular interface (data interface or mailbox interface). The device name determines which controller board, which node, and which interface is addressed. It is structured as follows:



Figure 5-4 Device name structure

From the device name, the openDevice function determines the node to which the data channel is to be opened. The *Board\_Pres\_x* bit in the MPM configuration register is evaluated to check whether the desired node actually exists. The parameters transferred to the openDevice function, such as access right, interface type, etc., are also checked. If an error occurs in one of these steps or the device name specified is not known, the function is terminated with an appropriate error message.

If all steps up to this point have been completed successfully, the function calls another routine to generate a node handle, which is then transferred to the user. If there are no more node handles available, the function is terminated with an appropriate error message.





A selection of error messages can be found in the "ddi\_err.h" file on the disk containing the C source code supplied with the DDK.

The node handle is an index in the *nodeHdCtrl* array (T\_NODE\_HD\_CTRL data type). To avoid having to start with the index value zero, a fixed offset is added to the actual index value. This value (index + offset) is then transferred to the user as the node handle. The node handle does not enable the user to draw any conclusions about the node addressed and type of interface. The *openDevice* function stores all of the parameters belonging to the node handle, such as access right, node number, and interface type, in the *nodeHdCtrl* control structure (T\_NODE\_HD\_CTRL data type). These parameters are then used for subsequent access with the node handle for test purposes and "determining the routing".



The assignment and management of node handles can be reduced or completely eliminated in operating systems that issue their own handle or file descriptor (e.g., UNIX). In these cases, the only check made is for the presence of the desired node. However, as already indicated, the procedure depends on the operating system used.

### 5.3.3 Close Data Channel (closeDevice)

The closeDevice function is the counterpart of the openDevice function. It is used to close an open data channel again, so that no more services can be executed via this channel. The corresponding *nodeHdCtrl* node handle control structure (T\_NODE\_HD\_CTRL data type) is marked "free" and is therefore available again. Errors can only occur if the node handle transferred is invalid, i.e., its value is outside the valid range, or the data channel has already been closed.

This function has no other effect on the device driver or controller board.



#### 5.3.4 Write Process Data (writeDTI)

The writeDTI function is used to write data to the required location in the data area (DTA) of the local node (in the host system, for example, this would be the data area of node 0). With firmware 4.xx the length of the data area is limited to a maximum of 4 kbytes. The *writeDTI* function basically checks the parameters transferred in the T\_DDI\_DTI\_ACCESS structure and copies the data to the required data consistency area.

The following checks are made:

- Status of the control structure
- Existence of access right to the data channels
- Interface type is "data interface"
- Compliance with permissible data area when writing data (sum of offset and number of bytes less than or equal to data area)

If one of these requirements cannot be met, the function is terminated with an error message.

If all of the requirements are met, the data is copied. The DTA start address of the writing node is determined first. The DTA start address in the MPM depends on the MPM node and is stored in the MPM descriptor. The data is then written to the MPM in a loop.

After the data has been copied successfully, the function is terminated with the return value *ERR\_OK*.



#### 5.3.5 Read Process Data (readDTI)

The process involved for reading from the data area corresponds to that of writing to the DTA. Only the data transfer direction changes.

The readDTI function is used to read data from the data area (DTA) of another node or the local node. The node handle determines the node from which data is read.

The function basically checks the parameters transferred in the T\_DDI\_DTI\_ACCESS structure and copies the data from the required area to a memory area provided by the application program.

The following checks are made:

- Status of the control structure
- Existence of access right to the data channels
- Interface type is "data interface"
- Compliance with permissible data area when reading data (sum of offset and number of bytes less than or equal to data area)

If one of these requirements cannot be met, the function is terminated with an error message.

If all of the requirements are met, the data is copied. Once again the start address should be taken from the MPM descriptor. The data is then read from the MPM in a loop.

After the data has been read successfully, the function is terminated with the return value *ERR\_OK*.



#### 5.3.6 Send Message (writeMXI)

The writeMXI function is used to send messages to any other MPM node. Unlike writing to the DTA, transmission of the message must follow a certain protocol. The mailbox handshake protocol used has already been described in Section 4, "Communication via the Mailbox Interface", and will not be explained in further detail at this point.

As with the other functions, the parameters transferred and the status of the controller board are checked:

- Validity of the node handle used
- Write access to the data channels permitted
- Interface type is "mailbox interface"
- MPM still displayed in host system memory area and enabled
- Message does not exceed the maximum permissible length of a mailbox
- Destination node is marked "ready", i.e., the corresponding MPM\_Node\_Ready\_x bit in status register 1 is set.

All of the following steps result from the mailbox protocol used:

- Check whether the send vector register is free, either by reading the handshake registers in the MPM, or by reading the *svrState* structure component in the relevant node control structure. If the SVR is free, it will then be marked as occupied.
- Determine whether the SVR has already been occupied for a long time.
   (Check SVR timeout counter for the node). If it has, the function is terminated with the error message ERR\_SVR\_TOUT.
- Use a help function to identify a free mailbox. If there are no more free mailboxes available, enable SVR and terminate the function with an error message.
- Enter the start address of the mailbox to be used for the message in the SVR.
- Copy message to the mailbox.
- Set corresponding handshake bit by writing to a set HS Ax/Bx register.
- Restore the original contents of the controller board I/O registers and terminate the function with the return value *ERR\_OK*.





There is no need to wait for the mailbox to be enabled at this point, since this task is performed by the interrupt service routine. There is also no need to wait for the send vector register to be enabled, because the relevant bit in the handshake register is checked before a message is sent to rule out the risk of overwriting. Any mailbox address within the permissible range (mailbox area) can be chosen for communicating with the other nodes.

The SVR to be used and its location in the MPM are determined using the node handle or the node number.

The addresses of the handshake and set HS Ax/Bx registers can be determined using the globally available *svrCtrl* structure (T\_AVR\_CTRL data type). The *Source\_Node\_Number* (row value) and *Destination\_Node\_Number* (column value) parameters required for this are contained in the *nodeHdCtrl* node handle control structure and the *devCtrlCB* general device driver control structure (T\_DEV\_CTRL data type).

### 5.3.7 Read Message (readMXI)

The readMXI function is used for reading a message from the MPM. It is the counterpart of the writeMXI function. In addition to reading the actual message, the function also handles the mailbox handshake protocol.

With DOS drivers this function is generally used in polling mode, i.e., the application program calls this function cyclically to determine whether a message is present. With other operating systems, such as OS-2, it can be implemented as a blocked function, which is to be left waiting (blocked) until a message arrives.

The function is notified of the presence of a message indirectly through the *msgCtrl* message control structure (T\_MSG\_CTRL data type). If the value of the structure component *msgCnt* is greater than zero, a message is present. A message is always only read by the MPM node specified by the node handle.



As with the other functions, before the message is read, the specified parameters specified (node handle, length of the buffer for the message, etc.) and the status of the controller board are checked:

- Validity of the node handle
- Read access permitted when opening the data channel
- Interface type is "mailbox interface"
- Destination node is marked "ready", i.e., the corresponding MPM\_Node\_Ready\_x bit in status register 1 is set.

If the parameters correspond to the values expected, the *msgCtrl* message control structure (T\_MSG\_CTRL data type) is then evaluated to determine whether a message is present. The chkMailbox function is called if there is no message. This routine is also used by the interrupt service routine. It detects and processes events that affect the mailbox handshake protocol. If, after the chkMailboxes function has been called, the message counter of the message control structure is still zero, the function is terminated with the return value *ERR\_NO\_MSG*.

If a message is present, a check is made to determine whether the MPM is still displayed on the host system memory area and enabled.

If it is still possible to access the MPM, the address of the mailbox in the MPM is determined. This information is used to calculate the MPM segment to be displayed and the offset within this segment for the message.

#### **Reading the Message:**

- Evaluate the message parameter counter (the parameter counter is the second word of the message, see also the *"Firmware Services and Error Messages" User Manual, IBS SYS FW G4 UM E*).
- Calculate the total length of the message in bytes ((parameter counter + 2) \* 2) and compare with the length of the message buffer. If the message received is longer than the buffer available, the function is terminated with an error message. In this case, the message is not copied.
- Copy data from the mailbox to the message buffer.
- Enter the length of the message in bytes ((parameter counter + 2) \* 2) in the variable referenced by *\*msgLength*.



The following steps are again identical for both mailbox directions, and are used to execute the mailbox handshake protocol:

- Decrement message counter in the message control structure msgCtrl.
- Enter address of the read mailbox in the corresponding acknowledge vector register.
- By writing to the corresponding set HS Ax/Bx register, set the relevant bit in one of the handshake registers, thereby indicating to the sending node that the mailbox is free again.
- Terminate the function with the return value ERR\_OK.

There is no need to wait for the "Mailbox free" bit to be reset. This task is performed by the sending node. As long as only one mailbox is used between the nodes, a new message cannot be transmitted until the sending node has itself detected that the mailbox is free. There is therefore no risk that a valid value in the AVR will be overwritten. It is only necessary to poll for a free AVR if several mailboxes are used between two nodes.

The addresses of the handshake and set HS Ax/Bx registers can be determined using the globally available *avrCtrl* structure (T\_AVR\_CTRL data type). The *Source\_Node\_Number* (row value) and *Destination\_Node\_Number* (column value) parameters required for this are contained in the *nodeHdCtrl* node handle control structure (T\_NODE\_HD\_CTRL data type) and the *devCtrl* general device driver control structure (T\_DEV\_CTRL data type).

### 5.3.8 Interrupt Service Routine (intrServiceFunction)

The interrupt service routine is a central part of the device driver. In particular, parts of the mailbox protocol (e.g., enabling the mailboxes used, receiving messages, reading the send vector registers, etc.) are handled within this routine. The SysFail and MPM node SG int x interrupts are also processed by this routine.

The sequence of the routine is as follows:

 Read the MPM status register to determine interrupt cause(s). Possible causes are: SysFail interrupt, MPM node SG int x interrupt, and handshake interrupt.



- Determine exact cause of interrupt: SysFail interrupt: Which node signaled the SysFail?
   --> Evaluate MPM status register
   MPM node SG int x interrupt: Which node caused the interrupt? -->
   Evaluate MPM status register 1
   Handshake interrupt: Which node caused the interrupt?
   --> Evaluate handshake registers to determine which node has
   signaled what ("Message present" or "Mailbox free")
- "Message present": Use the node numbers (source and destination) to locate and read the relevant SVR. Then reset the handshake bit ("Message present detected"). Save the contents of the SVR (mailbox address) and increment the message counter for the node. Also call the notification function if there is one and it has been activated.
- "Mailbox free": Use the node numbers (source and destination) to locate and read the relevant AVR. Then reset the handshake bit by writing to the set HS Ax/Bx register ("Mailbox free detected"). Mark the mailbox "free" again in the local control structures.



During the interrupt service routine all other interrupts are disabled. They are only enabled again when the routine is terminated. In the current version, processing of the SysFail interrupt and the MPM node SG int x interrupt is limited to merely recording the events. There are no other actions.

The interrupt service routine is divided into two functions: the actual interrupt service routine, which is entered in the interrupt vector, and an independent function that performs all of the actions needed for the mailbox handshake protocol. The two routines can nevertheless be regarded as functionally related. However, this division also makes it possible to call the routine for the mailbox handshake protocol outside the interrupt service routine (see also implementation of the writeMXI and the readMXI function).

#### 5.3.9 Device IO Control (devIOCtrl)

The devIOCtrl function is used to perform special services that cannot be assigned to the "normal" functions. The possible tasks covered by this function range from additional diagnostics, through reading the MPM, to various utility functions (enable watchdog, trigger watchdog, etc.). The advantage of this method is that only one function is required to access the tasks to be carried out in the INTERBUS master.





The function is provided with three values as parameters:

- Node handle (nodeHd)
- Command code (cmd)
- Pointer to a buffer for reading or writing (dataPtr)

The *nodeHd* parameter is neither checked nor used. Its further use can be defined by the creator of the driver.

The *cmd* (command code) parameter is used to determine which command or special task is to be carried out with the routine. The value must always be unique.

The parameters required for the task or the result of the function are transferred or returned using the *dataPtr* pointer. The type of data to which this pointer refers depends on the desired task and is not restricted.



#### 5.3.10 Utilities

In addition to functions that are a direct mapping of the DDI, some extra utilities are also provided. They are used to read the diagnostic registers, manage the watchdog functions, and set and reset the notification functions. The actual task is implied by the name of the function. See the "vmeutil.c" file for a more detailed description. The following table contains some utilities:

| Table 5-1 | Additional | utilities |
|-----------|------------|-----------|
|-----------|------------|-----------|

|                    |                                                                                                                                    | _    |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------|------|
| Function           | Task                                                                                                                               | Page |
| GetIBSDiagnostic   | Evaluates the operating state of the INTERBUS master                                                                               | 5-22 |
| GetIBSDiagnosticEx | Evaluates the operating state of the INTERBUS master (like <i>GetIBSDiagnostic</i> , additional structure element <i>addinfo</i> ) | 5-23 |
| GetSlaveDiagnostic | Evaluates the operating state of the slave                                                                                         | 5-24 |
| GetSysFailRegister | Reads the contents of the SysFail register                                                                                         | 5-25 |
| EnableWatchDog     | Switches a watchdog on                                                                                                             | 5-26 |
| TriggerWatchDog    | Triggers the watchdog                                                                                                              | 5-26 |
| GetWatchDogState   | Reads the status of a watchdog                                                                                                     | 5-27 |
| ClearWatchDog      | Resets the status of a watchdog                                                                                                    | 5-27 |
| SetWatchDogTimeout | Sets the timeout value and switches the watchdog on                                                                                | 5-28 |
| GetWatchDogTimeout | Reads the timeout value                                                                                                            | 5-28 |
| onlin              |                                                                                                                                    |      |

6189A



#### GetIBSDiagnostic 5.3.10.1 Task The GetIBSDiagnostic() function reads the diagnostic status register and diagnostic parameter register. The function receives a valid node handle and a pointer to a T\_IBS\_DIAG data structure as parameters. After the function has been called successfully, the components of the structure contain the contents of the diagnostic status register and the diagnostic parameter register. IBDDIRET IBDDIFUNC GetIBSDiagnostic (IBDDIHND nodeHd, **Syntax** T\_IBS\_DIAG IBPTR \*diagInfo); Parameter nodeHd Node handle (MXI or DTI) of the controller board from which the diagnostic status register and diagnostic parameter register are to be read. diagInfo Pointer to a T\_IBS\_DIAG data structure. T IBS DIAG The contents of the register are entered in this structure. Positive ERR\_OK (0000<sub>hex</sub>) The function was executed successfully. acknowledgment: Describes an error that has occurred. Negative DDI error code - Invalid node handle acknowledgment Cause: T\_IBS\_DIAG The bits of the state structure element state structure elements correspond to the diagnostic status register. diagPara The diagPara structure element corresponds to the diagnostic parameter register. Format of the typedef struct { T IBS DIAG \*/ /\* Status of INTERBUS USIGN16 state; structure USIGN16 diagPara; /\* Type of error \*/ /\* (controller, user, \*/ etc.) } T\_IBS\_DIAG;



|                                             | 5.3.10.2 GetIBSDiag                                                                             | nosticEx                                                                                                                                                                                                                                                    |
|---------------------------------------------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Task                                        | and diagnostic paramet<br>of the INTERBUS contr<br>corresponds to the <i>Get</i>                | Ex() function reads the diagnostic status register<br>er register. It is used to display the operating state<br>oller board or that of INTERBUS. The function<br>(BSDiagnostic() function. However, the addInfo<br>een added (this is a software register). |
| Syntax                                      | IBDDIRET IBDDIFUNC                                                                              | GetIBSDiagnosticEx (IBDDIHND nodeHd,<br>T_IBS_DIAG_EX IBPTR *diagInfo);                                                                                                                                                                                     |
| Parameter                                   | nodeHd<br>diagInfo<br>T_IBS_DIAG_EX                                                             | Node handle (MXI or DTI) of the controller board<br>from which the diagnostic status register and<br>diagnostic parameter register are to be read.<br>Pointer to a T_IBS_DIAG_EX data structure.<br>This data structure contains all the elements           |
|                                             |                                                                                                 | required for diagnostic purposes.                                                                                                                                                                                                                           |
| Positive<br>acknowledgment                  | ERR_OK (0000 <sub>hex</sub> )                                                                   | The function was executed successfully.                                                                                                                                                                                                                     |
| Negative<br>acknowledgment                  | DDI error code                                                                                  | Describes an error that has occurred.<br>Cause: – Invalid node handle                                                                                                                                                                                       |
| T_IBS_DIAG_EX<br>structure elements         | state                                                                                           | The bits of the <i>state</i> structure element correspond to the diagnostic status register.                                                                                                                                                                |
|                                             | diagPara                                                                                        | The <i>diagPara</i> structure element corresponds to the diagnostic parameter register.                                                                                                                                                                     |
|                                             | addInfo                                                                                         | The <i>addInfo</i> structure element corresponds to the <i>Add_Error_Info</i> parameter for negative messages.                                                                                                                                              |
| Format of the<br>T_IBS_DIAG_EX<br>structure | <pre>typedef struct {     USIGN16 stat     USIGN16 diag     USIGN16 addI } T_IBS_DIAG_EX;</pre> | Para; /* Type of error */<br>/* (controller, user, */<br>etc.)                                                                                                                                                                                              |



|                                          | 5.3.10.3 GetSlaveDia                                                        | agnostic                                                                                                                                                        |
|------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Task                                     | register and the slave d                                                    | <i>c()</i> function reads the slave diagnostic status<br>iagnostic parameter register of an INTERBUS<br>ed to display the operating state of the slave part or  |
|                                          |                                                                             | structure element is implemented in the it is not currently supported by the controller board                                                                   |
| Syntax                                   | IBDDIRET IBDDIFUNC                                                          | GetSlaveDiagnostic (IBDDIHND nodeHd,<br>T_IBS_DIAG IBPTR *diagInfo);                                                                                            |
| Parameter                                | nodeHd                                                                      | Node handle (MXI or DTI) of the system coupler<br>from which the slave diagnostic status register<br>and slave diagnostic parameter register are to be<br>read. |
|                                          | diagInfo                                                                    | Pointer to a T_IBS_DIAG data structure.                                                                                                                         |
|                                          | T_IBS_DIAG                                                                  | This data structure contains all the elements required for diagnostics purposes.                                                                                |
| Positive<br>acknowledgment               | ERR_OK (0000 <sub>hex</sub> )                                               | The function was executed successfully.                                                                                                                         |
| Negative<br>acknowledgment               | DDI error code                                                              | Describes an error that has occurred.<br>Cause: – Invalid node handle                                                                                           |
| T_IBS_DIAG<br>structure elements         | state                                                                       | The bits of the <i>state</i> structure element correspond to the slave diagnostic status register.                                                              |
|                                          | diagPara                                                                    | The diagPara structure element corresponds to the slave diagnostic parameter register.                                                                          |
| Format of the<br>T_IBS_DIAG<br>structure | <pre>typedef struct {     USIGN16 stat     USIGN16 diag } T_IBS_DIAG;</pre> |                                                                                                                                                                 |



### 5.3.10.4 GetSysFailRegister

| Task                       | <ul> <li>The <i>GetSysFailRegister()</i> function writes the contents of the MPM status SysFail register to the variable referenced by the <i>sysFailRegPtr</i> parameter. Bits 0, 4, 8, and 12 of the register indicate whether the SysFail signal of the controller board is activated or not. If a malfunction occurs (e.g., watchdog triggered) in one of the two bits (8 and 12), the relevant bit is activated in the status SysFail register, i.e., set to one. This bit then remains set until the malfunction is corrected. The individual bits of the register are assigned to the MPM as follows:</li> <li>Bit 12: Host system</li> <li>Bit 8: INTERBUS controller board</li> </ul> |                                                                                                 |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|
| Syntax                     | IBDDIRET IBDDIFUNC (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | GetSysFailRegister (IBDDIHND nodeHd,<br>USIGN16 IBPTR *sysFailRegPtr);                          |
| Parameter                  | nodeHd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Node handle (MXI or DTI) of the controller board from which the SysFail register is to be read. |
|                            | sysFailRegPtr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Pointer to a variable to which the contents of the SysFail register are to be transferred.      |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | The function was executed successfully.                                                         |
| Negative<br>acknowledgment | DDI error code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Describes an error that has occurred.<br>Cause: – Invalid node handle                           |
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                 |



|                            | 5.3.10.5 EnableW                                                                                                                                              | atchDog                                                                                      |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Task                       | The watchdog is activated with the <i>DDI_EnableWatchDog()</i> function. After activation, the watchdog must be reset at regular intervals (TriggerWatchDog). |                                                                                              |
| R <sup>3</sup>             |                                                                                                                                                               | atchdog can only be deactivated by switching off the eans of a hardware reset.               |
| KZ                         | The default watchdo                                                                                                                                           | g time is 128 ms.                                                                            |
| Syntax                     | IBDDIRET IBDDIFU                                                                                                                                              | NC EnableWatchDog (IBDDIHND nodeHd);                                                         |
| Parameter                  | nodeHd                                                                                                                                                        | Node handle (MXI or DTI) of the controller board from which the watchdog is to be activated. |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                                                                                                                                 | The function was executed successfully.                                                      |
| Negative<br>acknowledgment | DDI error code                                                                                                                                                | Describes an error that has occurred.<br>Cause: – Invalid node handle                        |
|                            | 5.3.10.6 TriggerW                                                                                                                                             | /atchDog                                                                                     |
| Task                       | The watchdog is res                                                                                                                                           | et with the <i>TriggerWatchDog()</i> function.                                               |
| Syntax                     | IBDDIRET IBDDIFU                                                                                                                                              | NC TriggerWatchDog (IBDDIHND nodeHd);                                                        |
| Parameter                  | nodeHd                                                                                                                                                        | Node handle (MXI or DTI) of the controller board from which the watchdog is to be reset.     |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                                                                                                                                 | The function was executed successfully.                                                      |
| Negative<br>acknowledgment | DDI error code                                                                                                                                                | Describes an error that has occurred.<br>Cause: – Invalid node handle                        |



|                            | 5.3.10.7 GetWatch                                   | DogState                                                                                                                                                   |
|----------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Task                       | watchdog has been tr                                | <i>ate()</i> function can be used to check whether the iggered (return = 1) or not (return = 0). This is g the watchdog register. The watchdog is also ss. |
| Syntax                     | IBDDIRET IBDDIFUN                                   | C GetWatchDogState (IBDDIHND nodeHd);                                                                                                                      |
| Parameter                  | nodeHd                                              | Node handle (MXI or DTI) of the controller board from which the watchdog is to be read.                                                                    |
| Positive                   | Return =1:                                          | Watchdog triggered.                                                                                                                                        |
| acknowledgment             | Return = 0:                                         | Watchdog not triggered.                                                                                                                                    |
| Negative<br>acknowledgment | DDI error code                                      | Describes an error that has occurred.<br>Cause: – Invalid node handle                                                                                      |
|                            | 5.3.10.8 ClearWate                                  | hDog                                                                                                                                                       |
| Task                       | The watchdog status                                 | is reset with the ClearWatchDog() function.                                                                                                                |
| Syntax                     | IBDDIRET IBDDIFUNC ClearWatchDog (IBDDIHND nodeHd); |                                                                                                                                                            |
| Parameter                  | nodeHd                                              | Node handle (MXI or DTI) of the controller board from which the watchdog is to be reset.                                                                   |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                       | The function was executed successfully.                                                                                                                    |
| Negative<br>acknowledgment | DDI error code                                      | Describes an error that has occurred.<br>Cause: – Invalid node handle                                                                                      |



|                            | 5.3.10.9 SetWatchD                                                                                                                                                                       | ogTimeout                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| Task                       | The <i>SetWatchDogTimeout()</i> function sets the watchdog timeout time and activates the watchdog. After activation, the watchdog must be reset at regular intervals (TriggerWatchDog). |                                                                                                                    |
| R                          | Once set, a watchdog timeout cannot be modified. An activated watchdog can only be deactivated by switching off the host system or by means of a hardware reset.                         |                                                                                                                    |
| Syntax                     | IBDDIRET IBDDIFUNG                                                                                                                                                                       | C SetWatchDogTimeout (IBDDIHND nodeHd,<br>USIGN16 IBPTR *dataPtr);                                                 |
| Parameter                  | nodeHd                                                                                                                                                                                   | Node handle (MXI or DTI) of the controller board<br>from which the watchdog timeout is to be set and<br>activated. |
|                            | dataPtr                                                                                                                                                                                  | Pointer to a variable, which contains the new timeout value.                                                       |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                                                                                                                                                            | The function was executed successfully.                                                                            |
| Negative<br>acknowledgment | DDI error code                                                                                                                                                                           | Describes an error that has occurred.<br>Cause: – Invalid node handle                                              |
|                            | 5.3.10.10 GetWatchD                                                                                                                                                                      | ogTimeout                                                                                                          |
| Task                       | The GetWatchDogTim timeout.                                                                                                                                                              | <i>eout()</i> function reads the current value of the                                                              |
| Syntax                     | IBDDIRET IBDDIFUNC                                                                                                                                                                       | C GetWatchDogTimeout (IBDDIHND nodeHd,<br>USIGN16 IBPTR *dataPtr);                                                 |
| Parameter                  | nodeHd                                                                                                                                                                                   | Node handle (MXI or DTI) of the controller board from which the timeout value is to be read.                       |
|                            | dataPtr                                                                                                                                                                                  | Pointer to a variable to which the timeout value is written.                                                       |
| Positive<br>acknowledgment | ERR_OK (0000 <sub>hex</sub> )                                                                                                                                                            | The function was executed successfully.                                                                            |
| Negative<br>acknowledgment | DDI error code                                                                                                                                                                           | Describes an error that has occurred.<br>Cause: – Invalid node handle                                              |





#### 5.3.11 Data Structures Used

All of the data structures used will now be described and explained in order to provide a clear picture of the driver and its organization.

#### 5.3.11.1 T\_DEV\_CTRL devCtrl

This structure contains all the parameters, which are of relevance to the controller board. They are as follows:

| stateOfDevice:       | Logical status of the host system (ready, error, etc.)           |
|----------------------|------------------------------------------------------------------|
| boardNumber:         | Logical number of the controller board addressed                 |
| localNodeNumber:     | Node number on the MPM (a "0" represents the driver itself.)     |
| addrMPM:             | Controller board memory address in the host system address area. |
| addrHostRegs:        | Host register address                                            |
| intrVector:          | Interrupt vector used by driver                                  |
| intrLevel:           | Interrupt level used by driver                                   |
| sndMXA:              | Mailbox area location and length                                 |
| startAddrExDTA:      | Extended data area start address                                 |
| lengthExDTA:         | Length of the extended data area in bytes                        |
| sndMXA.offsetoutData | length:<br>Location and length of the DTA and MXA in the<br>MPM  |



The structure is configured during the initialization phase. During operation, it is accessed primarily for read purposes.

#### 5.3.11.2 T\_NODE\_CTRL nodeCtrl[ ]

A *nodeCtrl* structure (T\_NODE\_CTRL data type) is set up and initialized for each node (maximum of four possible) on the MPM. This structure primarily contains information assigned specifically to one node.

nodeNumber:Node number for which the structure is useddevNameDTI:Pointer to the relevant device name for the DTI



| devNameMXI:           | Pointer to the relevant device name for the MXI                         |
|-----------------------|-------------------------------------------------------------------------|
| curDTIOpenCnt:        | Number of data channels open to the DTI                                 |
| maxDTIOpenCnt:        | Maximum number of data channels to the DTI                              |
| curMXIOpenCnt:        | Number of data channels open to the MXI                                 |
| maxMXIOpenCnt:        | Maximum number of data channels to the MXI                              |
| svr.addrSVRToRem:     | Address of the SVR for sending to the relevant node                     |
| svr.stateSVRToRem:    | SVR status (free or occupied, has no significance at present)           |
| avr.addrAVRToRem:     | Address of the AVR for notifying ("Mailbox free") for the relevant node |
| avr.stateAVRToRem:    | AVR status (free or occupied, has no significance at present)           |
| avr.addrAVRFromRem:   | Address of the AVR of the relevant node (message to local node)         |
| avr.stateAVRFromRem:  | AVR status (free or occupied, has no significance at present)           |
| dta.addrDTAToRem:     | Address of the data area to the relevant node                           |
| dta.lengthDTAToRem:   | Length of the data area to the relevant node                            |
| dta.addrDTAFromRem:   | Address of the data area from the relevant node                         |
| dta.lengthDTAFromRem: | Length of the data area from the relevant node                          |
| exDta.addrExDTAToRen  | n:                                                                      |
|                       | Address of the extended data area to the relevant node                  |
| exDta.lengthExDTAToRe |                                                                         |
|                       | Length of the extended data area to the relevant node                   |
| exDta.addrExDTAFromR  |                                                                         |
|                       | Address of the extended data area from the relevant node                |
| exDta.lengthExDTAFrom |                                                                         |
|                       | Length of the extended data area from the relevant node                 |



#### 5.3.11.3 T\_NODE\_HD\_CTRL nodeHdCtrl[]

T\_NODE\_HD\_CTRL data structures are provided based on the total number of node handles available to the user. The number can be adjusted to meet individual requirements. The structures are initialized when the driver is started or loaded. During operation they are occupied or enabled again when the data channels are opened and closed. The structure contains parameters that enable the node handle to be easily assigned to the node it specifies. The structure also contains parameters for the type of data channel and access rights.

| stateOfNodeHd: | Node handle status (free, in use, etc.)       |
|----------------|-----------------------------------------------|
| nodeNumber:    | Number of node on which the handle operates   |
| devType:       | Type of interface (mailbox or data)           |
| perm:          | Interface access rights (read, write or both) |
| flagNotify:    | Notification for this handle activated        |

#### 5.3.11.4 T\_NOTIFY\_CTRL notifyCtrl[]

A T\_NOTIFY\_CTRL data structure is available for each node (maximum of four). The structures are initialized when the driver is started or loaded. During operation these structures are used by the notification functions and the interrupt service routine. The index in the array corresponds to the node number.

| nodeHd:     | The node handle identifies a data channel open to a node.                                  |
|-------------|--------------------------------------------------------------------------------------------|
| flagNotify: | Indicates whether notification has been activated for this node.                           |
| notifyFunc: | Address of the function to be called. The call is made from the interrupt service routine. |



#### 5.3.11.5 T\_MSG\_CTRL msgCtrl[]

For each node the incoming messages are detected using this structure. In its current form, only one message can be detected with this structure. However, since each node uses only one mailbox, there is no risk of any problems arising.

state:Indicates whether a message is present or not.addrOfMsg:Address (offset) of the message in the MPM.remNodeNumber:Number of the node from which the message<br/>has been received.

#### 5.3.11.6 T\_SVR\_CTRL svrCtrl[4][4]

This structure is already initialized at the time of translation. It is used when processing the mailbox handshake protocol to determine the following parameters:

- Addresses of the MPM handshake registers in the MPM
- Addresses of the set HS Ax/Bx registers in the MPM
- Mask for masking out the MPM handshake register (already in Intel format)



Access to this two-dimensional array is based on the row for the source node and the column for the destination node. This enables quick access to the parameters required for the mailbox handshake protocol.

#### 5.3.11.7 T\_AVR\_CTRL avrCtrl[4][4]

The information given for the *svrCtrl* structure also applies to this structure. The parameters for the acknowledge vector registers are entered here.



#### 5.3.11.8 CHAR devNamesDTI[ ][ ]

This structure contains the strings of all valid device names for the data interface. The device names for each node are determined using the local node number. The pointers of the *nodeCtrl* data structure (T\_NODE\_CTRL data type) refer to these strings. The strings are created in static form and are not modified.

#### 5.3.11.9 CHAR devNamesMXI[ ][ ]

Contains the strings of all valid device names for the mailbox interface. Otherwise the same comments as for devNamesDTI apply.

#### 5.3.11.10 USIGN16 avrToutCnt[4]

A counter is implemented here for each node of the MPM, containing the number of consecutive unsuccessful attempts to access the AVR for a node. After a certain value has been exceeded, the error message T\_AVR\_TIMEOUT is returned.



This counter is not in use at present.

#### 5.3.11.11 USIGN16 svrToutCnt[4]

A corresponding counter for the send vector registers. If a specified value is exceeded, the error message ERR\_SVR\_TIMEOUT appears when the sendMXI function is called.

#### 5.3.11.12 USIGN16 msgCnt[4]

This is an array with the message counters for each node. Incremented when a message is received and decremented when a message is read.



hinecomponents.



# Section 6

|                     | This section informs you about <ul> <li>adaptation to operating systems</li> </ul> |     |
|---------------------|------------------------------------------------------------------------------------|-----|
| ToDo (Adaptation to | o Operating Systems)                                                               | 6-3 |
|                     | 6.1 File Structures in the Driver                                                  | 6-3 |
|                     | hecomponents.com                                                                   |     |





minecomponents.com PHENIX

## 6 ToDo (Adaptation to Operating Systems)

### 6.1 File Structures in the Driver

In order to give an overview of the dependency relationships within the driver, the "file path" for VxWorks is described here as an example. The adaptation for Windows NT is also shown. The example demonstrates the differences between different operating systems and gives a rough idea of which adaptations are necessary for other operating systems. A description of the individual "c" and "h" files can be found in Section 1.1 "Files on the Disk".



It is recommended that the file names are selected to correspond to the operating system, as shown here. This enables the file to be clearly identified and retains the link to the structure described here.



The calls and functions described here in relation to Windows NT are only given for the purpose of clarification and are **not** part of the IBS PCI DDK.







#### **ToDo (Adaptation to Operating Systems)**

"OS?"sys.c The "OS?"sys.c files (ntsys.c, vxwsys.c, and soon also "YourOS"sys.c) represent the interface to the relevant operating system. The system function calls are made here. The data structures are also adapted to the operating system.

#### The following functions are executed in "OS?"sys.c: IBD\_IoConnectInterrupt(PT\_BOARD\_INFO pBoardInfo);

- Connects the interrupt with the operating system

#### VxWorks function:

if ((**pciIntConnect**(INUM\_TO\_IVEC (((int) pBoardInfo->queryInfo.uInterrupt) + INT\_NUM\_IRQ0), IbsInterruptServiceRoutine, (int)pBoardInfo)) == ERROR)

printf("Connect interrupt failed\n");

return(RETURN\_ERR);

sysIntEnablePIC((int) pBoardInfo->queryInfo.uInterrupt);

#### Windows NT function:

status = IoConnectInterrupt(&pBoardInfo->pInterruptObject,

IbsInterruptServiceRoutine,

pBoardInfo, NULL, pBoardInfo->uMappedIrqVector,

pBoardInfo->Irql, pBoardInfo->Irql, LevelSensitive,

TRUE, /\* share interrupt \*/ pBoardInfo->Affinity, FALSE);

#### ReadIOAddressBoardNumber(PT\_PCI\_INFO PciInfo);

 Reads the first I/O register of the PCI controller board. This contains the board number that is set using the DIP switches. All 8 possible board numbers are compared, and if two boards have the same address, these are indicated as "invalid".

#### IbsInterruptServiceRoutine(PT\_BOARD\_INFO pBoardInfo);

- Link to the InterruptServiceRoutine

#### ScanPciDevices(PT\_PCI\_INFO PciInfo);

 Searches in the PCI address area for the IBS PCI controller board and enters the relevant data structure.



The "ScanPciDevices" function is used to clarify the different readings of the required parameters. The sections of text marked in *bold/italics* are PCI system function calls. The "pPciInfo" structure, with the relevant data entered, is then available for other functions.

#### Windows NT: (ntsys.c)

```
void ScanPciDevices(PT_PCI_INFO PciInfo)
{
   . . .
   ...
   ...
   for (bus = 0; flag; bus++)
   {
     for (i = 0; i < PCI_MAX_DEVICES && flag; i++)
     ł
     SlotNumber.u.bits.DeviceNumber = i;
     for (f = 0; f < PCI_MAX_FUNCTION; f++)
     {
       SlotNumber.u.bits.FunctionNumber = f;
       j = HalGetBusData (PCIConfiguration, bus, SlotNumber.u.AsULONG,
             PciData, PCI_COMMON_HDR_LENGTH);
       if (j == 0)
       { // out of buses
         flag = FALSE;
         break;
       if (PciData->VendorID == PCI_INVALID_VENDORID)
       { // skip to next slot
         break;
       if (PciData->VendorID == PCI_PHOENIX_VENDOR_ID)
       {
         switch (PciData->DeviceID)
         {
         case PCI_PHOENIX_DEVICE_ID_SC:
           pciInfo->boardNumber = boardNumber;
           ++boardNumber;
           pciInfo->bus = (USIGN16)bus;
           pciInfo->pciDevice = (USIGN16)i;
           pciInfo->pciFunction = (USIGN16)f;
           pcilnfo->vendorId = PciData->VendorID;
           pcilnfo->deviceId = PciData->DeviceID;
           ...
           ...
           ...
```



#### **ToDo (Adaptation to Operating Systems)**

#### VxWorks: (vxwsys.c)

```
void ScanPciDevices(PT_PCI_INFO PciInfo)
{
   ...
   ...
   for (bus = 0; bus < 3; bus++)
   {
     for (sDeviceNo = 0; sDeviceNo < sDevices; sDeviceNo++)
     {
       pciConfigInWord (bus, sDeviceNo, 0, PCI_CFG_VENDOR_ID,
           &vendorId);
       pciConfigInWord (bus, sDeviceNo, 0, PCI_CFG_DEVICE_ID, & deviceId);
       if (vendorld != 0xffff)
       {
         if (vendorId == PCI_PHOENIX_VENDOR_ID)
         ł
           switch (deviceId)
           {
             case PCI PHOENIX DEVICE ID SC:
            pPciInfo->boardNumber = uBoardNumber;
             ++uBoardNumber;
            pPciInfo->bus = (USIGN16)bus:
            pPciInfo->pciDevice = (USIGN16)i;
            pPciInfo->pciFunction = PCI_PHOENIX_FUNCTION_NUM;
            pPciInfo->vendorId = vendorId;
            pPcilnfo->deviceId = deviceId;
            pciConfigInLong (bus, sDeviceNo,
              PCI_PHOENIX_FUNCTION_NUM,
              PCI_CFG_BASE_ADDRESS_1,
              &pPciInfo->memBaseAddress);
             pciConfigInLong (bus, sDeviceNo,
              PCI_PHOENIX_FUNCTION_NUM,
              PCI_CFG_BASE_ADDRESS_0,
             &pPciInfo->ioBaseAddress);
            pPciInfo->ioBaseAddress = (pPciInfo->ioBaseAddress & (~1));
            pciConfigInByte (bus, sDeviceNo,
              PCI_PHOENIX_FUNCTION_NUM, PCI_CFG_BRG_INT_LINE,
             &pPciInfo->interruptLine);
             ...
         }
     } /* for device */
   } /* for bus */
}
```

**DPHŒNIX** CONTACT

```
Example YourOS: ("YourOS"sys.c)
```

```
void ScanPciDevices(PT_PCI_INFO PciInfo)
{
   for (bus = 0; bus < 3; bus++)
   {
     for (sDeviceNo = 0; sDeviceNo < sDevices; sDeviceNo++)
     {
       vendorId = YourFunction(get PCI_Bus_Data.Vendor);
               /* Here for example,
               all data can be read at the same time */
       deviceId = YourFunction(get PCI_Bus_Data.Device);
       if (vendorId != 0xffff)
       {
         if (vendorId == PCI_PHOENIX_VENDOR_ID)
         {
           switch (deviceId)
           {
           case PCI_PHOENIX_DEVICE_ID_SC:
             pPciInfo->boardNumber = uBoardNumber;
             ++uBoardNumber;
             pPciInfo = YourFunction(get PCI_Bus_Data); /* Here for
             example, all data can be read at the same time */
           }
         }
     } /* for device */
   } /* for bus */
```

### ToDo (Adaptation to Operating Systems)

| os_adapt.h | The pointers, structures, and macros defined here are operating system dependent. Thus, for example, the byte read access to the I/O ports in Windows NT is gained using the " <i>READ_PORT_UCHAR</i> (addr)" function and in VxWorks using " <i>sysInByte</i> (addr)". The function that makes " <i>YourOS</i> " available should be used here. |                |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|            | Windows NT:                                                                                                                                                                                                                                                                                                                                      |                |
|            | <pre>#ifdef IBS_WIN_NT_VERSION /*selects the WindowsNT-funtionality typedef int T_BIN_SEMAPHORE; typedef ISIGN8 *IOPORT8; typedef DEVICE_OBJECT *P_DEVICE_OBJECT; typedef DRIVER_OBJECT *P_DRIVER_OBJECT; typedef UNICODE_STRING P_DEVICE_NAME; /* device object pointer /* device name</pre>                                                    | */<br>*/<br>*/ |
|            |                                                                                                                                                                                                                                                                                                                                                  |                |
|            | /*<br>// General macros for reading and writing the I/O ports of the Interbus board.<br>*/                                                                                                                                                                                                                                                       |                |
|            | <pre>#define lbsReadlOPort(addr) (READ_PORT_UCHAR((addr))) #define lbsReadlOPort16(addr) (READ_PORT_USHORT((addr))) #define lbsWritelOPort(addr, dataByte) (WRITE_PORT_UCHAR((addr), (UCHAR)dataByte)) #define lbsWritelOPort16(addr, dataByte) (WRITE_PORT_USHORT((addr), (USHORT)dataByte))</pre>                                              |                |
|            |                                                                                                                                                                                                                                                                                                                                                  |                |
|            |                                                                                                                                                                                                                                                                                                                                                  |                |
|            | VxWorks:                                                                                                                                                                                                                                                                                                                                         |                |
|            | #ifdef IBS_VXWORKS_VERSION /* selects the VxWorks-funtionality<br>typedef SEM_ID T_BIN_SEMAPHORE;<br>typedef SEM_ID T_MUTEX_SEMAPHORE;                                                                                                                                                                                                           | */             |
|            | typedef short int IOPORT8; /* io-port access<br>/* device object pointer */<br>typedef struct {void *DeviceExtension; } BUF_P_DEVICE_OBJECT,                                                                                                                                                                                                     | */             |
|            | *P_DEVICE_OBJECT;       /* driver object pointer         typedef int *P_DRIVER_OBJECT;       /* driver object pointer         typedef char *P_DEVICE_NAME;       /* device name                                                                                                                                                                  |                |
|            |                                                                                                                                                                                                                                                                                                                                                  |                |
|            | /*<br>// General macros for reading and writing the I/O ports of the Interbus board.<br>*/                                                                                                                                                                                                                                                       |                |
|            | #define IbsReadIOPort(addr) ( <b>sysInByte</b> ((addr)))<br>#define IbsReadIOPort16(addr) (sysInWord((addr)))                                                                                                                                                                                                                                    |                |
|            |                                                                                                                                                                                                                                                                                                                                                  |                |



#define lbsWriteIOPort(addr, dataByte) (sysOutByte((addr), (USIGN8)dataByte))
#define lbsWriteIOPort16(addr, dataByte) (sysOutWord((addr), (USIGN16)
dataByte))

typedef USIGN32 NTSTATUS;

...

#### Your OS:

#ifdef IBS\_ YourOS\_VERSION /\* selects the "YourOS"-funtionality \*/
typedef "YourDatatyp" T\_BIN\_SEMAPHORE;
....
#define IbsReadIOPort(addr) ("YourReadIOPortFunktion"(addr))))
...
your os\_inc.h The "distribution" to the various header files, depending on the operating
system, takes place here.
Windows NT:
#ifdef IBS\_WIN\_NT\_VERSION
/\*\*/
#include <stddef.h>

#include <stade.n>
#include <stade.n>
#include <ntddk.h>
#include <string.h>
#include <stdio.h>
#include <devioctl.h>
#include 'sys/nt\_kernl.h"
/\*\*/
#endif

6-10



#### **ToDo (Adaptation to Operating Systems)**

#### VxWorks:

#ifdef IBS\_VXWORKS\_VERSION /\*\*/ #include <vxworks.h> #include <stddef.h> #include <config.h> #include <string.h> #include <stdio.h> #include <semLib.h> /\*#include <vxcpu.h>\*/ #ifdef PENTIUM #include "drv/pci/pciConfigLib.h" #include "drv/pci/pciConfigShow.h" #include "drv/pci/pciHeaderDefs.h" #else /\* PENTIUM was not supported in VxWorks 3.5.1 (Tornado1) \*/ #include "drv/pci/pcilomapLib.h" #include "drv/pci/pciLocalBus.h" #endif /\* set INCLUDE\_POSIX\_SEM to include Posix named semaphore handling \*/ #ifdef INCLUDE POSIX SEM #include <semaphore.h> #endif #endif Your OS: #ifdef IBS\_YourOS\_VERSION |\*\*| #include <stddef.h> #include <string.h> #include <stdio.h> #include <????> ... ...

/\*\*/ #endif





minecomponents.com

**TPHENIX** 

#### Appendix A

# A 1 List of Figures

| Section 1 |              |                                                                                         |
|-----------|--------------|-----------------------------------------------------------------------------------------|
|           | Figure 1-1:  | Disk directory structure1-4                                                             |
| Section 2 |              |                                                                                         |
|           | Figure 2-1:  | Controller board address windows in the host system2-3                                  |
|           | Figure 2-2:  | DIP switch assignment2-6                                                                |
|           | Figure 2-3:  | Structure of the Board_Number register2-9                                               |
|           | Figure 2-4:  | Structure of the IRQ_Control_Host register2-9                                           |
|           | Figure 2-5:  | Structure of the WDT_Control_Host register<br>during write access2-10                   |
|           | Figure 2-6:  | Structure of the WDT_Control_Host register<br>during read access2-11                    |
|           | Figure 2-7:  | Structure of the Reset_Control_Host register<br>during write access2-12                 |
|           | Figure 2-8:  | Structure of the Reset_Control_Host register<br>during read access2-13                  |
|           | Figure 2-9:  | Structure of the status register during write access2-13                                |
|           | Figure 2-10: | Structure of the status register during read access2-14                                 |
|           | Figure 2-11: | Structure of the Direct_IN register2-14                                                 |
|           | Figure 2-12: | Structure of the Direct_OUT register2-15                                                |
|           | Figure 2-13: | The MPM as the central interface of the controller board2-16                            |
|           | Figure 2-14: | MPM address area2-19                                                                    |
|           | Figure 2-15: | Segmentation of the SRAM2-20                                                            |
|           | Figure 2-16: | Diagram of the various MPM communication options 2-21                                   |
|           | Figure 2-17: | Bit assignment for the MPM configuration register<br>(address 3F90 <sub>hex</sub> )2-26 |



#### List of Figures

|    | Figure 2-18: | Bit assignment for status register 1<br>(address 3FB0 <sub>hex</sub> )             | .2-27 |
|----|--------------|------------------------------------------------------------------------------------|-------|
|    | Figure 2-19: | Bit assignment for status register 2<br>(address 3FB6 <sub>hex</sub> )             | .2-29 |
|    | Figure 2-20: | Bit assignment for<br>the set MPM node ready x register                            | .2-30 |
|    | Figure 2-21: | Bit assignment for<br>the set MPM node par ready x register                        | .2-31 |
|    | Figure 2-22: | Bit assignment for the status SysFail register (address 3FB2 <sub>hex</sub> )      | .2-32 |
|    | Figure 2-23: | Bit assignment for the set SysFail request register (address 3FA0 <sub>hex</sub> ) | .2-33 |
|    | Figure 2-24: | Bit assignment for the clear status bit x registers                                | .2-34 |
|    | Figure 2-25: | Bit assignment for handshake register A (address 3FC0 <sub>hex</sub> )             | .2-35 |
|    | Figure 2-26: | Bit assignment for handshake register B (address 3FC2 <sub>hex</sub> )             | .2-36 |
|    | Figure 2-27: | Bit assignment for the set HS Ax register<br>and set HS Bx register                | .2-37 |
|    | Figure 2-28: | Bit assignment for the set MPM node SG int x register                              | .2-38 |
|    | Figure 2-29: | Bit assignment for the status node SG inf register (address 3FB4 <sub>hex</sub> )  | .2-40 |
|    | Figure 2-30: | Bit assignment for the set sync register (address 3F9C <sub>hex</sub> )            | .2-41 |
| C. | Figure 2-31: | Bit assignment for the switch memory register<br>(address 3F98 <sub>hex</sub> )    | .2-42 |
|    | Figure 2-32: | Bit assignment for the read memory page register (address 3F98 <sub>hex</sub> )    | .2-43 |
|    | Figure 2-33: | Bit assignment for the serial address register (address 3FA6 <sub>hex</sub> )      | .2-43 |
|    | Figure 2-34: | Bit assignment for the serial data register (address 3FA4 <sub>hex</sub> )         | .2-44 |
|    | Figure 2-35: | Bit assignment for the program bits register (address 3FA2 <sub>hex</sub> )        | .2-45 |
|    |              |                                                                                    |       |



#### **List of Figures**

|           | Figure 2-36: | Bit assignment for the ready bits register (address 3FA2 <sub>hex</sub> )2-46 |
|-----------|--------------|-------------------------------------------------------------------------------|
|           | Figure 2-37: | Bit assignment for the configuration data register (address 2)2-46            |
| Section 3 |              |                                                                               |
|           | Figure 3-1:  | Read and write access to the DTA                                              |
|           | Figure 3-2:  | Asynchronous access of the application to<br>INTERBUS data                    |
|           | Figure 3-3:  | Asynchronous with synchronization pulse (implementation in the driver)        |
|           | Figure 3-4:  | Asynchronous, consistent access of the application to INTERBUS data           |
| Section 4 |              |                                                                               |
|           | Figure 4-1:  | Assignment of the handshake bits4-4                                           |
|           | Figure 4-2:  | Timing diagram for handshake bits4-5                                          |
|           | Figure 4-3:  | Timing diagram for handshake bits4-8                                          |
| Section 5 |              |                                                                               |
|           | Figure 5-1:  | Integrating the device driver into any operating system5-5                    |
|           | Figure 5-2:  | Integrating the device driver under UNIX5-6                                   |
|           | Figure 5-3:  | Integrating the device driver under Windows NT5-7                             |
|           | Figure 5-4:  | Device name structure5-11                                                     |
|           | Figure 5-5:  | devIOCtrl function5-20                                                        |
| Section 6 |              |                                                                               |
|           | Figure 6-1:  | File structures in the driver6-4                                              |



List of Figures

minecomponents.com



#### Appendix A

## A 2 List of Tables

## Section 1

| Table 1-1: | Directory contents                      | 1-4 |
|------------|-----------------------------------------|-----|
| Table 1-2: | Files in the "IBPCIMPM.SYS" directory   | 1-5 |
| Table 1-3: | Files in the "IB_INC\SYS" directory     | 1-5 |
| Table 1-4: | Files in the "IB_INC\USR" directory     | 1-6 |
| Table 1-5: | Files in the "VXWORX\EXAMPLE" directory | 1-6 |
| Table 1-6: | Files in the "VXWORX\SYSTEM" directory  | 1-6 |
| Table 1-7: | Files in the "VXWORX\DDI" directory     | 1-6 |
|            |                                         | ~ 4 |

## Section 2

| Table 2-1:  | PCI register                                                | 2-4  |
|-------------|-------------------------------------------------------------|------|
| Table 2-2:  | Possible settings for controller board numbers              | 2-7  |
| Table 2-3:  | Addresses of the I/O registers                              | 2-8  |
| Table 2-4:  | WDT_Interval                                                | 2-11 |
| Table 2-5:  | Bit pattern for the master reset                            | 2-12 |
| Table 2-6:  | Write register addresses in the MPM                         | 2-24 |
| Table 2-7:  | Read register addresses in the MPM                          | 2-25 |
| Table 2-8:  | Setting the MPM size                                        | 2-26 |
| Table 2-9:  | The set MPM node ready x register addresses                 | 2-30 |
| Table 2-10: | The set MPM node par ready x register addresses             | 2-31 |
| Table 2-11: | Clear status bit x register addresses                       | 2-34 |
| Table 2-12: | The set HS Ax register and the set HS Bx register addresses | 2-37 |
| Table 2-13: | The set MPM node SG int x register addresses                | 2-38 |
| Table 2-14: | Assignment of register bits to nodes                        | 2-39 |
| Table 2-15: | Assignment of the sync req bits to the nodes                | 2-42 |
|             |                                                             |      |



#### List of Tables

| Table 2-16: | Serial address register                        | 2-44 |
|-------------|------------------------------------------------|------|
| Table 2-17: | Meaning of the bits                            | 2-45 |
| Table 2-18: | Board present bits                             | 2-47 |
| Table 2-19: | Assignment of the array elements               | 2-53 |
| Table 2-20: | Assignment of the array elements for SVR[ ][ ] | 2-54 |
| Table 2-21: | Assignment of the array elements for AVR[ ][ ] | 2-55 |
| Table 2-22: | Assignment of the array elements for SNR[ ][ ] | 2-56 |

## Section 5

Additional utilities ......5-21



#### Appendix A

## A 3 Index

## А

| A24 area      | 2-3 |
|---------------|-----|
| Address lines | 2-3 |
|               |     |

## В

| Base address 2- | 3 |
|-----------------|---|
|-----------------|---|

## D

| Data Area (DTA)               | 2-48, 3-3  |
|-------------------------------|------------|
| Access                        | 3-4        |
| Data exchange                 | 3-3        |
| Size                          | 3-3        |
| Data format                   |            |
| Intel                         | 2-16       |
| Data Interface (DTI)          | 2-21, 2-22 |
| Data lines                    | 2-3        |
| DDI functions                 |            |
| ClearWatchDog                 | 5-27       |
| EnableWatchDog                | 5-26       |
| GetIBSDiagnostic              | 5-22       |
| GetIBSDiagnosticEx            | 5-23       |
| GetSlaveDiagnostic            | 5-24       |
| GetSysfailRegister            | 5-25       |
| GetWatchDogState              | 5-27       |
| GetWatchDogTimeout            | 5-28       |
| SetWatchDogTimeout            | 5-28       |
| TriggerWatchDog               | 5-26       |
| Device driver                 |            |
| Architecture and structure    | 5-3        |
| Functions                     |            |
| Device Driver Interface (DDI) | 5-3        |

| Device name                   | 5-11 |
|-------------------------------|------|
| Diagnostic register           | 2-19 |
| Diagnostic parameter register | 5-22 |
| Diagnostic status register    | 5-22 |
| E                             |      |

## Е

| Exchanging messages              | 4-3 |
|----------------------------------|-----|
| Extended Data Area (ExDTA) 2-48, | 3-3 |
| Size                             | 3-3 |

| -3       | Size 3-3                       |
|----------|--------------------------------|
| -4       | F                              |
| -3       |                                |
| -3       | Functions                      |
|          | closeDevice 5-4, 5-8, 5-12     |
| 16       | devCtrl 5-4, 5-8, 5-19         |
| 22       | Init device driver routine 5-8 |
| -2<br>-3 | initDDI 5-4                    |
| -0       | Interrupt service routine 5-9  |
| 27       | intrServiceFunction 5-4, 5-18  |
| 26       | openDevice 5-4, 5-8, 5-11      |
| 22       | readDTI 5-4, 5-8, 5-14         |
|          | readMXI 5-4, 5-8, 5-16         |
| 23       | Release device driver routine  |
| 24       | releaseDDI 5-4                 |
| 25       | setMsgNotification 5-10        |
| 27       | Utilities                      |
| 28       |                                |
| 28       | writeDTI 5-4, 5-8, 5-13        |
| 26       | writeMXI 5-4, 5-8, 5-15        |

## Н

| Hardware interface | 2-3  |
|--------------------|------|
| Hardware register  | 2-17 |



#### Index

| Host interface | 2-6      | 2-16 |
|----------------|----------|------|
|                | <u> </u> | 2 10 |

## I

| I/O area                   | 2-3       |
|----------------------------|-----------|
| Init device driver routine | 5-8       |
| Initialization             | 5-10      |
| Interfaces                 | 2-3       |
| Interrupt operation        | 2-3       |
| Interrupt service routine  | 5-9, 5-18 |

## Μ

| Mailbox Area (MXA) 2-22            | 2, 2-48 |
|------------------------------------|---------|
| Mailbox Interface (MXI) 2-21, 2-22 | 2, 2-54 |
| Communication                      | 4-3     |
| Memory manager                     | . 2-17  |
| MPM                                | . 2-16  |
| Address area                       | . 2-19  |
| Communication methods              | . 2-21  |
| Hardware register                  | . 2-24  |
| Read register (addresses)          | . 2-25  |
| Software register                  | . 2-48  |
| Write register (addresses)         | . 2-24  |
| MPM descriptor 2-48                | 8, 2-49 |
| Multi-port memory                  | . 2-16  |

## Ρ

| PCI bus       | 2-3 |
|---------------|-----|
| PCI connector | 2-3 |

## R

| 2-55, 4-5 |
|-----------|
| 2-9       |
| 2-34      |
|           |

| Configuration data       2-46         Handshake register A       2-35, 4-4         Handshake register B       2-36, 4-4         IRQ_Control_Host       2-9         MPM configuration       2-26         Program bits       2-45         Read memory page       2-43         Ready bits       2-46         Reset_Control_Host       2-12         Send vector register       2-48, 2-54, 4-5         Serial address       2-43, 2-44         Set HS Ax       2-37         Set HS Bx       2-31         Set MPM node par ready x       2-30         Set MPM node ready x       2-33         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status register 1       2-27, 4-4         Status register 2       2-29         Status sysFail       2-32         Subnode register       2-32         Subnode register       2-36         Switch memory       2-42         WDT_Control_Host       2-10 |     |                                | o 40   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------|--------|
| Handshake register B2-36, 4-4IRQ_Control_Host2-9MPM configuration2-26Program bits2-45Read memory page2-43Ready bits2-46Reset_Control_Host2-12Send vector register2-48, 2-54, 4-5Serial address2-43, 2-44Set IS Ax2-37Set HS Ax2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set SysFail request2-33Status and control register2-17Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-36Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | •                              |        |
| IRQ_Control_Host2-9MPM configuration2-26Program bits2-45Read memory page2-43Ready bits2-46Reset_Control_Host2-12Send vector register2-48, 2-54, 4-5Serial address2-43, 2-44Set HS Ax2-37Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-33Set sync2-41Set SysFail request2-33Status and control register2-17Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-36Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | Handshake register A 2-3       | 5, 4-4 |
| MPM configuration2-26Program bits2-45Read memory page2-43Ready bits2-46Reset_Control_Host2-12Send vector register2-48, 2-54, 4-5Serial address2-43, 2-44Serial data2-43Set HS Ax2-37Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-33Set sync2-41Set SysFail request2-33Status and control register2-17Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-36Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | Handshake register B 2-3       | 6, 4-4 |
| Program bits       2-45         Read memory page       2-43         Ready bits       2-46         Reset_Control_Host       2-12         Send vector register       2-48, 2-54, 4-5         Serial address       2-43, 2-44         Serial data       2-43         Set HS Ax       2-37         Set HS Bx       2-37         Set MPM node par ready x       2-31         Set MPM node ready x       2-30         Set MPM node SG int x       2-33         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status register 1       2-27, 4-4         Status register 2       2-29         Status SysFail       2-32         Subnode register       2-32         Subnode register       2-32         Switch memory       2-42         WDT_Control_Host       2-10                                                                                                                                 |     | IRQ_Control_Host               | 2-9    |
| Read memory page2-43Ready bits2-46Reset_Control_Host2-12Send vector register2-48, 2-54, 4-5Serial address2-43, 2-44Serial data2-44Set HS Ax2-37Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-33Set sync2-41Set SysFail request2-33Status and control register2-17Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-36Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | MPM configuration              | 2-26   |
| Ready bits.       2-46         Reset_Control_Host       2-12         Send vector register       2-48, 2-54, 4-5         Serial address.       2-43, 2-44         Serial data       2-44         Set HS Ax       2-37         Set HS Bx       2-37         Set MPM node par ready x       2-30         Set MPM node ready x       2-30         Set MPM node SG int x       2-33         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status register 1       2-27, 4-4         Status register 2       2-29         Status SysFail       2-32         Subnode register       2-36         Switch memory       2-42         WDT_Control_Host       2-10                                                                                                                                                                                                                                       |     | Program bits                   | 2-45   |
| Reset_Control_Host       2-12         Send vector register       2-48, 2-54, 4-5         Serial address       2-43, 2-44         Serial data       2-44         Set HS Ax       2-37         Set HS Bx       2-37         Set MPM node par ready x       2-31         Set MPM node ready x       2-30         Set MPM node SG int x       2-33         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status register 1       2-27, 4-4         Status register 2       2-29         Status SysFail       2-32         Subnode register       2-36         Switch memory       2-42         WDT_Control_Host       2-10                                                                                                                                                                                                                                                                       |     | Read memory page               | 2-43   |
| Send vector register       2-48, 2-54, 4-5         Serial address       2-43, 2-44         Serial data       2-44         Set HS Ax       2-37         Set HS Bx       2-37         Set MPM node par ready x       2-31         Set MPM node ready x       2-30         Set MPM node ready x       2-33         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status register 1       2-27, 4-4         Status register 2       2-29         Status SysFail       2-32         Subnode register       2-32         Switch memory       2-42         WDT_Control_Host       2-10                                                                                                                                                                                                                                                                                                              |     | Ready bits                     | 2-46   |
| Serial address       2-43, 2-44         Serial data       2-44         Set HS Ax       2-37         Set HS Bx       2-37         Set MPM node par ready x       2-31         Set MPM node ready x       2-30         Set MPM node SG int x       2-38         Set sync       2-41         Set SysFail request       2-33         Status and control register       2-17         Status node SG inf       2-40         Status register 1       2-27, 4-4         Status register 2       2-29         Status SysFail       2-32         Subnode register       2-36         Switch memory       2-42         WDT_Control_Host       2-10                                                                                                                                                                                                                                                                                                                          |     | Reset_Control_Host             | 2-12   |
| Serial data2-44Set HS Ax2-37Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-38Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     | Send vector register 2-48, 2-5 | 4, 4-5 |
| Set HS Ax2-37Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-38Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     | Serial address 2-43            | , 2-44 |
| Set HS Bx2-37Set MPM node par ready x2-31Set MPM node ready x2-30Set MPM node SG int x2-38Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     | Serial data                    | 2-44   |
| Set MPM node par ready x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     | Set HS Ax                      | 2-37   |
| Set MPM node ready x2-30Set MPM node SG int x2-38Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     | Set HS Bx                      | 2-37   |
| Set MPM node SG int x2-38Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     | Set MPM node par ready x       | 2-31   |
| Set sync2-41Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     | Set MPM node ready x           | 2-30   |
| Set SysFail request2-33Status and control register2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     | Set MPM node SG int x          | 2-38   |
| Status and control register.2-17Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail.2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     | Set sync                       | 2-41   |
| Status node SG inf2-40Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     | Set SysFail request            | 2-33   |
| Status register 12-27, 4-4Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     | Status and control register    | 2-17   |
| Status register 22-29Status SysFail2-32Subnode register2-56Switch memory2-42WDT_Control_Host2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     | Status node SG inf             | 2-40   |
| Status SysFail                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     | Status register 1 2-2          | 7, 4-4 |
| Subnode register 2-56<br>Switch memory 2-42<br>WDT_Control_Host 2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     | Status register 2              | 2-29   |
| Switch memory 2-42<br>WDT_Control_Host 2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     | Status SysFail                 | 2-32   |
| WDT_Control_Host 2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | Subnode register               | 2-56   |
| WDT_Control_Host 2-10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     | Switch memory                  | 2-42   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     | -                              |        |
| Release device driver routine 5-9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Rel |                                |        |

## S

| Signal Interface      | 2-21  |
|-----------------------|-------|
| Software interface    | . 2-3 |
| Software register     | 2-17  |
| SRAM                  | 2-20  |
| Standard address area | . 2-3 |



| Static RAM 2-20                |  |
|--------------------------------|--|
| Status SysFail register 5-25   |  |
| Structures                     |  |
| CHAR devNamesDTI 5-33          |  |
| CHAR devNamesMXI 5-33          |  |
| T_AVR_CTRL avrCtrl 5-32        |  |
| T_DEV_CTRL devCtrl 5-29        |  |
| T_MSG_CTRL msgCtrl 5-32        |  |
| T_NODE_CTRL nodeCtrl 5-29      |  |
| T_NODE_HD_CTRL nodeHdCtrl 5-31 |  |
| T_NOTIFY_CTRL notifyCtrl 5-31  |  |
| T_SVR_CTRL svrCtrl 5-32        |  |
| USIGN16 avrToutCnt 5-33        |  |
| USIGN16 msgCnt 5-33            |  |
| USIGN16 svrToutCnt 5-33        |  |
| Switches                       |  |
| Test mode 2-7                  |  |
| Synchronization request 2-21   |  |
| SysFail interrupt 2-33         |  |
| SysFail request 2-21, 2-23     |  |
| SysFail signal 2-33            |  |
| Sysfail signal 5-25            |  |

## Т

Transmitting messages ..... 4-7



Index

minecomponents.com

PHENIX

#### We Are Interested in Your Opinion!

We would like to hear your comments and suggestions concerning this document.

We review and consider all comments for inclusion in future documentation.

Please fill out the form on the following page and fax it to us or send your comments, suggestions for improvement, etc. to the following address:

Phoenix Contact GmbH & Co. KG **Marketing Services Dokumentation INTERBUS** 32823 Blomberg GERMANY

S.C - (0, 49 - (0) tecdoc@p. Phone +49 - (0) 52 35 - 3-00 Telefax +49 - (0) 52 35 - 3-4 20 66 E-Mail tecdoc@phoenixcontact.com

| <b>PHŒNIX</b><br>CONTACT |
|--------------------------|
|--------------------------|

| FAX Reply                                                             |                  |               | L'ACONTACT                  |         |        |  |
|-----------------------------------------------------------------------|------------------|---------------|-----------------------------|---------|--------|--|
| Phoenix Contact GmbH & Co. KG<br>Marketing Services                   |                  | Date:         |                             |         |        |  |
| Dokumentation INTERBUS                                                |                  | Fax No:       | +49 - (0) 52 35 - 3-4 20 66 |         |        |  |
| From:                                                                 |                  |               |                             |         |        |  |
| Company:                                                              |                  | Name:         |                             |         |        |  |
|                                                                       |                  | Department:   |                             |         |        |  |
| Address:                                                              |                  | Job function: |                             |         |        |  |
| City, ZIP<br>code:                                                    |                  | Phone:        |                             | 0       |        |  |
| Country:                                                              |                  | Fax:          | G                           |         |        |  |
| Document:                                                             |                  |               |                             |         |        |  |
| Designation:                                                          | IBS PCI DDK UM E | Revision: A   | Order No.: 26 98 16 4       |         | 8 16 4 |  |
| My Opinion                                                            | on the Document  |               |                             |         |        |  |
| Form                                                                  |                  |               | Yes                         | In part | No     |  |
| Is the table of contents clearly arranged?                            |                  |               |                             |         |        |  |
| Are the figures/diagrams easy to understand/helpful?                  |                  |               |                             |         |        |  |
| Are the written explanations of the figures adequate?                 |                  |               |                             |         |        |  |
| Does the quality of the figures meet your expectations/needs?         |                  |               |                             |         |        |  |
| Does the layout of the document allow you to find information easily? |                  |               |                             |         |        |  |
| Contents                                                              |                  |               | Yes                         | In part | No     |  |
| Is the phraseology/terminology easy to understand?                    |                  |               |                             |         |        |  |
| Are the index entries easy to understand/helpful?                     |                  |               |                             |         |        |  |
| Are the examples practice-oriented?                                   |                  |               |                             |         |        |  |
| Is the document easy to handle?                                       |                  |               |                             |         |        |  |
| Is any important information missing? If yes, what?                   |                  |               |                             |         |        |  |

## **Other Comments:**