# SIMATIC NET

# DPC31 Siemens PROFIBUS-DP Controller with C31 Core

Hardware Description

Date May, 19, 2004



#### Liability Exclusion

We have tested the contents of this document regarding agreement with the hardware and software described. Nevertheless, deviations can't be ruled out, so that we are not guaranteeing complete agreement. However, the data in this document is checked periodically. Required corrections are included in subsequent editions. We gratefully accept suggestions for improvement.

#### Copyright

Copyright Siemens AG 2004 All Rights Reserved Unless permission has been expressly granted, passing on this document or copying it, or using and sharing its content is not allowed. Offenders will be held liable. All rights reserved, in the event a patent is granted, or a utility model or design is registered.

The trade marks SIMATIC, SINEC L2 are protected by law for Siemens through application/registration. All other product and system names are (registered) trade marks of their respective proprietors, and are to be treated as such.

Subject to technical change

## **Overview of Versions**

| Version No. | Date             | Page            | Comment                                                       |
|-------------|------------------|-----------------|---------------------------------------------------------------|
| 0.x         |                  |                 | First version                                                 |
| 1.0         | Dec.14,<br>2000  | div.            | RS485 wiring corrected<br>RXD_RXS and XCTS_RXA Data<br>Buffer |
| 1.1         | Apr. 25,<br>2002 | div.            | Casing, wiring of external processor                          |
| 1.2         | Apr. 9,<br>2003  | Chap.<br>12.2.2 | Optimization of the bus cycle                                 |
| 2.0         | Feb. 16,<br>2004 | div.            | Detailed description for DPC31 STEP C                         |
| 2.1         | May, 19,<br>2004 | Chap. 13.3      | Correction of the Order number                                |

## **Table of Contents**

| 1      | INT                                                         | RODUCTION                                                                                                                                                                                                                                                                                                                            | 7                                                        |
|--------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|
| 2      | ٥v                                                          | <b>ERVIEW</b>                                                                                                                                                                                                                                                                                                                        | 8                                                        |
|        | 2.1                                                         | General Data                                                                                                                                                                                                                                                                                                                         | 8                                                        |
|        | 2.2                                                         | Differences Between the DPC31 and the SPC3/SPC4                                                                                                                                                                                                                                                                                      | 8                                                        |
|        | 2.3                                                         | Function Overview (Block Diagram)                                                                                                                                                                                                                                                                                                    | 9                                                        |
|        | 2.4                                                         | Pin Description                                                                                                                                                                                                                                                                                                                      | 10                                                       |
| 3      | ME                                                          | MORY ASSIGNMENT                                                                                                                                                                                                                                                                                                                      | 12                                                       |
|        | 3.1                                                         | Memory Area Distribution in the DPC31                                                                                                                                                                                                                                                                                                | 12                                                       |
|        | 3.2                                                         | Control Unit Parameters (Latches/Registers)                                                                                                                                                                                                                                                                                          | 12                                                       |
|        | 3.3                                                         | Organizational Parameters (RAM)                                                                                                                                                                                                                                                                                                      | 15                                                       |
| 4      | AS                                                          | IC INTERFACE                                                                                                                                                                                                                                                                                                                         | 23                                                       |
| 5<br>S | CC<br>YSTE                                                  | MMUNICATION FUNCTIONS OF THE SEQUENTIAL CONTROL                                                                                                                                                                                                                                                                                      | 24                                                       |
|        | 5.1<br>5.1.<br>5.1.<br>5.1.                                 | 2 Request Interface for DPS and FDL (Instruction Queue)                                                                                                                                                                                                                                                                              | 25<br>28<br>30<br>32                                     |
|        | 5.2<br>5.2.<br>5.2.<br>5.2.<br>5.2.<br>5.2.<br>5.2.<br>5.2. | <ul> <li>2 Set_Param, Prm (SAP61)</li> <li>3 Check_Config, Chk_Cfg (SAP62)</li> <li>4 Slave_Diagnosis (SAP60)</li> <li>5 Write_Read_Data (Default SAP)</li> <li>2.5.1 DX-Entered-Interrupt</li> <li>6 Global_Control (SAP58)</li> <li>7 Read_Inputs (SAP56)</li> <li>8 Read_Outputs (SAP57)</li> <li>9 Get_Config (SAP59)</li> </ul> | 33<br>35<br>36<br>38<br>40<br>41<br>42<br>44<br>45<br>45 |
|        | 5.3<br>5.3.<br>5.3.<br>5.3.                                 | - 0                                                                                                                                                                                                                                                                                                                                  | 48<br>48<br>49<br>50                                     |

| 6 USER FUNCTIONS ON THE C31 CONTROLLER                           | 50 |
|------------------------------------------------------------------|----|
| 7 DESCRIPTION OF THE HARDWARE BLOCKS                             | 50 |
| 7.1 Universal Processor Interface                                | 50 |
| 7.1.1 Bus Interface Unit (BIU)                                   | 51 |
| 7.1.2 IO Interface                                               | 55 |
| 7.1.3 Interface Signals                                          | 56 |
| 7.1.4 Interrupt Controller of the $\mu$ P Interface in the DPC31 | 56 |
| 7.2 Synchronous Serial Interface (SSC Interface)                 | 59 |
| 7.3 80C31 Core and Interface                                     | 62 |
| 7.3.1 Reset Phase of the C31                                     | 63 |
| 7.3.1.1 Boot Type Setting                                        | 63 |
| 7.3.1.2 Boot Type 2                                              | 63 |
| 7.3.2 80C31 Core                                                 | 64 |
| 7.3.2.1 Data Area                                                | 64 |
| 7.3.2.2 Code Area                                                | 66 |
| 7.3.3 Code RAM                                                   | 66 |
| 7.3.4 Expansion Interface to the 80C31 Core                      | 67 |
| 7.3.5 Interface Signals                                          | 67 |
| 7.4 C31 Interrupt Controller in the DPC31                        | 68 |
| 7.5 Serial PROFIBUS Interface                                    | 68 |
| 7.5.1 Asynchronous Physics Unit (NRZ)                            | 68 |
| 7.5.1.1 Transmitter                                              | 68 |
| 7.5.1.2 Receiver                                                 | 68 |
| 7.5.1.3 Interface Signals                                        | 69 |
| 7.5.2 Synchronous Physics Unit (Manchester)                      | 69 |
| 7.5.2.1 Transmitter                                              | 69 |
| 7.5.2.2 Receiver                                                 | 71 |
| 7.5.2.3 Power-Saving Serial Interface                            | 72 |
| 7.5.2.4 Interface Signals                                        | 78 |
| 7.6 DPS Watchdog Timer                                           | 78 |
| 7.7 Watchdog Timer                                               | 78 |
| 7.7.1 Automatic Baud Rate Detection                              | 78 |
| 7.7.2 Baud rate Monitoring                                       | 78 |
| 7.7.3 Response Monitoring                                        | 79 |
| 7.8 Clock Supply                                                 | 79 |
| 7.8.1 PLL                                                        | 79 |
| 8 TEST SUPPORT                                                   | 81 |
| 8.1 Emulator Connection for the C31                              | 81 |
| 9 ELECTRICAL SPECIFICATIONS                                      | 83 |
| 9.1 Maximum Limits                                               | 83 |
|                                                                  |    |
| 9.2 Permitted Operating Values                                   | 83 |
| 9.3 Guaranteed Operating Range for the Specified Parameters      | 84 |

## ComDeC

# SIEMENS

| <ul> <li>9.4 Power Loss</li> <li>9.4.1 Power-Up of the Supply Voltage</li> <li>9.4.2 Structure of the Pad Cells with 5V Tolerance</li> <li>9.4.3 DC Specification of the Pad Cells</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                | 84<br>84<br>85<br>87                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| <ul> <li>9.5 AC Specification</li> <li>9.5.1 Driver Capability</li> <li>9.5.2 Timing Diagrams, Signal Run Times</li> <li>9.5.2.1 Clock Supply (XPLLEN = '1')</li> <li>9.5.2.2 Clock Outputs</li> <li>9.5.2.3 Reset</li> <li>9.5.2.4 Interrupt</li> <li>9.5.2.5 μP Interface</li> <li>9.5.2.5.1 Synchronous Intel Mode (80C32)</li> <li>9.5.2.5.2 Asynchronous Intel Mode (X86 Mode)</li> <li>9.5.2.5.3 Synchronous Motorola Mode (E_Clock mode; for example, 68HC11)</li> <li>9.5.2.6 C31 Memory Interface (internal C31 on external memory)</li> <li>9.5.2.8 SSC Interface (SPI)</li> </ul> | 88<br>88<br>89<br>89<br>89<br>90<br>90<br>90<br>92<br>93<br>95<br>97<br>99<br>102 |
| 10 MECHANICAL SPECIFICATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 103                                                                               |
| 10.1PQFP 100 Casing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 103                                                                               |
| 10.11 QTT 100 Odding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                   |
| 11 DPC31 PINOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 106                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                   |
| 11 DPC31 PINOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 106                                                                               |
| 11 DPC31 PINOUT<br>12 APPLICATION NOTES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 106<br>107                                                                        |
| 11 DPC31 PINOUT<br>12 APPLICATION NOTES<br>12.1DPC31 Wiring<br>12.2PROFIBUS Interface<br>12.2.1 Pin Assignment                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>106</b><br><b>107</b><br>107<br>107<br>107                                     |
| 11 DPC31 PINOUT<br>12 APPLICATION NOTES<br>12.1DPC31 Wiring<br>12.2PROFIBUS Interface<br>12.2.1 Pin Assignment<br>12.2.2 Wiring Example RS485 Interface                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>106</b><br><b>107</b><br>107<br>107<br>107<br>109                              |
| 11 DPC31 PINOUT<br>12 APPLICATION NOTES<br>12.1DPC31 Wiring<br>12.2PROFIBUS Interface<br>12.2.1 Pin Assignment<br>12.2.2 Wiring Example RS485 Interface<br>13 APPENDIX                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>106</b><br><b>107</b><br>107<br>107<br>107<br>109<br><b>110</b>                |

## 1 Introduction

Siemens offers to its users several ASICs for data exchange between automation devices that, on the basis of IEC 61158, support or completely process the data traffic between the individual automation stations.

To support intelligent master/slave solutions, that is, implementations with a microprocessor, the following ASICs are available. All ASICs do the following: support the transmission rates of 9.6 kBits/s ... 12000 kbit/s, autonomously set themselves to the transmission rate specified by the master and monitor it. After these ASICs receive a correct message, they autonomously generate the requested response messages.

In the **ASPC2** (Advanced Siemens PROFIBUS Controller), many components of Layer2 of the OSI model are already integrated according to ISO, but it still needs the support of a processor. This ASIC supports baud rates up to 12000 kbit/s; however, in its complexity, it is conceived more for master applications.

The **SPC3** (Siemens PROFIBUS Controller), through the integration of the complete PROFIBUS DP slave protocol, considerably relieves the processor of an intelligent PROFIBUS slave.

However, in the field of automation, there are also simple devices such as switches, thermoelements, etc. that do not require a microprocessor for recording their states.

For a low cost adaptation of such devices, two additional ASICs are available: the **SPM2** (Siemens PROFIBUS Multiplexer, Version 2) and **LSPM2** (Lean Siemens PROFIBUS Multiplexer). These chips process as DP slaves in the bus system. The LSPM2 has the same functions as the SPM2 but with a lower number of I/O and diagnostic ports.

The **DPC31** (<u>DP</u> <u>C</u>ontroller with integrated 8031 core) is a highly integrated PROFIBUS slave ASIC. The DPC31 is a slave controller for both PROFIBUS DP/DPV1 and PA applications. The uses of this chip cover a wide area. On the one hand, it can be used for simple, intelligent applications that make do with the integrated C31 core.

On the other hand, it can be used for high performance slave solutions that have increased communication requirements. This requirement is met with an internal RAM that has been increased to 6kByte.

Approximately 5.5kByte of communication memory is available to the user.

#### The DPC31 has the following main features:

- integrated standard C31 core with an additional 3<sup>rd</sup> timer (Timer 2)
- low processor load through the integration of the complete DP slave protocol
- simple processor interface for a large number of processors:

| INTEL:    | 8032, 80x86       |
|-----------|-------------------|
| Siemens:  | C166              |
| Motorola: | HC11, HC16, HC916 |
|           |                   |

- SSC interface (SPI) for interfacing serial EEPROMs, A/D converters, etc.
- integration of synchronous as well as asynchronous bus physics

This document explains the hardware configuration and the wiring of the DPC31.

In addition, Siemens offers a separate software package that relieves the user of local H/W register manipulations and memory calculations. The package provides a convenient C-interface for interfacing Profibus communication with the slave process.

## 2 Overview

### 2.1 General Data

| Package:            | 100 Pin PQFP                                                                                                      |
|---------------------|-------------------------------------------------------------------------------------------------------------------|
| Baud rate:          | Asynchronous: 9.6, 19.2, 45.45, 93.75, 187.5, 500 kBd, 1.5, 3, 6 & 12<br>MBd                                      |
|                     | Synchronous: 31.25 kBd                                                                                            |
| Bus Interface:      | 8-Bit asynchronous/synchronous Intel and Motorola interface                                                       |
| C31 Ports:          | Standard Port Interface (4 Ports) for external memory expansion and emulator interface                            |
| SSC Interface:      | Synchronous serial interface (SPI) for connecting serial E <sup>2</sup> PROMs, A/D converters, etc.               |
| Memory Area         | 6 kByte (approx. 5.5 kByte utilizable) can be directly addressed and can be broken down into data and code memory |
| Environmental Cond. | : 3.3V ±10%; -40 to +85 °C                                                                                        |

| Characteristics                | DPC31                                | SPC3                     | SPC4                     |
|--------------------------------|--------------------------------------|--------------------------|--------------------------|
| General:                       |                                      |                          |                          |
| Package                        | 100 Pin PQFP                         | 44 Pin PQFP              | 44 Pin PQFP              |
| External µP Interface          | parallel, 8 bits                     | parallel, 8 bits         | parallel, 8 bits         |
| Family                         | Siemens, Intel, Motorola             | Siemens, Intel, Motorola | Siemens, Intel, Motorola |
| Preprocessing                  | yes, via int. C31                    | no                       | no                       |
| External Memory                | yes, Flash, RAM etc.                 | no                       | no                       |
| Expansion (C31)                |                                      |                          |                          |
| SSC Interface (SPI)            | yes, for example E <sup>2</sup> PROM | no                       | no                       |
|                                | up to 64 kByte,                      |                          |                          |
|                                | A/D conv. (AD7714)                   |                          |                          |
| I/O Interface                  | yes, up to 40 bits                   | no                       | no                       |
| Internal PLL                   | yes, input 12 MHz                    | no                       | no                       |
| Communication RAM              | max. 5.5 kByte                       | 1.4 kByte                | 1.14 kByte               |
|                                |                                      |                          | (1.64 for SPC41)         |
| PB Communication:              |                                      |                          |                          |
| Baud rate                      |                                      |                          |                          |
| async. RS485                   | 9.6 kBd to 12 MBd                    | 9.6 kBd to 12 MBd        | 9.6 kBd to 12 MBd        |
| sync. Manchester               | 31.25kBd                             | no                       | 31.25 kBd                |
| DP Slave                       | fully integrated                     | fully integrated         | partially integrated     |
| Receive Resources              | exchange buffer                      | exchange buffer          | polling list             |
| Receive Resources              | exchange builer                      | exchange builer          | polinig list             |
| Integrated User                |                                      |                          |                          |
| Functions:                     |                                      |                          |                          |
| E <sup>2</sup> PROM Read/Write | No                                   | no                       | no                       |
| DPV1 Protocol                  | No                                   | no                       | no                       |
|                                |                                      |                          |                          |

### 2.2 Differences Between the DPC31 and the SPC3/SPC4

 Table 2.2-1:
 Differences with respect to SPC3 and SPC4

### 2.3 Function Overview (Block Diagram)

Figure 2.3-1 shows the block diagram of the DPC31. The DPC31 has a **bus interface** for connecting an external microprocessor. It is a parameterizable, synchronous/asynchronous 8-bit interface for various Siemens, Intel, and Motorola micro-controllers/processors. Via the 13-bit address bus, the user can directly access the internal 5.5k RAM or the register cells. If the application does not need an external processor, the ports of the bus interface can be used as I/O. This makes 27 I/O bits available that the internal C31 can address individually.

The sequence control enters various events (for example, indication events, error events, etc.) in the **interrupt controller** that are signaled to the slave firmware via the interrupt pin. These events can be enabled individually via a mask register. Acknowledgement is made via the acknowledge register.

The **SSC interface (SPI)** is used for connecting a serial  $E^2$ PROM or an A/D converter (such as AD7714). This interface is laid out only as a master interface. The user must create an appropriate program for the C31 for control of this interface

The **C31** interface includes the ports of the standard controller. Via this interface, an external memory- and I/O expansion can be implemented. Via corresponding CS signals, the code and data address areas are coded out that are not used internally. In addition, up to 13 bits of I/O can be connected via these ports. The C31/32 emulator (Hitex etc.) is also controlled via this interface.

Via the **register cells**, the following are accessed: internal registers, the DPS(DP Slave) control units and the SSC module. The DPS control units represent the user interface to the DPS layer that is implemented via individual buffers. These control units exchange the buffers.

The integrated **C31** is fully compatible with the standard microcontroller. Also integrated is a **256 byte data RAM**. Via a second **interrupt controller**, the interrupt events mentioned above can also be entered in the C31. This makes it possible to distribute interrupt events between an external and an internal application.

The **bus physics unit** includes the asynchronous Layer1 (RS485: 9.6kBd to 12 MBd) and the synchronous Layer1 (IEC 1158-2; Manchester encoded: 31.25kBd), which also allows the chip to be operated in an intrinsically safe environment.

In the **clock unit**, an analog **PLL** is integrated, to which an external 12MHz quartz must be connected. With it, the PLL generates the internal 48MHz clock pulse for the asynchronous mode. In the synchronous mode, the PLL is switched off and an external clock pulse of 2 to 16 MHz is applied. In addition, power management is implemented in the clock unit that switches off internal clock pulses in certain states. As outputs, the internal working clock pulse divided by 2 and by 4 is available.



Figure 2.3-1: Block Diagram DPC31

### 2.4 Pin Description

The DPC31 has a 100 pin PQFP package with the following signals:

DPC31 HW

ComDeC

| Function Group   | Name      | Pins | Туре | Voltage | Function                                         |
|------------------|-----------|------|------|---------|--------------------------------------------------|
|                  |           |      |      | Proof   |                                                  |
| C31 Interface    | PA        | 8    | I/O  | 5V      | Corresponds to P0 for the discrete type          |
|                  | PB        | 8    | I/O  | 5V      | Corresponds to P1 for the discrete type          |
|                  | PC        | 8    | I/O  | 5V      | Corresponds to P2 for the discrete type          |
|                  | PD        | 8    | I/O  | 5V      | Corresponds to P3 for the discrete type          |
|                  | ALE       | 1    | I/O  | 5V      | Address Latch Enable                             |
|                  | XPSEN     | 1    | I/O  | 5V      | For emulation only                               |
|                  | XCSDATA   | 1    | 0    | 5V      | Chip select for external RAM                     |
|                  | XCSCODE   | 1    | 0    | 5V      | Chip select for external ROM                     |
|                  | BOOTTYP   | 2    | I    | 5V      | Type for loading the user program                |
|                  | DBX       | 1    |      | 5V      | Switch to In Circuit Emulator                    |
| µP Interface     | PE        | 8    | I/O  | 5V      |                                                  |
|                  | PF        | 8    | I/O  | 5V      |                                                  |
|                  | PG        | 8    | I/O  | 5V      |                                                  |
|                  | PH        | 3    | I/O  | 5V      |                                                  |
|                  | BUSTYP    | 3    |      | 5V      |                                                  |
| SSC Interface    | SSCLK     | 1    | 0    | 5V      | Connection for SPI Chips, Clock                  |
|                  | SSDO      | 1    | 0    | 5V      | Connection for SPI Chips, Data_Out               |
|                  | SSDI      | 1    |      | 5V      | Connection for SPI Chips, Data_In                |
| PLL + Clock Unit | XTAL1_CLK | 1    | I    | 3.3V    | Quartz connection / Clock supply                 |
|                  | XTAL2     | 1    | 0    | 3.3V    | Quartz connection                                |
|                  | AVDD      | 1    |      |         | Separate V <sub>DD</sub> supply for PLL          |
|                  | AGND      | 1    |      |         | Separate GND supply for PLL                      |
|                  | XPLLEN    | 1    | I    | 5V      | Switching off the PLL and supply clock pulse via |
|                  |           |      |      |         | XTAL1_CLK                                        |
|                  | CLKOUT1X2 | 1    | 0    | 5V      | Clock pulse output CLK/2 (without reset)         |
|                  | CLKOUT1X4 | 1    | 0    | 5V      | Clock pulse output CLK/4 (without reset)         |
| Physics Unit     | RTS_TXE   | 1    | 0    | 3.3V    |                                                  |
|                  | TXD_TXS   | 1    | 0    | 3.3V    |                                                  |
|                  | XCTS_RXA  | 1    | I    | 5V      |                                                  |
|                  | RXD_RXS   | 1    |      | 5V      |                                                  |
| General          | RESET     | 1    | Ι    | 5V      | Reset Input                                      |
| Test             | NTEST1    | 1    | I    | 5V      | Test Pin                                         |
|                  | NTEST2    | 1    | I    | 5V      | Test Pin                                         |
|                  | TST1      | 1    | I    | 5V      | Test Pin                                         |
| Supply           | VDD       | 4    |      |         | +3.3V                                            |
|                  | GND       | 9    |      |         | OV                                               |
| Total            |           | 100  |      |         |                                                  |

#### Figure 2.4-1: DPC31 Pin List

Because of the 5V-tolerant I/O, and in order to ensure the least possible power loss, no pullup or pull-down resistors are integrated in the pad cells; that is, <u>all</u>unused inputs or all output ports (since these are switched as input after reset) are to be applied to one defined level (Ports A, B, D, E, F, G, and H). This is not necessary for Port C since it is permanently configured as output. A bus contention is permitted for a maximum of 20ns.

## 3 Memory Assignment

### 3.1 Memory Area Distribution in the DPC31

Table 3.1-1 shows the distribution of the internal 8k address space of the DPC31. Via this address space, the user interface to communication (DPS) is mapped. It does not matter whether the user program is running internally on the C31 or on the external microprocessor; the interface is identical in both cases.

The address area is subdivided into a 2K address space for the register cells and a 6k address space for the internal RAM. The internal registers (interrupt controller, Mode Register1, DPS control units, SSC interface) are located in the register area. Certain registers can only be read or written.

The RAM starts at address 800h. In the first area, the internal work cells are located (bit array, variables). The user is not to access this area. The sequential control system uses these cells for processing the protocol. Starting with address 0840h, the organizational parameters (parameter cells, buffer ptr(pointer) are located in the RAM. In the parameter cells, general parameter assignment data is transferred (Param Register, station address, Ident No., etc.), or status displays are stored (status register, GC\_Command, Score\_Register, etc.). The buffer pointers describe the entire buffer management for the SAPs. At address 08A0h, the buffers generated by the user start, corresponding to the parameter assignment of the organizational parameters. The sequence of the buffers can be selected as required. All buffers or IiDXB must be located on segment addresses (32 bytes segmentation).

| 1FFFh   |          | Code Area for the Internal C31 |                         |  |  |
|---------|----------|--------------------------------|-------------------------|--|--|
| 08A0h   |          | Communic-<br>ation Area        | Buffer Area             |  |  |
| 00/1011 |          |                                |                         |  |  |
|         |          |                                | Organizational          |  |  |
| 0840h   |          |                                | Parameters              |  |  |
| 0800h   | RAM      |                                | Internal Work Area      |  |  |
|         |          |                                | SSC-Interface           |  |  |
|         |          |                                | Control Unit Parameters |  |  |
| 0000h   | Register |                                | Latches/Registers       |  |  |

 Table 3.1-1: Memory Area Distribution in the Internal RAM of the DPC31

The stack for the sequential control system needs 64 bytes. A buffer for temporarily storing the receive message requires 32 bytes.

### 3.2 Control Unit Parameters (Latches/Registers)

The register cells that are, for example, in the interrupt controller and the DPS control units, are located in the address area of 0000-0044h (XDATA). These cells can either be read or written only. The address assignments are shown in Table 3.2-1. When writing the register cells, the unassigned bit positions are 'don't care'.

| Com | DeC |
|-----|-----|
|-----|-----|

| Address   | Name                                      | Meaning (read access!)                                                                    |
|-----------|-------------------------------------------|-------------------------------------------------------------------------------------------|
| 0000h     | Int-Req-Reg <sub>70</sub>                 | Interrupt Controller Register                                                             |
| 0001h     | Int-Req-Reg <sub>158</sub>                |                                                                                           |
| 0002h     | Int-Req-Reg <sub>2316</sub>               |                                                                                           |
| 0003h     | Int-Req-Reg <sub>2824</sub>               |                                                                                           |
| 0004h     | Int-Reg <sub>70</sub>                     |                                                                                           |
| 0005h     | Int-Reg <sub>158</sub>                    |                                                                                           |
| 0006h     | Int-Reg <sub>2316</sub>                   |                                                                                           |
| 0007h     | Int-Reg <sub>2824</sub>                   |                                                                                           |
| 0008h     |                                           |                                                                                           |
|           | Reserved                                  |                                                                                           |
| 000Fh     |                                           |                                                                                           |
| 0010h     | C31_Control Register70                    | Refer to Chapter 4                                                                        |
| 0011h     |                                           |                                                                                           |
|           | Reserved                                  |                                                                                           |
| 0013h     | 1                                         |                                                                                           |
| 0014h     | Delay-Timer70                             | Content of delay timer                                                                    |
| 0015h     | Delay-Timer <sub>158</sub>                | · · · · · · · · · · · · · · · · · · ·                                                     |
| 0016h     |                                           |                                                                                           |
|           | Reserved                                  |                                                                                           |
| <br>001Fh |                                           |                                                                                           |
| 0020h     | SSC_Rcv-Buf <sub>70</sub>                 | Receive buffer of the SSC interface                                                       |
| 0021h     | SSC_Sta-Reg <sub>3.0</sub>                | Status register of the SSC interface                                                      |
| 0022h     | SSC_Ctrl1-Reg <sub>70</sub>               | Control register of the SSC interface                                                     |
| 0023h     | SSC_Ctrl2-Reg <sub>20</sub>               | Control register of the SSC interface                                                     |
| 0024h     |                                           |                                                                                           |
|           | Reserved                                  |                                                                                           |
| 002Fh     |                                           |                                                                                           |
| 0030h     | User_SSA_Ok Cmd <sub>1.0</sub>            | The user acknowledges the user SSA data of an SSA message positively                      |
| 0031h     | User_Prm_Ok Cmd <sub>10</sub>             | The user acknowledges the user parameter assignment data of a prm message positively      |
| 0032h     | User_Prm_Not_Ok Cmd <sub>10</sub>         | The user acknowledges the user parameter assignment data of a prm message negatively      |
| 0033h     | User_Ext_Prm_Ok Cmd <sub>10</sub>         | The user acknowledges the ext. user parameter assignment data of a prm message positively |
| 0034h     | User_Ext_Prm_Not_Ok<br>Cmd <sub>1.0</sub> | The user acknowledges the ext. user parameter assignment data of a prm message negatively |
| 0035h     | User_Cfg_Ok Cmd <sub>10</sub>             | The user acknowledges the configuring data of a Cfg message positively                    |
| 0036h     | User_Cfg_Not_Ok-Cmd <sub>10</sub>         | The user acknowledges the configuring data of a Cfg message negatively                    |
| 0037h     | User_Diag_Read-Cmd                        | The user makes a new diag buffer available                                                |
| 0038h     | User_Get_Cfg_Read-Cmd                     | The user makes a new Get_Cfg buffer available                                             |
| 0039h     | User_New_Din-Cmd <sub>10</sub>            | The user makes a new Din buffer available                                                 |
| 003Ah     | User_Din_Buffer-State <sub>70</sub>       | The user reads the current Din buffer assignment                                          |
| 003Bh     | User_New_Dout-Cmd <sub>30</sub>           | The user fetches the last Dout buffer from the N state                                    |
| 003Ch     | User_Dout_Buffer-State70                  | The user reads the current Dout buffer assignment                                         |
| 003Dh     | User_New_DXB0_ Cmd <sub>20</sub>          | The user fetches the last DXB0 buffer from the N state                                    |
| 003Eh     | User_New_DXB1_ Cmd <sub>20</sub>          | The user fetches the last DXB1 buffer from the N state                                    |
| 003Fh     | User_New_DXB2_ Cmd <sub>20</sub>          | The user fetches the last DXB2 buffer from the N state                                    |
| 0040h     | User_New_DXB3_ Cmd <sub>20</sub>          | The user fetches the last DXB3 buffer from the N state                                    |
| 0041h     | User_New_DXB4_ Cmd <sub>20</sub>          | The user fetches the last DXB4 buffer from the N state                                    |
| 0042h     | User_New_DXB5_ Cmd <sub>20</sub>          | The user fetches the last DXB5 buffer from the N state                                    |

| 0043h | User_New_DXB6_ Cmd <sub>20</sub> | The user fetches the last DXB6 buffer from the N state |
|-------|----------------------------------|--------------------------------------------------------|
| 0044h | User_New_DXB7_ Cmd <sub>20</sub> | The user fetches the last DXB7 buffer from the N state |
| 0045h |                                  |                                                        |
|       | Reserved                         |                                                        |
| 07FFh |                                  |                                                        |

Table 3.2-1: Assignment of the Internal Register Cells for READ

| ComDeC |  |
|--------|--|
|--------|--|

| 0000h | Int-Req-Reg <sub>70</sub>          | Interrupt Controller Register                            |
|-------|------------------------------------|----------------------------------------------------------|
| 0001h | Int-Req-Reg <sub>158</sub>         |                                                          |
| 0002h | Int-Req-Reg <sub>23.16</sub>       |                                                          |
| 0003h | Int-Req-Reg <sub>2824</sub>        |                                                          |
| 0004h | Int-Ack-Reg <sub>70</sub>          |                                                          |
| 0005h | Int-Ack-Reg <sub>158</sub>         |                                                          |
| 0006h | Int-Ack-Reg <sub>2316</sub>        |                                                          |
| 0007h | Int-Ack-Reg <sub>2824</sub>        |                                                          |
| 0008h | Int-Mask-Reg <sub>70</sub>         |                                                          |
| 0009h | Int-Mask-Reg <sub>158</sub>        |                                                          |
| 000Ah | Int-Mask-Reg <sub>2316</sub>       |                                                          |
| 000Bh | Int-Mask-Reg <sub>2824</sub>       |                                                          |
| 000Ch | Int-EOI-Reg₀                       |                                                          |
| 000Dh |                                    |                                                          |
| 000Eh | reserved                           |                                                          |
| 000Fh |                                    |                                                          |
| 0010h | C31_Ctrl-Reg <sub>60</sub>         | Refer to Chapter 6                                       |
| 0011h | Mode-Reg1-Set <sub>70</sub>        | Refer to Chapter 6                                       |
| 0012h | Mode-Reg1-Reset <sub>70</sub>      | Refer to Chapter 6                                       |
| 0013h | User_InstQ_Write-Cmd <sub>70</sub> | Transfers a new request to the sequential control system |
| 0014h |                                    |                                                          |
|       | reserved                           |                                                          |
| 001Fh |                                    |                                                          |
| 0020h | SSC_Transmit-Buf70                 | Receive buffer of the SSC interface                      |
| 0021h | SSC_Sta-Reg <sub>70</sub>          | Status register of the SSC interface                     |
| 0022h | SSC_Ctrl1-Reg <sub>70</sub>        | Control register of the SSC interface                    |
| 0023h | SSC_Ctrl2-Reg <sub>20</sub>        | Control register of the SSC interface                    |
| 0024h | SSC_Int_Enable-Reg <sub>3.0</sub>  | Interrupt_Enable register of the SSC interface           |
| 0025h | SSC_Baudrate-Reg <sub>70</sub>     | Baud rate register of the SSC interface                  |
| 0026h |                                    |                                                          |
|       | reserved                           |                                                          |
| 07FFh |                                    |                                                          |

Table 3.2-1: Assignment of the Internal Register Cells for WRITE

### 3.3 Organizational Parameters (RAM)

The organizational parameters are stored by the user in the RAM under the addresses specified in the table below. These parameters primarily describe the parameter cells and the buffer pointers of the communication profile (buffer management).

| 0800h |                                    | Internal working area                                                                                  |
|-------|------------------------------------|--------------------------------------------------------------------------------------------------------|
|       | reserved                           |                                                                                                        |
| 0827h |                                    |                                                                                                        |
| 0828h | Master_Add <sub>70</sub>           | Address of parameter assignment mask                                                                   |
| 0829h |                                    | Internal working area                                                                                  |
|       | reserved                           |                                                                                                        |
| 0833h |                                    |                                                                                                        |
| 0834h | U_Buffer_State                     | Status of user buffers, if "Disable C Buffer" is in parameter register                                 |
| 0835h | -                                  | Internal working area                                                                                  |
|       | reserved                           |                                                                                                        |
| 083Eh |                                    |                                                                                                        |
| 083Fh | Param_Ext_1-Register <sub>70</sub> | see below                                                                                              |
| 0840h | Status-Register70                  | see below                                                                                              |
| 0841h | Status-Register <sub>158</sub>     | see below                                                                                              |
| 0842h | Param-Register70                   | see below                                                                                              |
| 0843h | Param-Register <sub>158</sub>      | see below                                                                                              |
| 0844h | Param-Register <sub>2316</sub>     | see below                                                                                              |
| 0845h | Param-Register <sub>3124</sub>     | see below                                                                                              |
| 0846h | TS_Adr_Register <sub>60</sub>      | Profibus station Address of the DPC31 (this slave)                                                     |
| 0847h | Real_No_Add_Change70               | This parameter indicates whether the DP slave address may be changed                                   |
|       |                                    | at a later time. After reset, the slave firmware must set this parameter if it                         |
|       |                                    | permits the Set_Slave_Address SAP.                                                                     |
|       |                                    | 0 = Address may be changed                                                                             |
|       |                                    | Otherwise = Address may not be changed                                                                 |
|       |                                    | If the DPC31 then receives a Set_Slave_ Address message, it enters the                                 |
|       |                                    | current value here.                                                                                    |
| 0848h | WD_Baud_Control_Val <sub>7.0</sub> | The root value for baud rate monitoring is parameterized.                                              |
| 0849h | Interframe GAP_Time <sub>50</sub>  | The Interframe GAP time (432 bits) is to be parameterized here for                                     |
|       |                                    | synchronous bus physics.                                                                               |
| 084Ah | DPS_User_Wd_Val <sub>70</sub>      | In the DPS_Mode, the user is monitored with an internal 16-bit watchdog                                |
|       |                                    | timer. The timer is decremented every 10 ms and must be reset by the                                   |
|       |                                    | user cyclically to the start value 'DPS_User_WD_Value <sub>150</sub> '. Resetting,                     |
|       |                                    | enabling, and disabling the timer is initiated with 'DPS_User-Wd' request<br>in the Instruction_Queue. |
| 004Db | DBS Lloor Wid Vial                 |                                                                                                        |
| 084Bh | DPS_User_Wd_Val <sub>15.8</sub>    | Creation for the next WD such for monitoring the configured above to                                   |
| 084Ch | Score_Register <sub>7.0</sub>      | Specification for the next WD cycle for monitoring the configured slave-to-                            |
|       | GC Command                         | slave connections                                                                                      |
| 084Dh | GC_Command <sub>7.0</sub>          | GC command last received                                                                               |
| 084Eh | Ident_Low <sub>7.0</sub>           | PNO Ident Number Low                                                                                   |
| 084Fh | Ident_High <sub>7.0</sub>          | PNO Ident Number High                                                                                  |
| 0850h | DXB_Sync <sub>7.0</sub>            | Specify links that are subject to Sync control                                                         |
| 0851h | Group Clock                        | Specify group under which the clock pulse beater is triggered                                          |
| 0852h | Temp_Base-Ptr <sub>7.0</sub>       | Segment address that points to the start of the temp buffer of the S/R unit                            |
| 0853h | SAP_List_Base-Ptr <sub>7.0</sub>   | Segment address that points to the start of the SAP list                                               |
| 0854h | SAP_SCB_Base-Ptr <sub>70</sub>     | Segment address that points to the start of the SAP SCB (system control                                |
| 00555 |                                    | block)                                                                                                 |
| 0855h | DPS_SAP_Start-Ptr70                | Offset address that points to the start of the DPS SAPs being established                              |
| 00566 | InstO. Pass Dtr                    | by the DPC31 in the SAP SCB                                                                            |
| 0856h | InstQ_Base-Ptr <sub>7.0</sub>      | (segment pointer to the instruction queue)                                                             |
| 0857h | InstQ_Length <sub>70</sub>         | (length of the instruction queue in bytes (multiple of the length of an entry                          |
| 00505 | InotO Road Dtr                     | -> n*5))                                                                                               |
| 0858h | InstQ_Read-Ptr <sub>7.0</sub>      | Byte offset to the next entry to be read                                                               |
| 0859h | InstQ_Write-Ptr <sub>7.0</sub>     | Byte offset to the next free entry                                                                     |

| 085Ah  | IndQ_Base-Ptr70                               | (segment pointer to the indication queue)                                      |
|--------|-----------------------------------------------|--------------------------------------------------------------------------------|
| 085Bh  | IndQ_Length <sub>70</sub>                     | (length of the indication queue in bytes (multiple of the length of an entry - |
|        |                                               | > n*3))                                                                        |
| 085Ch  | IndQ_Read-Ptr <sub>70</sub>                   | Byte offset to the next entry to be read                                       |
| 085Dh  | IndQ_Write-Ptr <sub>70</sub>                  | Byte offset to the next free entry                                             |
| 085Eh  | Dout_Buffer-Length <sub>7.0</sub>             | Length of the 4 Dout buffers                                                   |
| 085Fh  | Dout_Buffer1-Ptr <sub>7.0</sub>               | Segment Pointer to Dout Buffer1                                                |
| 0860h  | Dout_Buffer2-Ptr70                            | Segment Pointer to Dout Buffer2                                                |
| 0861h  | Dout_Buffer3-Ptr70                            | Segment Pointer to Dout Buffer3                                                |
| 0862h  | Dout_Buffer4-Ptr70                            | Segment Pointer to Dout Buffer4                                                |
| 0863h  | Din_Buffer-Length70                           | Length of the 3 Din buffers                                                    |
| 0864h  | Din_Buffer1-Ptr <sub>70</sub>                 | Segment Pointer to Din Buffer1                                                 |
| 0865h  | Din_Buffer2-Ptr70                             | Segment Pointer to Din Buffer2                                                 |
| 0866h  | Din_Buffer3-Ptr70                             | Segment Pointer to Din Buffer3                                                 |
| 0867h  | User_SSA_Buffer-Ptr70                         | Segment Pointer to User SSA Buffer                                             |
| 0868h  | MAC_SSA_Buffer-Ptr70                          | Segment Pointer to Mac SSA Buffer                                              |
| 0869h  | User_Prm_Buffer-Ptr70                         | Segment Pointer to User Prm Buffer                                             |
| 086Ah  | MAC_Prm_Buffer-Ptr <sub>70</sub>              | Segment Pointer to Mac-Prm Buffer                                              |
| 086Bh  | User_DDB_Prm_Buffer-                          | Segment Pointer to User DDB Prm Buffer                                         |
|        | Ptr <sub>70</sub>                             |                                                                                |
| 086Ch  | MAC_DDB_Prm_Buffer-                           | Segment Pointer to Mac DDB Prm Buffer                                          |
| 086Dh  | Ptr <sub>7.0</sub>                            | Sogment Deinter to Llear Ofg Duffer                                            |
|        | User_Cfg_Buffer-Ptr <sub>70</sub>             | Segment Pointer to User Cfg Buffer                                             |
| 086Eh  | MAC_Cfg_Buffer-Ptr <sub>7.0</sub>             | Segment Pointer to Mac Cfg Buffer                                              |
| 086Fh  | User_Diag_Reply_Buffer-<br>Ptr <sub>7.0</sub> | Segment Pointer to User-Diag Buffer                                            |
| 0870h  | MAC_Diag_Reply_Buffer-                        | Segment Pointer to Mac Diag Buffer                                             |
|        | Ptr <sub>70</sub>                             |                                                                                |
| 0871h  | User_GCfg_Reply_Buffer-                       | Segment Pointer to User-Get-Cfg Buffer                                         |
| 00705  | Ptr <sub>7.0</sub>                            | Comment Deinter to Mag Cat Ofe Duffer                                          |
| 0872h  | MAC_GCfg_Reply_Buffer-<br>Ptr <sub>7.0</sub>  | Segment Pointer to Mac-Get-Cfg Buffer                                          |
| 0873h  | MAC_GC_Buffer-Ptr <sub>7.0</sub>              | Segment Pointer to Global Ctrl Buffer                                          |
| 0874h  | DXB0_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB0 Buffer1                                                |
| 0875h  | DXB0_Buffer2-Ptr <sub>70</sub>                | Segment Pointer to DXB0 Buffer2                                                |
| 0876h  | DXB0_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB0 Buffer3                                                |
| 0877h  | DXB1_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB1 Buffer1                                                |
| 0878h  | DXB1_Buffer2-Ptr70                            | Segment Pointer to DXB1 Buffer2                                                |
| 0879h  | DXB1_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB1 Buffer3                                                |
| 087Ah  | DXB2_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB2 Buffer1                                                |
| 087Bh  | DXB2_Buffer2-Ptr <sub>70</sub>                | Segment Pointer to DXB2 Buffer2                                                |
| 087Ch  | DXB2_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB2 Buffer3                                                |
| 087Dh  | DXB3_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB3 Buffer1                                                |
| 087Eh  | DXB3_Buffer2-Ptr <sub>70</sub>                | Segment Pointer to DXB3 Buffer2                                                |
| 087Eh  | DXB3_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB3 Buffer3                                                |
| 0880h  | DXB4_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB4 Buffer1                                                |
| 0881h  | DXB4_Buffer2-Ptr <sub>7.0</sub>               | Segment Pointer to DXB4 Buffer2                                                |
| 0882h  | DXB4_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB4 Buffer3                                                |
| 0883h  | DXB5_Buffer1-Ptr <sub>70</sub>                | Segment Pointer to DXB5 Buffer1                                                |
| 0884h  | DXB5_Buffer2-Ptr <sub>70</sub>                | Segment Pointer to DXB5 Buffer2                                                |
| 0885h  | DXB5_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB5 Buffer3                                                |
| 0886h  | DXB6_Buffer1-Ptr <sub>7.0</sub>               | Segment Pointer to DXB6 Buffer1                                                |
| 0880h  | DXB6_Buffer2-Ptr <sub>70</sub>                | Segment Pointer to DXB6 Buffer2                                                |
| 0888h  |                                               |                                                                                |
| 000011 | DXB6_Buffer3-Ptr <sub>70</sub>                | Segment Pointer to DXB6 Buffer3                                                |

| 0889h | DXB7_Buffer1-Ptr70 | Segment Pointer to DXB7 Buffer1 |
|-------|--------------------|---------------------------------|
| 088Ah | DXB7_Buffer2-Ptr70 | Segment Pointer to DXB7 Buffer2 |
| 088Bh | DXB7_Buffer3-Ptr70 | Segment Pointer to DXB7 Buffer3 |
| 088Ch |                    |                                 |
|       | reserved           | Preset with 0x00                |
| 0896h |                    |                                 |
| 0897h |                    |                                 |
|       | Buffer Area        |                                 |
| 1FFFh |                    |                                 |

Table 3.3-2: Assignment of the Organizational Parameters

#### Meaning of the Register Cells:

#### Status Register:

| WD-State <sub>10</sub><br>1 0 | DPS-State <sub>10</sub><br>1 0 | 0 | Diag_Flag | 0                | MAC State |
|-------------------------------|--------------------------------|---|-----------|------------------|-----------|
| 7                             | 4                              |   | 2         |                  | 0         |
| _                             |                                |   |           |                  | _         |
| DPC31 F                       | Release <sub>3.0</sub>         |   | Baudrat   | te <sub>30</sub> |           |
| 3 2                           | 1 0                            | 3 | 2         | 1                | 0         |
| 15                            |                                |   |           |                  | 8         |

The status register displays the current MAC status, the DPS status, and the watchdog timer status. In addition, the baud rate that was found, and the release number of the DPC31 is also entered.

| MAC State:                    | The state of the MAC                                                                           |
|-------------------------------|------------------------------------------------------------------------------------------------|
|                               | <ul><li>=0 The MAC is in the 'Offline' state</li><li>=1 The MAC is in 'Passive Idle'</li></ul> |
| Diag_Flag:                    | State Diagnostic Buffer                                                                        |
|                               | =0 The diagnostic buffer was fetched by the master (if                                         |
|                               | Diag.Stat_Diag=0).                                                                             |
|                               | =1 The diagnostic buffer was not fetched by the master.                                        |
| DPS-State <sub>10</sub> :     | The state of the DPS State Machine                                                             |
|                               | =00 State 'Wait_Prm'                                                                           |
|                               | =01 State 'Wait_Cfg'                                                                           |
|                               | =10 State 'Data_Exchange'                                                                      |
| WD-State <sub>10</sub> :      | The state of the Watchdog SM                                                                   |
|                               | =00 State 'Baud_Search'                                                                        |
|                               | =01 State 'Baud_Control'                                                                       |
|                               | =10 State 'DP_Control'                                                                         |
| Baudrate <sub>30</sub> :      | The baud rate found by the DPC31                                                               |
|                               | =0000 12 MBd (asyn.)                                                                           |
|                               | =0001 6 MBd (asyn.)                                                                            |
|                               | =0010 3 MBd (asyn.)                                                                            |
|                               | =0011 1.5 MBd (asyn.), 31.25 kBd (syn.)                                                        |
|                               | =0100 500 kBd (asyn.)                                                                          |
|                               | =0101 187.5 kBd (asyn.)                                                                        |
|                               | =0110 93.75 kBd (asyn.)                                                                        |
|                               | =0111 45.45 kBd (asyn.)                                                                        |
|                               | =1000 19.2 kBd (asyn.)                                                                         |
| DD004 Dalaasa                 | =1001 9.6 kBd (asyn.)                                                                          |
| DPC31-Release <sub>30</sub> : | Release number of the DPC31: The release number consiDXB of two                                |
|                               | groups.                                                                                        |
|                               | DPC31-Release <sub>1.0</sub> : numbers the compatible versions                                 |
|                               | DPC31-Release <sub>3.2</sub> : is the index within a compatible version.                       |
|                               | Bit (3:0) Meaning                                                                              |
|                               | 0000 DPC31 Step A                                                                              |
|                               | 0001 DPC31 Step B                                                                              |
|                               | 0010 DPC31 Step C                                                                              |
|                               | Rest not possible so far                                                                       |

#### Param Register:

## ComDeC



In the Param Register, individual parameter bits are transferred that are to be changed only in the MAC state 'Offline', however. When the request 'MAC\_Start' (refer to Chapter 5.1.2) is executed, these parameters are distributed by the sequential control system to the individual modules. Subsequent changes are not taken into account.

| En Clock<br>Sync             | Early_<br>Ready             | EOI_<br>Timebase    | Quick_Sync<br>_New | GIM_EN           | XRTS/<br>ADD         | 0                  | 0       |
|------------------------------|-----------------------------|---------------------|--------------------|------------------|----------------------|--------------------|---------|
| 7                            |                             |                     |                    |                  |                      |                    | 0       |
|                              |                             |                     |                    |                  |                      |                    |         |
| Check_No_<br>GC_Reserv<br>ed | Check No<br>Prm<br>Reserved | New_GC_<br>Int_Mode | XDP/FDL<br>MinTSDR | Failsafe<br>Mode | Freeze_<br>Supported | Sync_<br>Supported | DP_Mode |
| 15                           |                             |                     |                    |                  |                      |                    | 8       |

| 0  | Check<br>DP V1<br>Enable | SD4_WD_<br>Reset | En_Change<br>_Cfg_Buffer | XAsyn/Syn | Syn Baud | Syn_Clkin₁ | Syn_Clkin₀ |
|----|--------------------------|------------------|--------------------------|-----------|----------|------------|------------|
| 23 |                          |                  |                          |           |          |            |            |

| Disable C En LM<br>Buffer | Val1 0 EN Erw Prm Check En En DXB Preamble <sub>1</sub> Preamble <sub>0</sub><br>Prm Cmd Publisher                           |  |  |  |  |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                           | 27 24                                                                                                                        |  |  |  |  |
|                           |                                                                                                                              |  |  |  |  |
| XRTS/ADD:                 | Switchover Output TxE (syn. physics) for different driver control                                                            |  |  |  |  |
|                           | =0 RTS Signal.                                                                                                               |  |  |  |  |
|                           | =1 ADD Signal                                                                                                                |  |  |  |  |
| GIM_EN:                   | Galvanic Isolation Mode for syn. physics                                                                                     |  |  |  |  |
|                           | =0 The power-saving interface is switched off                                                                                |  |  |  |  |
|                           | =1 The power-saving interface is switched on (possible only for                                                              |  |  |  |  |
|                           | 31.25kBd)                                                                                                                    |  |  |  |  |
| Quick Syna Now            | Switching on the improved guide even                                                                                         |  |  |  |  |
| Quick_Sync_New:           | Switching on the improved quick sync<br>=0 The improved quick synchronizer is off.                                           |  |  |  |  |
|                           | =1 The improved quick synchronizer is on.                                                                                    |  |  |  |  |
| EOI_Timebase:             | Time base of the EOI timer                                                                                                   |  |  |  |  |
|                           | =0 The interrupt inactive time is 1 to 2 $\mu$ sec.                                                                          |  |  |  |  |
|                           | =1 The interrupt inactive time is 1 to 2 msec.                                                                               |  |  |  |  |
| Early_Ready:              | Early Ready Signal                                                                                                           |  |  |  |  |
|                           | =0 Ready is generated if the data is valid (Read) or if the data is                                                          |  |  |  |  |
|                           | taken over (write).                                                                                                          |  |  |  |  |
|                           | =1 Ready is moved ahead by one clock pulse.                                                                                  |  |  |  |  |
| En_Clock_Sync:            | Enable time of day synchronization                                                                                           |  |  |  |  |
|                           | =0 The time of day synchronization is blocked                                                                                |  |  |  |  |
|                           | =1 The time of day synchronization is enabled                                                                                |  |  |  |  |
| DP_Mode:                  | Enable of DPS                                                                                                                |  |  |  |  |
|                           | =0 DPS is not enabled.                                                                                                       |  |  |  |  |
| Ourse Ourses enterels     | =1 DPS is enabled.                                                                                                           |  |  |  |  |
| Sync_Supported:           | Support of Sync_Mode                                                                                                         |  |  |  |  |
|                           | <ul><li>=0 The Sync_Mode is not supported.</li><li>=1 The Sync_Mode is supported. Data is made available in the N-</li></ul> |  |  |  |  |
|                           | Buffer of the Dout-SM (not comparable to ASIC LSPM 2).                                                                       |  |  |  |  |
| Freeze_Supported:         | Support of Freeze_Mode                                                                                                       |  |  |  |  |
|                           | =0 The Freeze_Mode is not supported.                                                                                         |  |  |  |  |
|                           | _ ''                                                                                                                         |  |  |  |  |



=1 The Freeze\_Mode is supported. Data is frozen from the N-buffer of the Din SM (not comparable to LSPM 2).

Failsafe\_Mode:

- =0 Failsafe\_Mode is not supported.
- =1 Failsafe\_Mode is supported.

XDP/FDL\_MinTSDR: Default setting of MinTSDR according to 'Baud rate Detect' for DPS or combo operation

=0 Pure DPS operation

Support of Failsafe\_Mode

=1 Combo operation

| XDP/FDL_MinTSDR | XAsyn/Syn | Baud rate | T <sub>MinTSDR</sub> / t <sub>Bit</sub> |
|-----------------|-----------|-----------|-----------------------------------------|
| 0               | -         | -         | 11                                      |
| 1               | 0         | 9.6 kBd   | 30                                      |
| 1               | 0         | 19.2 kBd  | 60                                      |
| 1               | 0         | 45.45 kBd | 160                                     |
| 1               | 0         | 93.75 kBd | 125                                     |
| 1               | 0         | 187.5 kBd | 250                                     |
| 1               | 0         | 500 kBd   | 255                                     |
| 1               | 0         | 1.5 MBd   | 255                                     |
| 1               | 0         | 3 MBd     | 255                                     |
| 1               | 0         | 6 MBd     | 255                                     |
| 1               | 0         | 12 MBd    | 255                                     |
| 1               | 1         | 31.25 kBd | 100                                     |

New\_GC\_Int\_Mode: Interrupt Mode for 'New\_GC\_Command'

=0 The 'New\_GC\_Command Int' is generated only if there is a change in the 'GC\_Command' (basic setting).

- =1 The 'New\_GC\_Command Int' is generated for each receipt of a GC
  - message.

Check\_No\_Prm\_Reserved: Reserved bits in Prm frame are not tested

- =0 Reserved bits are tested.
- =1 Reserved bits are not tested.

#### Check\_No\_GC\_Reserved: Reserved bits in the GC frame are not tested

- =0 Reserved bits are tested.
- =1 Reserved bits are not tested.

XAsyn/Syn:

Setting the bus physics =0 Asynchronous physics; the work clock pulse is fixed at 48 MHz (via PLL)

a FLL) Roud roto: 0.6 kRd to 12 MRd

- Baud rate: 9.6 kBd to 12 MBd (basic setting)
- =1 Synchronous physics; the work clock pulse can be set: 2, 4, 8 or 16  $\rm MHz$

Baud rate: fixed at 31.25 kBd

Syn\_Baud: Setting of synchronous baud rate. =0 Only 31.25 kbaud is supported as a synchronous baud rate, irrespective of the clock pulse supply (basic setting). =1 The synchronous baud rate is variable, irrespective of the clock pulse supply (see below).

En\_Change\_Cfg\_Buffer: Enable of the

buffer exchange (User\_Cfg\_Buffer for MAC\_GCfg\_Rbuffer)

=0 The buffers won't be exchanged.

| Syn_Clkin <sub>10</sub> : | =1 With 'User_Cfg_Ok Cmd', the above-mentioned buffers are<br>exchanged. The exchange is confirmed with the interrupt<br>'Get_Cfg_Buffer_Changed'.<br>Setting the external clock pulse supply at Pin XTAL1_CLK (not via<br>PLL). The internal C31 processes with half the clock frequency!<br>=00 External clock = 2 MHz $\Rightarrow$ Baud rates: 31.25<br>=01 External clock = 4 MHz $\Rightarrow$ Baud rates: 31.25<br>=10 External clock = 8 MHz $\Rightarrow$ Baud rates: 31.25<br>=11 External clock = 16 MHz $\Rightarrow$ Baud rates: 31.25 |
|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Check_DPV1_Enable         | <ul> <li>Control of the MSAC1S-SAPs (SAP50-52) is tied to the cyclic machine if "DPV1_Enable=1" in the Set_Prm frame.</li> <li>No check of DPV1_Enable in Set_Prm frame.</li> <li>=1 DPV1_Enable is checked in Set_Prm frame</li> </ul>                                                                                                                                                                                                                                                                                                             |
| Preamble <sub>10</sub> :  | For the syn. physics, the preamble length is parameterized in number<br>of bytes.<br>=00 $\Rightarrow$ 1 byte<br>=01 $\Rightarrow$ 2 bytes<br>=10 $\Rightarrow$ 4 bytes<br>=11 $\Rightarrow$ 8 bytes                                                                                                                                                                                                                                                                                                                                                |
| En_DXB_Publisher:         | <ul> <li>Enable as Publisher for internode communication</li> <li>=0 Publisher mode is blocked, DDB request frames are filtered (basic setting).</li> <li>=1 Publisher mode is enabled for all SAPs (for the FDL-SAPs, the user must set Access_Value=8h).</li> </ul>                                                                                                                                                                                                                                                                               |
| Check_En_Prm_Cmd          | <ul> <li>In the Set_Prm frame, the 'En_Prm_Cmd' bit (DPV1_Status_3, Bit7) is scanned and brings about the appropriate responses</li> <li>No check of the En_Prm_Cmd bit in the Set_Prm frame.</li> <li>The En_Prm_Cmd bit is checked in the Set_Prm frame.</li> </ul>                                                                                                                                                                                                                                                                               |
| En_Erw_Prm:               | <ul> <li>This bit enables the expanded parameter register at address 083Fh.</li> <li>=0 No expanded parameter register present, i.e., all bits of this register are set to the default value. The register is read only.</li> <li>=1 The expanded parameter register is enabled and can be written to.</li> </ul>                                                                                                                                                                                                                                   |
| En_LM_Val1:               | <ul> <li>This bit enables additional evaluation of the Value1 byte for the request interface when "User Leave Master" is requested.</li> <li>=0 No evaluation of Value Byte 1</li> <li>=1 The content of Value Byte 1 is evaluated also.</li> </ul>                                                                                                                                                                                                                                                                                                 |
| Disable_C_Buffer:         | This bit determines whether the Clear Buffer is applied by the user or<br>automatically by the DPC31. However, due to a hardware<br>defect, automatic application of Clear Buffer is not available on the<br>DPC31 Step B.                                                                                                                                                                                                                                                                                                                          |
|                           | <ul><li>=1 User must output the Clear state to the outputs when required.</li><li>=0 When required, the DPC31 automatically applies the Clear Buffer using the DP-DOut_SM.</li></ul>                                                                                                                                                                                                                                                                                                                                                                |

If the user outputs the Clear Buffer to the outputs, this is signaled using two means:

#### **Expanded Parameter Register**

Additional parameter bits are transferred in the expanded Param Register. These bits may only be changed in MAC state 'Offline." When the 'MAC\_Start' request is executed, these



parameters are distributed to the individual modules. Subsequent changes are not taken into account by KRISC. The expanded parameter register is available starting with DPC31 Step C but only if Bit #28 (En\_Erw\_Prm) is set to log. '1' in the parameter register.

| 0 | 0 | 0 | 0 | 0 | 0 | Sampling_<br>Mode Bit 1 | Sampling_<br>Mode Bit 0 |
|---|---|---|---|---|---|-------------------------|-------------------------|
| 7 |   |   |   |   |   |                         | 0                       |

Sampling\_Mode1..0:

Depending on the sampling mode setting, a window of uncertainty results for the differentiation of a short pulse or long pulse when the physics unit is operated in energy saving mode (see Section 5.7.3.3)

| =00 | $\Rightarrow$ 2.5 $\mu$ s to 3,0 $\mu$ s |
|-----|------------------------------------------|
| =01 | $\Rightarrow$ 3.0 $\mu$ s to 3,5 $\mu$ s |
| =10 | $\Rightarrow$ 3.5 $\mu$ s to 4,0 $\mu$ s |
| =11 | $\Rightarrow$ 4.0 $\mu s$ to 4,5 $\mu s$ |
|     |                                          |

## 4 ASIC Interface

## Interrupt Controller Register (Int Mask Reg, Int Ack Reg, Int Req Reg, Int and Int EOI Reg):

The meaning of these registers will be explained in later chapters. The interrupt controller exiDXB twice (for ext.  $\mu$ P and C31). Both are instances are mapped onto the same addresses.

Mode Register1: (ext. µP and C31, write access)

Mode Register1 is used for parameterizing single bits. These bits are control bits and internally directly affect the hardware. The meaning is described below. Different addresses are used for setting and resetting (Mode Register1 set/reset). A logical '1' is written to those bit positions that are to be changed. All other bit positions must be logical. '0'

| Int_<br>Polarity | 0         | 0                                              | 0                                                      | Dis_C31                       | Dis_Clkout1X4                        | Dis_Clkout1X2 | Stop_Del<br>aytimer |
|------------------|-----------|------------------------------------------------|--------------------------------------------------------|-------------------------------|--------------------------------------|---------------|---------------------|
| Stop_Dela        | ay-Timer: |                                                | er is stopped<br>r timer is not s<br>r timer is stopp  | •• •                          | ault).                               |               |                     |
| Dis_Clkou        | ut1X2:    | asyn=24MHz,<br>reset phase, tł<br>=0 Clkout1X  | syn=1 to 8 M<br>ne output is ini                       | /IHz). After<br>tially active | ed off (½ of the<br>being switched o |               |                     |
| Dis_Clkou        | ut1X4:    | asyn=12MHz,<br>reset phase, tł<br>=0 Clkout1X4 | syn=0.5 to 4                                           | MHz). Afte<br>tially active   | ed off (¼ of the<br>r being switched |               |                     |
| Dis_C31:         |           |                                                | 31 is switched<br>tive (default).<br>active (absolut   | ·                             | ,                                    |               |                     |
| Int_Polari       | ty:       |                                                | interrupt outpu<br>upt output is le<br>upt output is h | ow-active (b                  | pasic setting).                      |               |                     |

C31\_Control Register: (ext. µP and C31, read/write access)

In the C31\_Control register, the settings specific to the C31 are made. The boot type bits are not to be parameterized by the user; the assignment of the chip pins 'BOOTTYP\_0/\_1' determines the boot type.

|               | Enable<br>DX_Out_Port | Enable_GC_CI<br>ock | 0   | Reserv | ved (0) | Boot | Туре |
|---------------|-----------------------|---------------------|-----|--------|---------|------|------|
|               |                       |                     |     | Bit1   | Bit0    | Bit1 | Bit0 |
| Bit Position  | 6                     | 5                   | 4   | 3      | 2       | 1    | 0    |
| Default Value | 0                     | 0                   | 0   | 0      | 0       | -    | -    |
|               | r/w                   | r/w                 | r/w | r/w    | r/w     | r    | r    |

| Boot type:        | These two bits can be used to scan the status at the BOOTTYP0 and BOOTTYP1 pins.                                                                                                                                                                |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | These two pins and the two bits in the register have no specified function any longer. Nevertheless, the pins are to be connected as follows: Bit $0 = 0$ ; Bit $1 = 1$ .                                                                       |
| Enable GC_Clock:  | <ul> <li>The clock pulse striker 'GC_Clock' is fed to Port PB<sub>2</sub></li> <li>=0 Port PB<sub>2</sub> is controlled by C31 (default).</li> <li>=1 The clock pulse striker 'GC Clock' is fed to Port PB<sub>2</sub></li> </ul>               |
| Ena. DX_Out_Port: | <ul> <li>The Interrupt 'DX_OUT' (IRR<sub>14</sub>) can be applied directly to Port PB<sub>3</sub>.</li> <li>=0 Port PB<sub>3</sub> is controlled by C31 (default).</li> <li>=1 The interrupt 'DX_OUT' is fed to Port PB<sub>3</sub>.</li> </ul> |

## 5 Communication Functions of the Sequential Control System

PROFIBUS Layer2 and the DP slave module are implemented in the sequential control system. Layer2 is composed of a MAC (media access control) part and an FLC (interface services) part. In the following, the Layer2 module is simply called MAC module. The user can influence only the cells that are described here.

### 5.1 Structure of SAP List

All liDXB and buffer elements are located in the communication memory and are addressed via an 8-bit segment buffer pointer. When a list or buffer is accessed, the communication control adds an 8-bit offset address to the segment address shifted by 5-bits (result: 13-bit physical address). A granularity of 32 bytes results for the list and buffer start addresses. The SAP structure includes an 'SAP\_List (addressed via the SAP\_List\_Base-Ptr)' and an 'SAP\_SCB (System Control Block, addressed via the SAP\_SCB\_ Base-Ptr)'. In the SAP\_List, a pointer is entered for each SAP (Default\_SAP, SAP0-63 and the SM\_Time\_SAP), which points to the SAP-SCB as an offset. The SAP\_List (66 bytes) must always be available, but only the enabled SAPs are entered in the SAP\_SCB. SAPs not enabled are entered in the SAP\_List with '**SAPx\_Ptr=FFh**'! The entries in the SAP\_SCB must not exceed 256 bytes (10 DPS, 26 FDL and 1 SM Time SAP).

The user enters all FDL\_SAPs in the SAP management and sets the 'DPS\_SAP\_Start Ptr' to the next position after the FDL\_SAPs. With the 'MAC\_Start' request, the MAC affixes the DP-SAPs following this if Bit 'DP\_Mode=1' is set in the Param Register. The entries in the SAP\_SCB differ between the DP SAPs and the FDL SAPs. However, the first three entries for each SAP are always identical. Specifically, the following entries are stored:

req\_sa: When a Request frame is received, the MAC makes the received Remote\_Adr plausible with this specified value. If this field is preassigned with '=FFh (All)', access protection is not set. If the field is assigned '=7Fh', SAP is blocked and the MAC replies with 'no Service activated (RS)'. Otherwise, the MAC compares the received Remote\_Adr with the specified req\_sa. If they do not match, the frame is rejected and replied to with 'RS'. Attention must be paid that the highest bit has to be set to log. '0' in the default SAP and to log. '1' in all other SAPs. For the FDL-SAPs, the MAC enters the access protection automatically. This always occurs if this field is preassigned "All" and a Request Pdu is received in 'Idle" ISM mode. The access protection can then only be removed via the request interface using 'SAP\_Act/Deact' !

Service\_Supported:

This field is divided into two. The Access value is in the lower 4 bits Ser\_Supported<sub>(3..0)</sub>. If **'=OH (AII)'** is preassigned, plausibility step is omitted. Otherwise, the MAC makes the function code from the FC field (FC<sub>3..0</sub>) of the Request frame plausible with the specified Serv\_Supported<sub>3..0</sub>. If no hits occur, the MAC replies with 'RS'.





Figure 5.1-1: Structure of SAP List, Buffer Structure

<<Puffer = buffer, gesperrt = blocked>>

| Service      | Access_Value <sub>30</sub> | Service        | Access_Value <sub>30</sub> |
|--------------|----------------------------|----------------|----------------------------|
| All          | 0h                         | SRD-Low/High   | 8h                         |
|              |                            | or DDB-Request |                            |
| SDN-Low      | 1h                         | SRD-Low        | 9h                         |
| SDN-High     | 2h                         | SRD-High       | Ah                         |
| SDN-Low/High | 3h                         | SRD-Low/High   | Bh                         |
| not allowed  | 4h                         | not allowed    | Ch                         |
| SDA-Low      | 5h                         | not allowed    | Dh                         |
| SDA-High     | 6h                         | not allowed    | Eh                         |
| SDA-Low/High | 7h                         | not allowed    | Fh                         |

#### Table 5.1-1: Coding of Access\_Value

In the 'Enable' field, the 'XDP/FDL' bit specifies whether a DP\_SAP (XDP/FDL=0) or an FDL\_SAP (XDP/FDL=1) is involved.

#### Ind\_Resp\_Buffer-Ptr1/2/3:

In the case of FDL-SAPs, up to 3 resources can be hooked in. The Ind\_Resp\_Buffer-Ptr points to the swapped out indication or response buffer. Each buffer operates in ,1buffer mode,' that is, the buffer is available to the SAP as an Indication buffer or as a Response buffer. When buffer lengths are different, the smallest buffer must be assigned the first buffer and the largest buffer the last. The MAC operates according to the 'Best Fit method', i.e., it always attempts to accommodate the received data in the first possible Indication buffer. If all of the Indication buffers are too small or occupied (see next section), it replies with 'No Resource (RR).' If only two buffers or one buffer is made available, more than one pointer must point to the same buffer. When the response is generated, the MAC of Ind\_Resp\_Buffer-Ptr1 $\rightarrow$ 3 searches for a Response buffer and sends the response data from the first one found.

Ind\_Buffer\_Ptr:

In the case of DP\_SAPs, a fixed Indication\_Buffer is available. In so doing, the respective MAC\_Buffer-Ptr (e.g., Ind\_Buffer-Ptr = MAC\_Prm\_Buffer-Ptr in SAP61) is always hooked in. Because all Indication resources are designed as alternating buffers, a receive resource is available at all times. For DP\_SAPs that require no receive resources (e.g., diagnostic SAP60), the 'Ind\_Buffer-Ptr=00h' is set (by the MAC).

#### Resp\_Buffer-Ptr:

In the case of DP\_SAPs, the Response\_Buffer-Ptr points to the swapped out Response buffer. In the case of DP\_SAPs without a Response buffer (e.g., Set\_Param, Check\_Config, etc.) the MAC enters a value of '00h' in the pointer during startup. It then answers a Request with a short acknowledgement.

For the FDL\_SAPs, the following entries still have to be made:

FDL\_Timer-Control:

The control for the FDL monitoring timer is stored in FDL\_Timer control. The control includes an Enable\_Bit and a Reaction coding for timer expiration (see Section 5.3.1).

FDL\_Timer\_Count-Low/High:

16-bit timer for monitoring of FDL connections. The timer interval is 10 ms. Times up to 655 s can be realized. The value must be at least 2.

SAP\_List and the SAP\_SCB for all FDL\_SAPs (incl. SM\_Time) must be configured by the user (int. C31 or ext.  $\mu$ P) during startup! Changes in the SAP\_List and SAP\_SCB may only be made in Offline status. Dynamic reconfiguring of the SAP list is not permitted! During operation, the DP\_SAPs are established and controlled by the DPS module (access protection). FDL\_SAPs can be opened or locked dynamically. The request 'SAP Act/Deact' is used for this purpose.

### 5.1.1 Configuration of Buffer

The figure below presents the configuration of the Indication and Response buffer for the FDL and DPS SAPs. Both types of buffer appear the same but do not occupy all of the header bytes in the Response buffer.

| Indication Buffer1/2,<br>Response Buffer: | Header Field: | Buffer_Control<br>Length_Data_Buffer<br>Request/Response_Data_Length<br>Request/Response_FC<br>Remote_Adr (req_sa)<br>Remote_SAP (req_ssap) |
|-------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|                                           | Data Field:   | Data 0<br>Data 1<br><br>Data 243                                                                                                            |

**Figure 5.1-2:** Configuration of Indication/Response Buffer The individual entries are explained in more detail below:

#### Header Field:

#### Buffer\_Control:

The Indication buffers are controlled using the 'Buffer\_State' bit. In the case of an Indication, the MAC sets 'Buffer\_State = 1', thus assigning the buffer to the user. In addition, 'Event\_Indication = 1' is set. For a DPS\_Indication buffer, these bits have no significance. The alternating buffer is always available here, i.e., in the case of an Indication, the Indication buffer in the SAP\_SCB is exchanged for another and the corresponding DPS\_SM is triggered, thus generated a DPS interrupt. In the case of FDL, an entry is generated in the Indication\_Queue of 'Request\_Pdu Indication' type and the 'IndQ\_Entry-Interrupt' is also generated. The user must then fetch the entry from the Indication\_Queue. This enables him to receive the SAP\_No. and Indication\_Buffer Address. After readout, he must set bit 'Event\_Indication = 0'.

If the user provides a Response Buffer for FDL, he must also set bit 'Response=1' in 'Buffer\_State=1'. The data are sent at the next Request frame to this SAP (Request Pdu or Poll Pdu). After the Response buffer has been sent, an entry is made in the Indication\_ Queue of type 'Poll\_End-Indication' (timing: only after any new request frame has been received). In so doing, the bit 'No\_Ind\_Reset' controls whether the buffer is available afterwards in the SAP as an Indication buffer (No\_Ind\_Reset=0  $\Rightarrow$  Buffer\_State=0, Response=0) or continues to be available to the user for entering a new response (No\_Ind\_Reset=1  $\Rightarrow$  Buffer\_State=1, Response=0).

In the case of a DP\_SAP, the Response buffer is available in SAP\_SCB until the user causes it to be swapped.

The 'Buffer\_In\_Use' bit is a MAC-internal control bit, which, in the case of an Indication buffer, indicates that an Indication has been buffered and thus the buffer is occupied (not for DP\_SAPs) or, in the case of the Response buffer, indicates that the Response data are being sent. With the corresponding FDL indication 'Req\_Pdu-Indication or Poll\_End-Indication', the MAC resets this flag.

| Buffer_Control <sub>7.0</sub> |            |          |        |              |          |
|-------------------------------|------------|----------|--------|--------------|----------|
| Buffer_State                  | Event_     | Response | Buffer | No_Ind_Reset | 20       |
|                               | Indication |          | In_Use |              | Reserved |

Figure 5.1-3: Assignment of Buffer\_Control Buffer\_State: Access of

Access control to the buffer (only relevant for FDL-SAPs)

Event\_Indication: Display an Indication (only relevant for FDL-SAPs)

|                | 0 = No Indication<br>1 = Indication                           |
|----------------|---------------------------------------------------------------|
| Response:      | Control of Response data                                      |
|                | 0 = The user has provided no response data.                   |
|                | 1 = The user has provided response data.                      |
| Buffer_In_Use: | Indication buffered, or response data are                     |
|                | being sent.                                                   |
|                | 0 = No indication buffered, or response-                      |
|                | data are not being sent.                                      |
|                | 1 = An indication is stored in the Indication buffer (not for |
|                | DP_SAPs), or the data are being fetched from the              |
|                | response buffer.                                              |
| No_Ind_Reset:  | Control of Response buffer after the 'Poll_End-Indication'    |
|                | (only relevant for FDL-SAPs). In the case of 'Req_Pdu-        |
|                | Indication', this bit is overwritten by DPC31.                |
|                | 0 = The buffer becomes the Indication buffer and is           |
|                | assigned to the MAC (Buffer_State=0, Response=0).             |
|                | 1 = The buffer remains for the user and can be used           |
|                | again as a Response buffer (Buffer_State=1,                   |

Length\_Data\_Buffer:

This value specifies the length of the data field in the Indication buffer (unoccupied in the Response buffer). If the net data length of the Request frame exceeds the available buffer length, the MAC responds with 'no Resource'.

Comment: SAP is made plausible according to the following sequence:

Response=0).

- Request\_SA: resp-status RS - Access-Value: resp-status RS

- Length\_Data\_Buffer: resp-status RR

Request/Response\_Data\_Length:

This value specifies the length of the entered net data in the Indication or Response buffer (0 to 244 bytes).

#### Request/Response\_FC:

The MAC enters the function code of the Request frame here in the Indication buffer. The following codes are available:

| Function                           | Code      |
|------------------------------------|-----------|
| SM Time 0                          | 01xx0000b |
| SM Time 1                          | 11xx0000b |
| Send Data with Acknowledge low     | 01xx0011b |
| Send Data with no Acknowledge low  | 01xx0100b |
| Send Data with Acknowledge high    | 01xx0101b |
| Send Data with no Acknowledge high | 01xx0110b |
| DXB-Request                        | 01xx0111b |
| DXB-Response low                   | 00xx1000b |
| DXB-Response high                  | 00xx1010b |
| Send and Request Data low          | 01xx1100b |
| Send and Request Data high         | 01xx1101b |

xx: received FCB/FCV

The user stores the Responder status in this field in the Response buffer. The following codes are permitted:

| Function                     | Code      |
|------------------------------|-----------|
| Response FDL/FMA1/2-Data low | 00001000b |

| (& Send Data okay)            |           |
|-------------------------------|-----------|
| Response FDL/FMA1/2-Data high | 00001010b |
| (& Send Data okay)            |           |

Remote\_Adr (req\_sa):

The MAC enters the received Remote\_Address in the Indication buffer (unoccupied in the Response buffer).

Remote\_SAP (req\_ssap):

The MAC enters the received Remote\_SAP here in the Indication buffer (unoccupied in Response buffer).

Special handling for default SAP:

In the case of the default SAP, this byte has a different meaning

#### Data Field:

The MAC stores the received net data here in the Indication buffer. The user provides the Response net data in the Response buffer. The maximum data length is 244 characters.

### 5.1.2 Request Interface for DPS and FDL (Instruction Queue)

User requeDXB to the DPS and MAC modules are transferred via a request interface. This request list is a polling list onto which the user transfers communication requeDXB. Figure 5.1-4 shows the organization of the Instruction\_Queue. With each entry (5 bytes respectively), the user must also transfer the command to the sequential control system. This is done with a write operation with any data value to the register cell 'User\_InstQ\_Write Cmd'. The organization of the Instruction\_Queue includes the following parameters:

| InstQ_Base Ptr: | The Instruction_Queue segment pointer                                         |
|-----------------|-------------------------------------------------------------------------------|
| InstQ_Length:   | Describes the length of the Instruction_Queue and is a multiple of the length |
|                 | of an entry (n*5)                                                             |
| InstQRd Ptr:    | An Offset_Pointer which points to the next entry that is to be read (and is   |
|                 | managed by the DPC31)                                                         |
| InstQ_Wr Ptr:   | An Offset_Pointer which points to the next free entry (and is managed by the  |
|                 | user)                                                                         |

The queue is empty if 'InstQ\_Wr ptr' and 'InstQ\_Rd ptr' point to the same position. **One entry in** the queue always must remain empty (wildcard, any content!); otherwise, an empty queue can't be distinguished from a full queue. The user must control the wrap in the queue. After each entry, the user places the InstQ\_Wr ptr behind this entry on the next free position. If this is the end of the queue, the InstW\_Wr ptr will then have to be placed on the beginning of the queue (wrap around).



Figure 5.1-4: Organization of the Instruction\_Queue

Table 5.1-2 lists all possible requests the necessary command codes.

| Request             | Com_ | Value1             | Value2     | Value3  | Value4   | Comment                                  |
|---------------------|------|--------------------|------------|---------|----------|------------------------------------------|
|                     | Code |                    |            |         |          |                                          |
| MAC_Start           | 10h  | -                  | -          | -       | -        | MAC enters Pas_ Idle                     |
| MAC_Stop            | 11h  | -                  | -          | -       | -        | MAC enters Offline                       |
| $MAC\_New\_T_{RDY}$ | 12h  | T <sub>RDY70</sub> | -          | -       | -        | Transfer of T <sub>RDY</sub>             |
| SAP_Act/Deact       | 13h  | SAP_No             | req_sa     | -       | -        | Activate/deactivate                      |
|                     |      |                    |            |         |          | FDL_SAP                                  |
| En_New_SM_          | 14h  | -                  | -          | -       | -        | New synchronization is                   |
| Time-Sync           |      |                    |            |         |          | enabled.                                 |
| User_Leave-         | 15h  | -                  | -          | -       | -        | User initiates a 'Leave                  |
| Master <sup>1</sup> |      |                    |            |         |          | Master' without Cfg_Fault                |
| User_Leave-         | 15h  | Bit 0: Cfg_Fault   | -          | -       | -        | User initiates a:                        |
| Master <sup>2</sup> |      | Bit 7 to 1: 0      |            |         |          | Bit0=1: 'Leave-Master' with<br>Cfg_Fault |
|                     |      |                    |            |         |          | Bit0=0: 'Leave-Master'                   |
|                     |      |                    |            |         |          | without Cfg_Fault                        |
| Stop_C1_Con         | 16h  | -                  | -          | -       | -        | User_Confirmation of                     |
|                     |      |                    |            |         |          | 'Stop_C1-Indication'                     |
| Set_Addr            | 17h  | Station_Addr       | -          | -       | -        | Set new station address.                 |
| DPS_User_Wd         | 20h  | 00h=reset          | -          | -       | -        | Control of DPS User_                     |
|                     |      | 01h=enable         |            |         |          | Watchdog Timer                           |
|                     |      | 02h=disable        |            |         |          |                                          |
| FDL_Timer_          | 21h  | SAP_Nr             | Timer_     | Timer_  | Timer_   | Change to an FDL Timer                   |
| Change              |      |                    | Control    | Low_Val | High_Val |                                          |
| DDB_                | 22h  | 00h=disable        | -          | -       | -        | Activate/deactivate                      |
| Enable/Disable      |      | 01h=EN_DP_DDB      |            |         |          | internode communication                  |
| Get_Ind_Resp_       | 23h  | SAP_Nr             | Ind_Resp_B | -       | -        | Retrieve an                              |
| Buffer              |      |                    | uffer_Ptr  |         |          | Indication/Response buffer               |
|                     |      |                    |            |         |          |                                          |
|                     |      |                    |            |         |          |                                          |

<sup>&</sup>lt;sup>1</sup> Im Parameterregister ist das Bit En\_LM\_Val1=0

<sup>&</sup>lt;sup>2</sup> Im Parameterregister ist das Bit En\_LM\_Val1=1

#### Table 5.1-2: Overview of User\_MAC/DPS Requests

The FMA requeDXB 'SAP\_Act/Deact', 'MAC\_Stop' and 'Get\_Ind\_Resp\_Buffer' are confirmed to the user after execution. For this purpose, an appropriate entry is made in the Indication\_Queue. Only one 'SAP\_Act/Deact Request and one 'Get\_Ind\_Resp\_Buffer Request' can be transferred each time. A new 'SAP\_Act/Deact Request' or 'Get\_Ind\_Resp\_Buffer Request' is possible only after the corresponding confirmation!

With 'Stop\_C1\_Con', the user acknowledges that the MSAC1S SAPS (50-52) are closed. This enables a new opening (entrance in Data\_Exchange)!

#### User-Leave-Master:

If bit <u>En LM Val1=0 in the parameter register</u>, the user then uses this request to initiate a 'Leave\_Master' without the bit 'Diag.Cfg\_Fault' being set simultaneously in the diagnostics. If on the other hand, bit <u>En\_LM\_Val1=1 is set in the parameter register</u>, the user uses this request—if bit 0 in Value1 is set—to initiate a 'Leave\_Master & Diag.Cfg\_Fault=1' or—if the bit is not set—to initiate a 'Leave\_Master' without bit 'Diag.Cfg\_Fault' being set simultaneously in the diagnostics.

#### **Special Operating Cases:**

- 1. If a 'User-Leave-Master' is provided with 'Cfg\_Fault' in the request interface and the diagnostic buffer is being sent during this evaluation, then:
- Only one internal memory bit is set
- Diagnostic bit 'Diag.Cfg\_Fault' is set once the diagnostic buffer is available again due to the set memory bit.
- 2. If two 'User-Leave-Master" (one with and one without Cfg\_Fault') are placed in direct succession in the request interface, diagnostics are not fetched at the present time. That is, the diagnostic buffer is available, then::
- The request sets the diagnostic bit 'Diag.Cfg\_Fault' with 'Cfg\_Fault'
- A subsequent request without 'Cfg\_Fault', on the other hand, does **not** reset the diagnostic bit 'Diag.Cfg\_Fault'.
- 3. If two 'User-Leave-Master' (one with and one without a'Cfg-Fault') are place in direct succession in the request interface and the diagnostic buffer is being sent, i.e., the diagnostic buffer is occupied during evaluation of both requeDXB, then:
- The request with 'Cfg\_Fault' sets only one internal memory bit
- A subsequent request without 'Cfg\_Fault' resets this internal memory bit, i.e., the 'User-Leave-Master' with 'Cfg\_Fault' is suppressed in this case.

#### <u>Set\_Addr:</u>

The user uses this request to initiate an immediate change of the node address. The node address is evaluated by DPC31 only when each new frame is received. The new node address must be  $\leq$  125.

The new node address can be read back after the successful conversion in the TS\_Adr\_Register (846h).

### 5.1.3 Acknowledgement Interface for FDL and FMA (Indication\_Queue)

FMA confirmations (for example, MAC\_Reset con; refer to Chapter 5.1.2) are transferred to the user in an Indication\_Queue (polling list). Figure 5.1-5 shows the organization of the Indication\_Queue. With each entry (3 bytes respectively), the 'IndQ\_Entry Int' is additionally generated for the user. If the queue is full and the MAC is to make another entry, this indication is abandoned and the 'IndQ\_Full Int' is set (refer to Chapter 7.1.4). The user should avoid this condition by dimensioning the queue accordingly large. There is no effect on the bus (for example, no RR if the queue is full). 

 The organization of the Indication\_Queue includes the following parameters:

 IndQ\_Base Ptr:
 The Indication\_Queue segment pointer

 IndQ\_Length:
 Describes the length of the Indication\_Queue, and is a multiple of the length of an entry (n\*3)

 IndQRd Ptr:
 An Offset\_Pointer and points to the next entry that is to be read (and is managed by the user)

 IndQ\_Wr Ptr:
 An Offset\_Pointer and points to the next free entry (and is managed by the MAC)

The queue is empty if 'IndQ\_Wr Ptr' and 'IndQ\_Rd Ptr' point to the same position. **One entry in the queue always has to remain empty .** 

Table 5.1-3 lists all possible indications with the associated command codes.



#### Figure 5.1-5: Organization of the Indication\_Queue

| Request                    | Com_Code | Value1  | Value2     | Comment                            |
|----------------------------|----------|---------|------------|------------------------------------|
| Req_Pdu-Ind                | 40h      | SAP_Nr. | Buf_Ptr    | Request_Pdu received <sup>3</sup>  |
| Poll_End-Ind               | 41h      | SAP_Nr. | Buf_Ptr    | Response sent, Poll end            |
| Stop_C1-Ind                | 42h      | -       | -          | MSAC1S-SAPs have been closed       |
| SAP_Act/Deact-Confirmation | 80h      | SAP_Nr. | req_sa     | FDL_SAP activated/deactivated      |
| MAC_Stop Confirmation      | 81h      | -       | -          | MAC_Stop was executed              |
| Get_Ind_Resp_Buffer-       | 82h      | SAP_Nr. | Ind_Resp_  | The requested Indication/Response- |
| Confirmation               |          |         | Buffer_Ptr | buffer has been retrieved.         |
| FDL_Timer Expired          | 83h      | SAP_Nr. | FDL_Timer_ | FDL monitoring timer expired       |
|                            |          |         | Control    |                                    |
| DPS_User WD Expired        | 84h      | -       | -          | DPS_User Watchdog timer expired    |

#### Table 5.1-3: Overview of Indications and Confirmations

#### Note:

MAC\_Stop confirmation confirms the MAC transition to the *Offline mode* after the current request has been processed.

SAP\_Act/Deact-Confirmation confirms the execution of this FMA request.

Get\_Ind\_Resp\_Buffer-Confirmation confirms retrieval of the buffer.

### 5.2 DPS Module, Description of the Interface

DPS is enabled in the param register with 'DP\_Mode=1', and started in the Instruction\_Queue with the MAC request 'MAC\_Start'. The user can disable the SAP55 (Set\_Slave\_Address). The DPS protocol is integrated completely into the DPC31. All other DP SAPs are always enabled except for the following: default SAP, SAP 56, SAP57, and SAP58. The remaining four SAPs are enabled only when the 'Data\_Exchange' mode is entered.

3

| SAP_SCB         | Profibus                          | Data CC'                              | User                 |  |  |
|-----------------|-----------------------------------|---------------------------------------|----------------------|--|--|
| Default_SAP:    | Ind_Puffer-Ptr<br>Resp_Puffer-Ptr |                                       | Dout-Puffer          |  |  |
|                 |                                   |                                       | Din-Puffer           |  |  |
| SAP57:          | Resp_Puffer_Ptr                   |                                       |                      |  |  |
| SAP56:          | Resp_Puffer_Ptr                   | Data                                  |                      |  |  |
| SAP58:          | Ind_Puffer-Ptr                    |                                       | _GC-Puffer           |  |  |
| SAP60:          | Resp Puffer Ptr                   | ·□' • 'U'                             | U_Diag-Puffer        |  |  |
| SAP59:          | Resp_Puffer_Ptr                   | ·D, ↔ (∩,                             | U_GCfg-Puffer        |  |  |
| SAP55:          | Ind_Puffer-Ptr                    | ·                                     | U_SSA-Puffer         |  |  |
| SAP61:          | Ind_Puffer-Ptr                    | · 'D' ↔ 'U'                           | U_Prm-Puffer         |  |  |
| SAP62:          | Ind_Puffer-Ptr                    | · · · · · · · · · · · · · · · · · · · | U_Cfg-Puffer         |  |  |
| SAP53:          | Ind_Puffer-Ptr                    | ·□' + 'U'                             | U_Ext_Prm-<br>Puffer |  |  |
| DXB_SCB         |                                   |                                       |                      |  |  |
| D               | XB0_D_Puffer-Ptr                  | · D' ↔ 'N' ← 'F' ← 'U'                | DXB0-Puffer          |  |  |
|                 |                                   |                                       |                      |  |  |
| D               | <br>XB7_D_Puffer-Ptr              |                                       | DXB7-Puffer          |  |  |
| Pufferanordnung |                                   |                                       |                      |  |  |

#### ure 5.2-1: DPS Buffer Structure

Figure 5.2-1 shows the DPS buffer structure. The buffers (length and buffer ptr) are configured by the user in the 'Offline Mode' in the DPS buffer management.

For the Dout data, four buffers of the same length are available and, for the DXB0-7 data (separate management in DDB\_SCB), three buffers each of the same length are available, which are implemented as alternating buffers. One buffer each is assigned to the incoming data transfer 'D' and the user 'U'. The third buffer is either in a Next 'N' or Free 'F' mode, whereby one of the two modes is always unoccupied. The MAC clears the data in 'D'. After receiving, 'D' is moved to 'N', and a new buffer is fetched from the 'N' or 'F'. The user fetches its output data from 'N'. In the fourth buffer 'C', the user makes the substitute values available for the Clear mode (failsafe). If the DPC31 receives Clear messages or if DPS leaves the 'Data\_Exchange' mode, the 'C' buffer is transferred to the user in the state 'U'. The buffers are moved through the corresponding exchange. DPS then also performs the buffer exchange for the user.

The Din data is controlled via three exchange buffers of the same length. One buffer each is assigned to the data transfer 'D' and the user 'U'. The third buffer is either in a Next "N" mode, or Free 'F' mode. When sending, the MAC fetches the Din data from 'D'. The user prepares new Din data in 'U' and then moves it to 'N'. DPS then changes the buffers from 'N' to 'D'.

For the diagnostic SAP and the Get\_Cfg SAP (SAP60/59), two buffers respectively are available that may have different lengths. The 'D' buffer is always assigned to the MAC for sending and the 'U' buffer belongs to the user for preparing new data. DPS exchanges the buffers upon user request.

In SAP55 (Set\_Slave\_Address), SAP53 (Set\_Ext\_Param), SAP61 (Set\_Param), and SAP62 (Check\_Config), one indication buffer, respectively, is available, in which the received data are cleared. At the indication, this buffer is exchanged for the corresponding buffer in DPS buffer management (User\_SSA buffer, User\_DDB\_Prm buffer, User\_Prm buffer, or User\_Cfg buffer) and then the corresponding DPS control unit is triggered.

# 5.2.1 Set\_Slave\_Address, SSA (SAP55)

Two exchange buffers of the same length are available for this SAP. One buffer is integrated as indication buffer in the SAP\_SCB (MAC\_SSA buffer) and the other is included in DPS buffer management as User\_SSA buffer. The indication is always transferred to the user in User\_SSA Buffer.

The user can disable the SSA service by setting the 'MAC\_SSA\_Buffer Ptr=00h' at power-up. The DPC31 then responds to an SSA request with 'no service activated'.

The new 'Station Address' and the parameter 'Real\_No\_Add\_Change' are stored by the user and retransferred to the software modules "MAC and DPS" after every restart caused by a voltage failure, for example.

If the DPC31 receives a Set\_Slave\_Address message, and if the SAP55 is enabled, the MAC first checks whether the indication buffer has the corresponding size. If not, the MAC responds with 'No Resource'. Otherwise, it sends a short acknowledgement and after the send process transfers this buffer to the DPS module. The MAC has already accepted the new station address, however.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | Byte    | Name              |
|---|---|---|---|---|---|---|---|---------|-------------------|
|   |   |   |   |   |   |   |   | 0-5:    | Buffer Header     |
|   |   |   |   |   |   |   |   | 6:      | New_Slave_Address |
|   |   |   |   |   |   |   |   | 7:      | Ident_Number_High |
|   |   |   |   |   |   |   |   | 8:      | Ident_Number_Low  |
|   |   |   |   |   |   |   |   | 9:      | No_Add_Change     |
|   |   |   |   |   |   |   |   | 10-249: | Rem_Slave-Data    |

## Figure 5.2-2: Assignment in the Data Field of the SSA Indication Buffer

In the following states, the DPS module ignores the SSA indication:

- DP\_SM mode 'Wait\_Cfg', 'Data\_Exchange'
- Net data length less than 4 bytes
- Parameter 'Real\_No\_Add\_Change' is 'True' (FFh)
- New station address is larger than 125
- Ident No. is wrong

#### User\_SSA\_OK Cmd (Read Operation):

| 0 | 0 | 0 | 0 | 0                 | 0 | User_Ack₁                                              | User_Ack <sub>0</sub>                  |  |  |  |  |  |  |
|---|---|---|---|-------------------|---|--------------------------------------------------------|----------------------------------------|--|--|--|--|--|--|
|   |   |   |   |                   |   | User_Ac                                                | $k_{10} = 00 \Rightarrow$              |  |  |  |  |  |  |
|   |   |   |   | User_SSA_Finished |   |                                                        |                                        |  |  |  |  |  |  |
|   |   |   |   |                   |   | User_Ack <sub>10</sub> = 01 $\Rightarrow$ SSA_Conflict |                                        |  |  |  |  |  |  |
|   |   |   |   |                   |   | User_Ac                                                | $k_{10} = 11 \Rightarrow Not_Allowed$  |  |  |  |  |  |  |
|   |   |   |   |                   |   | User_Ac                                                | $k_{10} = 10 \Rightarrow not possible$ |  |  |  |  |  |  |

#### Table 5.2-1: Coding of User\_SSA\_OK Cmd

The acknowledgement 'User\_SSA\_OK Cmd' is a read access to a register cell with the corresponding codes 'Not\_Allowed', 'User\_SSA\_Finished', or 'SSA\_Conflict'.

The SSA\_State\_Machine is reset also when the DPS is powered up -that is, after the user has transferred 'MAC\_Start' in the request list- or the watchdog has expired in the mode 'DP\_Control'. If the SSA message is repeated because the short acknowledgement was faulty on the bus, the MAC ignores it because it has already accepted the new station address.

## 5.2.2 Set\_Param, Prm (SAP61)

For this SAP, two exchange buffers of the same length are available. One buffer is integrated as the indication buffer (MAC\_Prm buffer) and the other is located as the User\_Prm buffer in DPS buffer management. The indication is always transferred to the user in the User\_Prm buffer. The DPS module accepts this request in any DPS mode (Wait\_Prm, Wait\_Cfg, Data\_Ex). However, the message has to have at least a length of >= 7 bytes; otherwise, it is ignored.

| 7               | 6              | 5             | 4              | 3         | 2           | 1    | 0    | Byte    | Name                 |
|-----------------|----------------|---------------|----------------|-----------|-------------|------|------|---------|----------------------|
|                 |                |               |                |           |             |      |      | 0-5:    | Buffer Header        |
| Lock_<br>Req    | Unlock_<br>Req | Sync_<br>Req  | Freeze_<br>Req | WD_<br>On | Res.        | Res. | Res. | 6:      | Station Status       |
|                 |                |               |                |           |             |      |      | 7:      | WD_Fact_1            |
|                 |                |               |                |           |             |      |      | 8:      | WD_Fact_2            |
|                 |                |               |                |           |             |      |      | 9:      | MinTSDR              |
|                 |                |               |                |           |             |      |      | 10:     | Ident_Number_High    |
|                 |                |               |                |           |             |      |      | 11:     | Ident_Number_Low     |
|                 |                |               |                |           |             |      |      | 12:     | Group_Ident          |
| DPV1_<br>Enable | Failsafe       | EN_D<br>P DXB | res            | res.      | WD_<br>Base | res  | res  | 13:     | DPV1_Status_1        |
| LIIADIE         |                | F_DAB         |                |           | Dase        |      |      |         | (Spec_User_Prm_Byte) |
|                 |                |               |                |           |             |      |      | 14:     | DPV1_Status_2        |
| EN_Prm<br>_Cmd  |                |               |                |           |             |      |      | 15:     | DPV1_Status_3        |
|                 |                |               |                |           |             |      |      | 16-249: | Rem_Slave-Data       |

## Figure 5.2-3: Assignment in the Data Field of the PRM Indication Buffer

Byte 13 is permanently reserved for the DPC31 and **must not** be used for User Prm data. The bytes 13 to 15 are reserved according to DPV1 and **should not** be used for User Prm data in order to make a compatible change to DPV1 possible.

# SIEMENS

Byte 13, Bit 2: WD\_Base:

This bit specifies the time base of the watchdog in DP\_Control; the following assignment applies.

WD\_Base = 0: time base of 10 ms

 $WD_Base = 1$ : time base of 1 ms

Default state: WD\_Base= 0.

Byte 13, Bit 4: Must be assigned log. '0'!

Byte 13, Bit 5: EN\_DP\_DXB:

The bit specifies whether DDB\_Request and DDB\_Response frames filter or pass through on the default SAP.

EN\_DP\_DXB=0: Only DXB\_Request frames are filtered

EN\_DP\_DXB=1: Error-free DDB\_Request and DXB\_Response frames are are passed through and processed by the MAC.

Default state: EN\_DP\_DXB = 0.

Byte 13, Bit 7: DPV1\_Enable:

This bit enables the coupling of the MSAC1S-SAPs to the cyclic machine if 'Check\_DPV1\_Enable=1' (Param register) and the parameter assignment frame contains a data length  $\geq$ 10 bytes.

DPV1\_Enable=0: No coupling of MSAC1S-SAPs.

DPV1\_Enable=1: Coupling of MSAC1S-SAPs.

Byte 15, Bit 7: 'Check\_En\_Prm\_Cmd=1' in the Param register enables 'Enable\_Prm\_Cmd' in the Set\_Prm frame (DPV1\_Status\_3, Bit 7) to be checked. However, this occurs only in the 'Data\_Ex' and 'Operation-Mode=V1' state when a new Prm frame (V1) is received from the same master. If 'Enable\_Prm\_Cmd=1', DPS remains in 'Data\_Ex' state. When 'Enable\_Prm\_Cmd=0', a Leave\_Master is executed. In the case of this Leave\_Master, the diagnostic bit 'Diag\_Prm\_fault' is set.

DPS evaluates the first 7 bytes or the first 10 bytes for longer Prm messages (refer to Figure 5.2-3). The evaluation is performed according to EN 50 170 Volume 2 and will not be discussed in more detail in this description.

In the case of negative validation, DPS sets corresponding diagnostic bits and branches into the 'Wait\_Prm mode'. If the master requests 'Sync\_Req' or 'Freeze\_Req' and the application does not support 'Sync' or 'Freeze' (Sync\_Supported=0, Freeze\_Supported=0 in the param register), the Prm message is not accepted and the diagnostic flag 'Diag.Not\_Supported = 1' is set. In case of positive validation (new, valid message), DPS makes the transition to 'Wait\_Cfg', and executes the following responses, depending on the data length:

- If 'Lock\_Req = 0' and 'Unlock\_Req = 0', only the parameter 'MinTSDR' is accepted internally (S/R unit) and no response is initiated to the user. If 'MinTSDR = 00H', the old value is saved. The S/R unit waits at least 11 T<sub>Bit</sub> prior to sending its response messages. If a MinTSDR < 11 is parameterized, the time is set to 11 by the ASIC.
- If 'Lock\_Req = 1' and 'Unlock\_Req = 0', the DPS accepts the following values: Flag: WD\_ON; watchdog factors: WD\_FACT1/2; the min station delay response: MinTSDR (if it differs from 0 and >10); group generation: Group\_Ident; the master address: Master\_Add. For messages that are longer than 7 net parameter data bytes, the bits from the Spec\_User\_Prm\_Byte are also accepted; otherwise, these bits are assigned default values. The user indication New\_Prm\_Data is then triggered.

The acknowledgements 'User\_Prm\_OK cmd/User\_Prm\_Not\_OK cmd' are read accesses to defined register cells with the corresponding messages 'Not\_Allowed', 'User\_Prm\_Finished', or 'Prm\_Conflict' (refer to Table 5.2-2).

ComDeC

DPC31 HW

# SIEMENS

User Prm OK Cmd (Read Operation):

| 0 | 0                                                            | 0 | 0 | 0                                                       | 0 | User_Ack <sub>1</sub>    | User_Ack <sub>0</sub>                       |  |  |  |  |  |  |
|---|--------------------------------------------------------------|---|---|---------------------------------------------------------|---|--------------------------|---------------------------------------------|--|--|--|--|--|--|
|   |                                                              |   |   |                                                         |   |                          | 00 Hann Deer Finiskard                      |  |  |  |  |  |  |
|   | User_Ack <sub>1.0</sub> = 00 $\Rightarrow$ User_Prm_Finished |   |   |                                                         |   |                          |                                             |  |  |  |  |  |  |
|   |                                                              |   |   |                                                         |   | User_Ack <sub>10</sub> = | $01 \Rightarrow \text{Prm}_\text{Conflict}$ |  |  |  |  |  |  |
|   |                                                              |   |   | User_Ack <sub>10</sub> = 11 $\Rightarrow$ Not_Allowed   |   |                          |                                             |  |  |  |  |  |  |
|   |                                                              |   |   | User_Ack <sub>1.0</sub> = 10 $\Rightarrow$ not possible |   |                          |                                             |  |  |  |  |  |  |

#### User Prm Not OK Cmd (Read Operation):

| 0 | 0 | 0 | 0 | 0 | 0 | User_Ack <sub>1</sub> | User_Ack <sub>0</sub> |
|---|---|---|---|---|---|-----------------------|-----------------------|
|   |   | • | • | • |   |                       |                       |

User\_Ack<sub>1.0</sub>= 00  $\Rightarrow$  User\_Prm\_Finished  $User\_Ack_{1..0} = 01 \Rightarrow Prm\_Conflict$  $User\_Ack_{1..0} = 11 \Rightarrow Not\_Allowed$ User\_Ack<sub>1.0</sub> = 10  $\Rightarrow$  not possible

Table 5.2-2: Coding of User\_Prm\_(Not)\_OK Cmd

## 5.2.3 Check Config, Chk Cfg (SAP62)

For this SAP, two exchange buffers of the same length are allocated. One buffer is integrated as the indication buffer (MAC\_Cfg buffer) and the other is included as the User\_Cfg buffer in DPS buffer management. The indication is always transferred to the user in the User\_Cfg buffer. This service is accepted by DPS in any DP mode. If the Check\_Config message does not come from

'Master \_Add' i.e., the locking master, DPS ignores this message.

The user evaluates the configuration data. After DPS has received a plausible Cfg message, there will be an indication. That is, DPS exchanges the indication buffer in the Cfg SAP for the User\_Cfg buffer from DPS buffer management and generates the 'New\_Cfg\_Data interrupt'. There is no response at this time in the DP SM. The user must then check the 'User Config Data' and acknowledge either positively or negatively (see below).

| User_Cfg_Ok Cn | d (Read Operation): |
|----------------|---------------------|
|----------------|---------------------|

| 0                                                        | 0                                                                                                                                                                                                                                                               | 0 | 0 | 0 | 0 | User_Ack₁             | User_Ack <sub>0</sub> |  |  |  |  |
|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-----------------------|-----------------------|--|--|--|--|
| User_                                                    | User_Ack_{10} = 00 $\Rightarrow$ User_Cfg_Finished<br>User_Ack_{10} = 01 $\Rightarrow$ Cfg_Conflict<br>User_Ack_{10} = 11 $\Rightarrow$ Not_Allowed<br>User_Ack_{10} = 10 $\Rightarrow$ not possibleer_Cfg_Not_Ok Cmd (Read Operation):0000User_Ack_1User_Ack_0 |   |   |   |   |                       |                       |  |  |  |  |
| 0                                                        | 0                                                                                                                                                                                                                                                               | 0 | 0 | 0 | 0 | User_Ack <sub>1</sub> | User_Ack <sub>0</sub> |  |  |  |  |
| $\begin{tabular}{ c c c c c c c c c c c c c c c c c c c$ |                                                                                                                                                                                                                                                                 |   |   |   |   |                       |                       |  |  |  |  |

Table 5.2-3: Coding of User\_Cfg\_(Not)\_OK Cmd

During operation, if the interrupts 'New\_Prm\_Data', New-Ext\_User\_Prm\_Data and 'New Cfg Data' are pending at the user at the same time, the user must follow the sequence Set Param, Set Ext User Param and then Check Config acknowledgement.

## 5.2.4 Slave\_Diagnosis (SAP60)

The diagnostic data of DPS in the DPC31 can be fetched by the master any time.

When the buffers are exchanged by the user, the internal 'Diag\_Flag' is set in. Furthermore, the Diag\_Flag is entered in the status register. If 'Diag\_Flag' is activated, the MAC responds at the next Write\_Read\_Data message with high priority response data. This signals to the associated master that new diagnostic data is present at the slave. If DPS does not have any input data, it responds with a high-priority SD2 message with a dummy net byte (00h). After this high priority reply, the master fetches the new diagnostic data with a Slave\_Diagnosis message. The 'Diag\_Flag' is then reset and the user 'Diag\_Fetched interrupt' is generated. However, if the user signals 'Diag.Stat\_Diag = 1" (static diagnosis; refer to structure of the Diagnosis\_Reply buffers), the 'Diag\_Flag' remains activated even after the associated master has fetched the diagnosis. The user can poll the 'Diag\_Flag' in the status register.

DPS sets 'Diag\_Flag=0' for 'Power\_On', caused by a reset or the startup of the watchdog timer in the 'DP Control mode'; or 'Diag Flag = 1' when entering 'Data Exchange'.

The Diag\_Buffer\_SM is also reset when DPS is powering up. That is, after the user has transferred 'MAC\_Start' in the request list or the watchdog has expired in the 'DP\_Control' mode. A 'Diag Buffer Changed' interrupt, if present, is not deleted.

## Structure of the Diagnosis\_Reply Buffers:

The user transfers the Diagnostic\_Reply buffer shown in Figure 5.2-4. The buffer control area is located in the first 6 bytes. In the 7<sup>th</sup> byte, the user only enters the bit 'Diag.Ext\_Diag' and in the 8<sup>th</sup> byte the bit 'Diag.Stat\_Diag'. The remaining bits in these two bytes can be assigned as required. The user sets up Byte 9 (StationStatus\_3), Byte 11,12 (Ident\_Number) and Byte 13..250 (Ext\_Diag data) completely. Byte 10 is used as wildcard for 'Master\_Add' and can be assigned as required. During buffer exchange, DPS enters the internal Diagnosis\_Flags in Bytes 7 and 8 and also enters the 'Master\_Add' in Byte 10 (refer to Figure 5.2-5).

| 7                             | 6 | 5 | 4 | 3                | 2 | 1                  | 0 | Byte    | Name              |
|-------------------------------|---|---|---|------------------|---|--------------------|---|---------|-------------------|
|                               |   |   |   |                  |   |                    |   | 0-5:    | Buffer Header     |
| -                             | - | - | - | Diag.Ext<br>Diag | - | -                  | - | 6:      | StationStatus_1   |
| -                             | - | - | - | -                | - | Diag.Stat_<br>Diag | - | 7:      | StationStatus_2   |
| Diag.Ext<br>Diag_<br>Overflow | 0 | 0 | 0 | 0                | 0 | 0                  | 0 | 8:      | StationStatus_3   |
| -                             | - | - | - | -                | - | -                  | - | 9:      | Wildcard          |
|                               |   |   |   |                  |   |                    |   | 10:     | Ident_Number_High |
|                               |   |   |   |                  |   |                    |   | 11:     | Ident_Number_Low  |
|                               |   |   |   |                  |   |                    |   | 12-249: | Ext_Diag-Data     |

Figure 5.2-4: Structure of the User Diag Reply Buffer

| 7                             | 6                      | 5                      | 4                          | 3                 | 2                      | 1                            | 0                    | Byte   |
|-------------------------------|------------------------|------------------------|----------------------------|-------------------|------------------------|------------------------------|----------------------|--------|
|                               |                        |                        |                            |                   |                        |                              |                      | 0-5:   |
| 0                             | Diag.<br>Prm_<br>Fault | 0                      | Diag.Not<br>Sup-<br>ported | Diag.Ext<br>_Diag | Diag.<br>Cfg_<br>Fault | Diag.<br>Station_<br>Not_Rdy | 0                    | 6:     |
| 0                             | 0                      | Diag.<br>Sync_<br>Mode | Diag.<br>Freeze_<br>Mode   | Diag.<br>WD_On    | 1                      | Diag.<br>Stat_<br>Diag       | Diag.<br>Prm_<br>Req | 7:     |
| Diag.Ext<br>Diag_<br>Overflow | 0                      | 0                      | 0                          | 0                 | 0                      | 0                            | 0                    | 8:     |
|                               |                        |                        |                            |                   |                        |                              |                      | 9:     |
|                               |                        |                        |                            |                   |                        |                              |                      | 10:    |
|                               |                        |                        |                            |                   |                        |                              |                      | 11:    |
|                               |                        |                        |                            |                   |                        |                              |                      | 12-249 |

| Name                                                    |
|---------------------------------------------------------|
| Buffer Header                                           |
| StationStatus_1                                         |
| StationStatus_2                                         |
| StationStatus_3                                         |
| Master_Address<br>Ident_Number_High<br>Ident_Number_Low |
| Ext_Diag-Data                                           |

Figure 5.2-5: Structure of the MAC\_Diag\_Reply Buffer

## 5.2.5 Write\_Read\_Data (Default SAP)

The MAC accepts the Write\_Read\_Data message only in the 'Data\_Exchange' mode and only from the 'Master\_Add' i.e., the locking master; otherwise, a negative acknowledgement 'RS' is generated. If the received net data (output data) does not fit into indication buffer 'D', the service is ignored and the response is 'no resource'.

The length of the indication buffer 'D' corresponds exactly to the data output configuration of the respective slave. If the received output data is less than the length of the indication buffer, there is a configuration error. In this case, DPS does the following: it sets 'Diag.Cfg\_Fault =1 ' (refer to diagnostic data), executes the 'Leave\_Master macro' transitioning to 'Wait\_Prm') and transmits the input data from the response buffer. Otherwise, the received net data is written to the assigned indication buffer and the net data that is to be sent is fetched from the assigned response buffer. For the output data, 4 exchange buffers are available and for the input data, 3 exchange buffers.

Two operating modes must be able to be taken into account:

#### • Operation without Clear Buffer

This operating mode occurs if bit Disable\_C\_Buffer=1 in the parameter register. In this case, only three alternating buffers are operated and the Clear buffer is blocked from use. The clear buffer is no longer automatically injected. A check by adding substitute values at the outputs is now done with the user software.

## • Operation with Clear Buffer

This operating mode occurs if bit Disable\_C\_Buffer=0 in the parameter register. In this case, four alternating buffers are operated. The Clear buffer is now automatically injected and discharged in the buffer circulation. A check by adding the C buffer and, thus, the substitute values, occurs automatically.

Operation with Clear buffer is always preferred over operation without Clear buffer. If operation without Clear buffer is employed, the Clear buffer is not used. Rather, the current 'D' is transferred to the 'N' buffer with 'DPS-Dout-Change' and an 'DX\_Out\_Interrupt' is initiated. However, in comparison with a 'normal'  $D \rightarrow N$  buffer changeover, the data in the buffer are now invalid. In place of the invalid data, the substitute values must now be output by the user.

In this operating mode, the user must determine for each 'User\_New\_Dout-Cmd' whether the data from the buffer or the substitute values are to be output. Two registers are available to the user for evaluation:

- The 'U\_Buffer\_State' register on address 834h
- The 'req\_ssap' byte in the buffer header of the current U buffer (applies only to the buffer of the default SAP).

In these two registers, only Bit #3 has a function, all other bits are log. '0'.

- Bit #3 = 1: The data transferred in the current U-buffer to the user are invalid. The substitute values must be output in place of the data from the U-buffer.
- Bit #3 = 0: The data transferred to the user in the current U-buffer are valid and can be output by the user.

Additional particularities in conjunction with this operating mode:

- In this operating mode, bit 'U\_Buffer\_Cleared' in the 'User-New\_Dout-Cmd' register is not updated and can therefore also not be used for evaluation
- If Bit #3 in the 'req\_ssap' byte of the current U-buffer is set and this buffer is entered by the MAC as a reply buffer for the read output SAP (SAP 57), the data length is always set to the value from the 'Dout\_Buffer-Length' register in this buffer header in byte 'Resp\_Data\_Length'. The data sent as a response for a Read Output SAP are invalid/incidental.
- Under certain circumstances, the content of the 'U\_Buffer\_State' register can be inconsistent with the content of the user's buffer.

For this reason, the 'req\_ssap' byte from the buffer header should be used.

• The 'req\_ssap' byte in the buffer header is only updated if an output buffer is present, i.e., Dout\_Buffer-Length is >0.

# 5.2.5.1 DX-Entered-Interrupt

If the MAC\_State\_Machine changes from 'passive-Idle' state to a Set\_Param\_Frame (SAP61) and the Check\_Config-Frame (SAP62) either through a Write\_Read\_Data-Frame (Default\_SAP), a fail-safe frame (Default-SAP), or a Global\_Control\_Clear-Frame(SAP58) in 'Data\_Exchange' state, the 'DX-Out-Interrupt' is triggered after each of these frames (provided it is enabled). In addition, the 'DX-Entered' interrupt is triggered with the first of these frames, if diagnostic messages are no longer present.

This interrupt is only triggered again if the 'Data\_Exchange' state is left and then reachieved.

With the read operation 'User\_Dout\_Buffer state', the user receives the current buffer assignment without initiating a buffer exchange!

#### User\_New\_Dout Cmd (Read Operation):

| 0 | 0 | 0  | 0         | U_Buffer_Cleared                       | U_Buffer_State                                   | U_Buffer₁                              | U_Buffer₀ |  |  |  |  |  |
|---|---|----|-----------|----------------------------------------|--------------------------------------------------|----------------------------------------|-----------|--|--|--|--|--|
|   |   |    |           |                                        |                                                  |                                        |           |  |  |  |  |  |
|   |   | U_ | Buffer_St | $U_Buffer_{10}=00 \Rightarrow Buffer4$ |                                                  |                                        |           |  |  |  |  |  |
|   |   | U_ | Buffer_St | ate = 1 ⇒ new U_Buffe                  | r                                                | $U_Buffer_{10}=01 \Rightarrow Buffer1$ |           |  |  |  |  |  |
|   |   | U_ | Buffer_Cl | eared = $0 \Rightarrow$ received d     | $U_Buffer_{10}=10 \Rightarrow Buffer_2$          |                                        |           |  |  |  |  |  |
|   |   | U_ | Buffer_Cl | eared = 1 $\Rightarrow$ substitute     | U_Buffer <sub>10</sub> =11 $\Rightarrow$ Buffer3 |                                        |           |  |  |  |  |  |

## User\_Dout\_Buffer State (Read Operation):

| F_Buffer1 F_Buffer                                           | D U_Buffer₁              | U_Buffer₀ | N_Buffer₁                                                    | N_Buffer <sub>0</sub> | D_Buffer <sub>1</sub>                                                                                  | D_Buffer₀ |  |  |
|--------------------------------------------------------------|--------------------------|-----------|--------------------------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------|-----------|--|--|
| F/N-Buffer <sub>10</sub> = C                                 | $0 \Rightarrow Nil$      | U-Buffer  | $_{0} = 00 \Rightarrow Buf$                                  | fer4 D                | D-Buffer <sub>10</sub> =00⇒not<br>possible                                                             |           |  |  |
| F/N-Buffer <sub>10</sub> = 0                                 | $1 \Rightarrow Buffer 1$ | U-Buffer  | $10 = 01 \Rightarrow Buf$                                    | fer1 D                | $D$ -Buffer <sub>10</sub> = 01 $\Rightarrow$ Buffer1                                                   |           |  |  |
| F/N-Buffer <sub>10</sub> = 1<br>F/N-Buffer <sub>10</sub> = 1 |                          |           | $h_{0} = 10 \Rightarrow Buf$<br>$h_{0} = 11 \Rightarrow Buf$ |                       | D-Buffer <sub>10</sub> = 10 $\Rightarrow$ Buffer2<br>D-Buffer <sub>10</sub> = 11 $\Rightarrow$ Buffer3 |           |  |  |

 Table 5.2-4:
 Coding of User\_New\_Dout Cmd, User\_Dout\_Buffer State

With the read operation 'User\_Din\_Buffer State', the user receives the current buffer assignment without the buffer being exchanged!

#### User\_New\_Din Cmd (Read Operation):

| -                                                                                                                                                                                                 |       |                      | •   |                |                                                                                                                                                                                                                                              |         |      |                        |                       |           |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------|-----|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------------------------|-----------------------|-----------|
| 0                                                                                                                                                                                                 | 0     | 0                    | 0   | 0              |                                                                                                                                                                                                                                              | 0       |      | U                      | Buffer₁               | U_Buffer₀ |
| $\begin{array}{l} U_Buffer_{10}=00 \Rightarrow not \ possible\\ U_Buffer_{10}=01 \Rightarrow Buffer1\\ U_Buffer_{10}=10 \Rightarrow Buffer2\\ U_Buffer_{10}=11 \Rightarrow Buffer3\\ \end{array}$ |       |                      |     |                |                                                                                                                                                                                                                                              |         |      | ⇒ Buffer1<br>⇒ Buffer2 |                       |           |
| F_Buff                                                                                                                                                                                            | er₁ F | _Buffer <sub>0</sub> | U_B | uffer₁ U_Buffe | r <sub>0</sub> N_                                                                                                                                                                                                                            | Buffer₁ | N_Bu | uffer <sub>0</sub>     | D_Buffer <sub>1</sub> | D_Buffer₀ |
|                                                                                                                                                                                                   |       |                      |     | F/N-Buff       | F/N-Buffer10 = 00 $\Rightarrow$ NilU/D-Buffer10=00 $\Rightarrow$ not<br>possibleF/N-Buffer10 = 01 $\Rightarrow$ Buffer1U/D-Buffer10 = 01 $\Rightarrow$ Buffer1F/N-Buffer10 = 10 $\Rightarrow$ Buffer2U/D-Buffer10 = 10 $\Rightarrow$ Buffer2 |         |      |                        |                       |           |

F/N-Buffer<sub>1..0</sub> = 11  $\Rightarrow$  Buffer3

U/D-Buffer<sub>1..0</sub> = 11  $\Rightarrow$  Buffer3

#### Table 5.2-5: Coding of User\_New\_Din Cmd and User\_Din\_Buffer State

At startup, the DP\_SM goes to 'Data\_Exchange' only after a positive user acknowledgement of User\_Cfg\_OK cmd' has followed a Check\_Config message, and additionally, the first valid Din buffer was made available in 'N' with the 'User\_New\_Din cmd'.

#### DPS\_User Watchdog:

After power-up ('Data\_Exchange' mode), it is possible that the DPC31 continuously replies to Write\_Read\_Data messages without the user fetching the received Dout buffers or making new Din buffers available. If the user processor should "hang", the master would not notice it. For that reason, a 'DPS\_User watchdog' is implemented in DPS. This timer can be enabled or disabled any time via the request interface (DPS\_User WD, Enable; or DPS\_User WD, Disable). Note: In the case of the SPC3, the processor is monitored via a counter.

The DPS\_User\_Watchdog is an internal 16bit RAM cell that is started by a user-parameterized value 'DPS\_User WD Value<sub>15..0</sub>', and is decremented every 10 msec. If the timer reaches the value '0000h', DPS does the following: it executes 'Leave\_Master', locks the DPS\_User WD, and enters the event 'DPS\_User\_WD Expired' in the Indication\_Queue.

The user has to cyclically set this timer to its initial value. To do this, the user must transfer 'DPS\_User WD, Reset' via the request interface. DPS then reloads the timer to the parameterized value 'DPS\_User WD Value<sub>15.0</sub>'.

With 'DPS\_USER WD, Enable' request, the DPS\_User WD is automatically set to its initial value and started.

## 5.2.6 Global\_Control (SAP58)

The MAC accepts the Global\_Control message only in the 'Data\_Exchange' mode and only from 'Master\_Add'. Under all other instances, the service is ignored. If more than two net data bytes (Control\_Command, Group\_Select) are received (refer to Table 5.2-6) or if there is no indication buffer, DPS also does not accept this service.

| 7    | 6    | 5    | 4      | 3      | 2        | 1              | 0    | Byte | Name            |
|------|------|------|--------|--------|----------|----------------|------|------|-----------------|
|      |      |      |        |        |          |                |      | 0-5: | Buffer Header   |
| Res. | Res. | Sync | Unsync | Freeze | Unfreeze | Clear_<br>Data | Res. | 6:   | Control_Command |
|      |      |      |        |        |          |                |      | 7:   | Group_Select    |

## Table 5.2-6: Data Format of the Global\_Control Message

The parameter Group\_Select establishes which group(s) is(are) to be addressed. The Global\_Control message becomes effective if the bit by bit AND operation of the Group\_Ident, transferred in the Set\_Parameter message, with the Group\_Select parameter supplies a value unequal to 0 on at least one bit position. If Group\_Select is equal to 0, all slaves are addressed.

## Byte Control\_Command:

| Bit 7, 6, 0: | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | The designation "Reserved" indicates that these bits are reserved for future function expansions. If such a bit is set, DPS sets 'Diag.Not_Supported=1', and the "Leave_Master macro' is executed. However, if the user parameterizes 'Check_No_GC_Reserved=1' in the param register, the Reserved bits are not                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|              | checked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 5:       | Sync                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              | The output data transferred with a Write_Read_Data message is changed from 'D' to 'N' (DX_OUT interrupt is generated). The subsequently transferred output data is kept in 'D' until the next 'Sync' command is made. The same reaction occurs for 'Sync_Supported=0' as does for a set Reserved bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Bit 4:       | Unsync                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Dit 1.       | The command 'Unsync' cancels the 'Sync' command. In addition, as in the case of 'Sync', the previously transferred output data is changed from 'D' to "N'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Bit 3:       | Freeze                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | The input data is fetched from 'N' to 'D', and "frozen". New input data will be fetched only if the master sends the next 'Freeze' command. The same reaction occurs for 'Freeze_Supported=0' as does for a set Reserved bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 2:       | Unfreeze                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|              | With 'Unfreeze', freezing the input data is cancelled. In addition, as in the case of 'Freeze', new input data that was made available is fetched from 'N' to 'D'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 1:       | Clear_Data<br>In operation with Clear buffer, the Dout buffer is not deleted and it is not changed;<br>rather, the mode 'N_Cl=1' is set in the Dout_Buffer_SM, and the user interrupt<br>'DX_OUT' is generated. If the user then fetches his new Dout data, the C and U<br>buffers are exchanged and the user gets the message 'U_Buffer_Cleared'.<br>In operation without Clear buffer, this command causes a completely normal buffer<br>exchange and interrupt 'DX_OUT' is generated. If the user fetches his new Dout<br>data from it, he must use the 'req-ssap' byte in the buffer header or the<br>'U_Buffer_State' register to determine whether the data are to be output from the<br>buffer or if the substitute values are to be output instead.<br>The DDB/DXBout data are not subject to Clear control. The 'Clear' has a higher<br>priority than 'Sync.' |

With 'sync', data buffers are made available synchronously. However, this does not provide for synchronous mapping directly to the I/O as is the case with the LSPM2. Although the application is interrupted via the 'DX\_OUT interrupt', the transfer time from the buffer that was made available to the I/O is subject to interrupt latency. To bypass it, the interrupt 'DX\_OUT' can directly be applied to the port PB3 if a global control message is received with 'Sync', provided 'Enable DX\_OUT\_Port=1' was parameterized in the C31\_Control register beforehand. Thus, external HW support, or separate interrupt processing could bring about the transfer from the buffer to the I/O in a fixed time reference.

With 'Freeze', the available Din buffer in 'N' is frozen to 'D'. Thus, in distinction to the LSPM2, no updating is provided at this time from the I/O. To circumvent this, the user would have to make the input data, if it changes, available immediately in the N buffer (high processor capacity required).

For each valid Global\_Control message, the Control\_Command byte is stored in the RAM cell 'GC\_Command'. At initialization, DPS preassigns FFh (not a valid value) to the RAM cell 'GC\_Command'. The user can read and interpret this cell. Depending on the setting of 'New\_GC\_Int mode' (refer to Param Register), the interrupt 'New\_GC\_Command' is generated. With 'New\_GC\_Int mode = 0', the interrupt is generated only if the Control\_Command byte for the last received Global\_Control message has changed. With 'New\_GC\_Int mode=1', the interrupt is generated after each receipt of a GC message.

## Equidistant Cycle, Sync Clock:

The ASPC2 Step E supports an equidistant cycle, i.e., it begins with the DP cycle exactly on the clock pulse (resolution; approx. 1  $\mu$ s). For closed-loop control systems such as an 'electronic shaft', the DPC31 can generate a Sync clock (clock pulse beater) after receipt of the last bit of the first DP request. This request must be a 'global control frame' in its own group. The Sync clock (low active pulse of 2-3  $\mu$ sec length), is output on Port PB<sub>2</sub> and interrupt 'GC-Clock' is also generated. So that Port PB<sub>2</sub> is isolated for this function, bit 'Enable GC\_Clock=1' must be set in the C31\_Control-Register.

The special group for the Sync clock must be parameterized for the DPC31 by the user ('group clock'). During receipt of **any GC frame** by the DP master (Master\_Add), the DPC31 makes a bit-by-bit AND operation of the second received data byte (Group Select) with 'Group\_Clock'. If a hit occurs, the Sync clock is initiated at the end of the GC frame. The values for the jitter and the delay of the Sync clock are presented in Table 5.2-7 for asynchronous operating mode of the DPC31 and a load of 80 pF at Port PB<sub>2</sub>.

| Baud Rate    | Delay (after ED of GC frame.)                | Jitter (max.)                          |
|--------------|----------------------------------------------|----------------------------------------|
| 12 MBd       | T <sub>BIT</sub> + 7 T <sub>48</sub> + 20 ns | 1/4 T <sub>BIT</sub> + T <sub>48</sub> |
| $\leq$ 6 MBd | T <sub>BIT</sub> + 7 T <sub>48</sub> + 20 ns | 1⁄4 T <sub>BIT</sub>                   |

 Table 5.2-7: Timing Values for Sync Clock

#### Failsafe Mode:

To support the failsafe mode, a 'Spec\_Clear\_Mode' is implemented in the DPC31. The master generates such a Clear mode by sending a Global\_Control message with 'Clear\_Data=1'. The Din data has to continue to be fetched during this Clear\_Mode. For this, the master has to send the Write\_Read\_Data message with the parameterized number of Dout data bytes=00h. However, in the case of many slave applications, the value 00h does not correspond to the Clear mode (for example, substitute values for analog modules). Here, the user generates the corresponding substitute values. If the Global\_Control message was not received because of a bus fault, this slave does not know that it should be in the Clear mode; therefore, the subsequently received Dout data bytes with the value 00h can't be replaced with the substitute values.

To support the failsafe mode, the DPC31 also accepts Write\_Read\_Data messages without output data even though the parameterized Dout length 'Dout\_Buffer length # 0' is set. After the receipt of this message, the C buffer where the substitute values are stored, is then included in the buffer circulation. If the user fetches this buffer in operation with Clear buffer, the display

'U\_Buffer\_Cleared' is set with 'User\_New\_Dout-Cmd' (refer to Table 5.2-4) and the user receives the information that it is cleared data (substitute values).

If the user fetches this buffer in operation without Clear buffer, he receives information with 'req\_ssap' byte in the buffer header or with the 'U\_Buffer\_State' register on whether the data from the data buffer or substitute values are to be output.

## 5.2.7 Read\_Inputs (SAP56)

The Read\_Input message is accepted by the MAC only with request data length = 0, in the mode 'Data\_Exchange', from any master. For this, DPS enters the corresponding validation values in

'SAP56 of the SAP\_SCB'. In the other modes, the DPC31 responds with 'no service activated' (modes 'Wait\_Prm, Wait\_Cfg') or 'no resource' (request data length # 0).

The exchange of the Read\_Input buffer has been described previously. Between the initial call and the repetition if there is a buffer change from 'U' -> 'N' -> 'D' (through User\_New\_Din command), the new input data is sent at the repetition.

# 5.2.8 Read\_Outputs (SAP57)

The Read\_Output message is accepted by the MAC only with request data length = 0, in the mode 'Data\_Exchange', from any master. For this, DPS enters the corresponding validation values in 'SAP57 of the SAP\_SCB'. In the other modes, the DPC31 responds with 'no service activated/no resource'.

The exchange of the Read\_Output buffer has been described previously.

Between the initial call and the repetition if there is a buffer change from 'N' -> 'U' (through User\_New\_Dout command), the new output data is sent at the repetition.

# 5.2.9 Get\_Config (SAP59)

The Get\_Config message is accepted in all modes. If the call message contains request data, the MAC acknowledges with 'no resource'.

# 5.2.10 Data Exchange Broadcast (DXB)

## Requirements for Data Exchange Broadcast:

- Every DP slave must be able to receive data from another DP node (master or slave) without going through its own master (see Figure 5.2.5).
- Each DP node (master or slave) must be able to send data to another DP slave without going through its own master.
- Up to 8 links per DP slave are possible.



Figure 5.2-6: Data Exchange Broadcast between different Masters and Slaves Implementation of Internode Data Communication:

- The DXB service (Write\_Read\_Data with DXB) enables internode communication from one DP slave (publisher) to several other DP slaves (subscriber) using a single data frame. The master addresses the publisher with a special call service (DXB request) and the publisher responds under the broadcast address. All slaves are thus in the position to receive this response frame.
- Configuration is used to inform each DP slave of which information is defined for it (link buffer). This configuration information is communicated to the node.
- The address relationship under which a DP slave is to receive data from one of these frames is entered in the respective link. In addition, the link includes the data range (continuous) that is to be tapped from the frame.
- The Publisher function applies to all DPS SAPs and the subscriber function applies only to the I/O data (Default\_SAP under DXB response frame)

- Publisher mode is enabled with 'EN\_DXB\_Publisher=1' in the Param register. Subscriber mode is only enabled in DPC31 if 'EN\_DP\_DXB=1' was communicated in the Set\_Param frame) or the command 'EN\_DP\_DXB' is issued via the request interface.
- When the DPC31 is used as a Publisher, the master must parameterize a  $T_{MinTSDR} \ge 35 T_{Bit}$ .

## **Configuration of the Data Exchange Broadcast:**

The configuration for the DXB tap can occur with the Set\_User\_Prm-Frame (SAP53) or via DPV1.

#### a) Ext\_User\_Prm-Frame (SAP53):

The Set\_DDB\_Prm-Frame can be locked by the user by setting the 'MAC\_Ext\_User\_Prm-Buffer=00h' during startup. This SAP is then available as a FDL\_SAP. Otherwise, two alternating buffers of the same length are available for this SAP. One buffer is integrated in the SAP-SCB as an Indication buffer (MAC\_Ext\_User\_Prm-Buffer) and the other is attached in the DPS buffer management as a Ext\_User\_Prm-Buffer. The Indication is always transferred to the user in the Ext\_User\_ Prm-Buffer.

This service is accepted by DPS in 'Wait\_Cfg' state only and by 'Master\_Add'. In the 'Data\_Exchange' state, this frame involves a 'Leave\_Master'. DPS ignores this call under all other faulty constellations.

The user takes on the evaluation of the Set\_Ext\_User\_Prm-Frame. Once DPS has received a plausible frame, an Indication occurs, i.e., DPS swaps the Indication buffer in the Ext\_User\_Prm-SAP for the Ext\_User\_Prm-Buffer from the DPS buffer management, and a 'New\_Ext\_User\_Prm\_Data-Interrupt' is generated. No reaction occurs at this time during the sequence. The user must check the 'Ext\_User\_Prm\_Daten' and provide either a positive or negative acknowledgement (see above).

The 'Ext\_User\_Prm\_Ok-Cmd/Ext\_User\_Prm\_Not\_Ok-Cmd' acknowledgements are read accesses to defined register cells with the corresponding messages 'Not\_Allowed', 'Ext\_User\_Prm\_Finished', or 'Ext\_User\_Prm\_Conflict'.

Ext\_User\_Prm\_Ok-Cmd (Read Operation):

| 0     | 0       | 0      | 0      | 0         | 0         | User_Ack1 User_Ack0                                                                                                                                                                                                 |                           |  |  |  |  |  |
|-------|---------|--------|--------|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|--|--|--|--|--|
| Ext_U | ser_Pri | m_Not_ | Ok-Cma | l (Read ( | Operation | User_Ack <sub>10</sub> = 00 $\Rightarrow$ Ext_Us<br>User_Ack <sub>10</sub> = 01 $\Rightarrow$ Ext_Us<br>User_Ack <sub>10</sub> = 11 $\Rightarrow$ Not_Al<br>User_Ack <sub>10</sub> = 10 $\Rightarrow$ not pos<br>): | ser_Prm_Conflict<br>lowed |  |  |  |  |  |
| 0     | 0       | 0      | 0      | 0         | 0         | User_Ack <sub>1</sub>                                                                                                                                                                                               | User_Ack <sub>0</sub>     |  |  |  |  |  |

 $\begin{array}{l} User\_Ack_{1..0}=00\Rightarrow Ext\_User\_Prm\_Finished\\ User\_Ack_{1..0}=01\Rightarrow Ext\_User\_Prm\_Conflict\\ User\_Ack_{1..0}=11\Rightarrow Not\_Allowed\\ User\_Ack_{1..0}=10\Rightarrow not\ possible \end{array}$ 

Table 5.2-8: Coding of Ext\_User\_Prm\_(Not)\_Ok-Cmd

DPS memorizes the current 'Master\_Add' at each trigger. When the DPS interrupts are processed, DPS first checks to determine whether the current 'Master\_Add' still corresponds to the previously stored 'Master\_Add'. If not, a different master has taken over in the meantime and , thus, events are rejected. Otherwise, DPS evaluates the acknowledgements.

If during operation the 'New\_Prm\_Data', 'New\_Ext\_User\_Prm\_Data' und 'New\_Cfg\_Data' interrupts are pending simultaneously for the user, he must adhere to the following acknowledgement order: Set\_Param, Set\_Ext\_User\_Param, and then Check\_Config. A reset is also performed during startup of DPS, thus once the user has transferred 'MAC\_Start' to the request list, or the watchdog has expired in 'DP Control' state.

#### b) DPV1 Configuration:

The Set\_Ext\_User\_Prm frame **must** be locked by the user by setting the 'MAC\_Ext\_User\_Prm buffer=00h' during startup. The user communicates the links (taps) to DPS in the Ext\_User\_Prm

# SIEMENS

DPC31 HW

buffer. In addition, the MAC must still be enabled for the internode communication. This occurs via the request 'DXB \_Enabled/Disabled' in the Instruction\_Queue. This same request can be used at any time to end internode communication. In addition, internode communication mode is tied to DPS. This mode is permitted only in 'Data\_Exchange' state. If DPS leaves 'Data\_Exchange' state, internode communication will be disabled simultaneously.

## Link Buffer (DXB \_Buffer):

The link buffer is the Ext\_User\_Prm buffer that was received and checked by the user. One to eight entries can be made in this buffer. The buffer end is defined based on an 'End Character = FFh'. When a DXB response frame is received, the MAC makes this frame plausible with the link entries. In so doing, the received DA and SA addresses are compared to the corresponding entries. In addition, the received net data length must correspond to the value assigned in 'DXB\_Data length'. Because each DP master can also be a DP slave, the frame type (Request or Response) must also still be made plausible. If the received frame is now plausible with a link entry, the preset data area (tap), which is specified by two offset pointers (start: Off\_Data\_Start, End: Off\_Data\_End), is tapped and placed in the appropriate D buffer. Three alternating buffers apiece are available for each configured link. Of these, the D buffer is integrated in the DXB\_SCB as a DXBn\_D-buffer.



Figure 5.2-7: Programming of 'Off\_Data\_Start' and 'Off\_Data\_End'

|        | Entries             | Coding                                      | Comments                                                    |
|--------|---------------------|---------------------------------------------|-------------------------------------------------------------|
| Cntl   | Header (6 Bytes)    |                                             | see Section 5.1                                             |
| Link0: | Destination Address | 01111111b                                   | Compared to the received DA                                 |
|        | Source Address      | 0xxxxxxb                                    | Compared to the received SA                                 |
|        | DXB_Data Length     | xxxxxxxb                                    | Must correspond to the net data length of the tapped frame! |
|        | Check byte          | 00000000b (Response)<br>01000000b (Request) | Compared to the masked frame type bit of the received FC    |
|        | Off_Data_Start      | xxxxxxxb                                    | Points to the first byte that is to be tapped               |
|        | Off_Data_End        | xxxxxxxb                                    | Points to the last byte that is to be tapped                |
|        |                     |                                             |                                                             |
| Link7: | Destination Address | 01111111b                                   |                                                             |
|        | Source Address      | 0xxxxxxb                                    |                                                             |
|        | DXB_Data Length     | xxxxxxxb                                    |                                                             |
|        | Check byte          | 0000000b (Response)                         |                                                             |
|        |                     | 0100000b (Request)                          |                                                             |
|        | Off_Data_Start      | xxxxxxxb                                    |                                                             |
|        | Off_Data_End        | xxxxxxxb                                    |                                                             |

| End     | End Character           | 11111111b | End coding of link buffer |
|---------|-------------------------|-----------|---------------------------|
| Table 5 | .2-9: Structure of Linl | < Buffer  |                           |

User New DXB0-7 Cmd (Read Operation):

| 0 | 0 | 0 | 0 | 0 | U_Buffer_State | U_Buffer <sub>1</sub> | U_Buffer <sub>0</sub> |
|---|---|---|---|---|----------------|-----------------------|-----------------------|
|   |   |   |   |   |                |                       |                       |

U\_Buffer\_State =  $0 \Rightarrow$  No new U\_Buffer\_U\_Buffer\_1..0 =  $00 \Rightarrow$  Buffer1 U Buffer State =  $1 \Rightarrow \text{New U}$  Buffer  $U_Buffer_{1..0} = 01 \Rightarrow Buffer_2$ U\_Buffer<sub>1..0</sub> = 10  $\Rightarrow$  Buffer3

Table 5.2-10: Coding of User New DXB-Cmd

## **Timeout Monitoring of DXB Connections:**

For timeout monitoring of the DXB connections, the watchdog must be operated in 'DP\_Control' state. For this purpose, the master must transfer a valid watchdog value with 'WD\_On=1' in the Set Param frame.

All configured links must have sent data at least once in a watchdog cycle. The links are hereby registered in a 'Score Actual Register'. When DXB mode is disconnected, DPS deletes this Score\_Actual\_Register. Each signaled link is arranged in the appropriate bit position in the Score Actual Register (Bit 0 to 7) with a "log. 1" according to its entry (0 to 7) in the link buffer. If the watchdog has reached its parameterized value, DPS compares the Score Actual Register to the 'Score\_Register', which contains the received links of the last turn. If no difference is detected, all of the links arrive and the Score\_Actual\_ Register is deleted for the next pass.

If a difference is detected, DPS transfers the Score Actual Register to the Score Register, then deletes the Score Actual Register, and generates the 'DXB Error-Interrupt'. As a result, the user receives information on failed or returned links in the new Score Register. This state is now taken as the basis for the subsequent watchdog cycle. If, for example, a failed link comes up again, a difference between the Score\_Actual\_Register and the Score\_Register arises again at the end of the cycle, and the 'DXB Error' interrupt is generated again.

If the user preassigns the Score\_Register with configured DXB connections for each disconnection of DXB mode, monitoring for 'failed links' starts. When '00h' is preassigned, all received links are first registered one time in the Score-Register following a turn, and consulted as monitoring for the next turn.

## 5.3 Additional FDL Functions

## 5.3.1 FDL Monitoring Timer

For monitoring a connection, a 16-bit monitoring timer (FDL Timer Count-H/L) is available for each FDL\_SAP. This timer is operated with a cycle clock of 10 ms (1 ms for WD\_Test=1). This enables implementation of monitoring times up to 655 sec. Each timer can be individually controlled via the FDL Timer control.

Table 5.3-1 gives the assignment FDL\_Timer control. With 'Timer\_Enable=1', the FDL\_Timer is enabled. After each elapsed time interval (10 ms), the timer (FDL\_ Timer\_Count H/L) is decremented. If it reaches a value of '0000h', the reaction assigned in 'Timer Action<sub>10</sub>' is executed and the timer is disabled. The following reactions are defined:

- No reaction
- Lock SAP 'req\_sa = 7Fh'
- Remove access protection 'req\_sa = FFh (all)'

| Timer_State <sub>3</sub> | Timer_State <sub>2</sub> | Timer_State₁ | Timer_State₀ | 0 | Timer_Action <sub>1</sub> | Timer_Action <sub>0</sub> | Timer_Enable |
|--------------------------|--------------------------|--------------|--------------|---|---------------------------|---------------------------|--------------|
| 7                        |                          |              |              |   |                           |                           | 0            |

Timer\_State<sub>3..0</sub> = User defined

Timer\_Action<sub>1..0</sub> =  $00 \Rightarrow$  nothing

Version V2.1

 $\begin{array}{l} Timer\_Action_{1..0}=01 \Rightarrow req\_sa=`7Fh \quad `Timer\_Enable=1 \Rightarrow enable\\ Timer\_Action_{1..0}=10 \Rightarrow req\_sa=`FFh'\\ Timer\_Action_{1..0}=11 \Rightarrow Reserved \end{array}$ 

Table 5.3-1: Assignment of FDL\_Timer Control

In addition, when an FDL\_Timer elapses, an entry is made in the Indication queue. The SAP\_No. in which the FDL\_Timer elapses and the FDL\_Timer control is thereby transferred to the user. The user recognizes the state of the connection monitoring in which the FDL\_Timer elapses via the 'Timer\_State<sub>1.0</sub>' (user defined, not modified by DPC31).

The FDL\_Timer can be started, stopped, or reloaded on a sap-specific basis using the request 'FDL\_Timer\_Change'. The new 'FDL\_Timer Control' and the Reload value 'FDL\_Timer\_Count-H/L' is always transferred with this request.

The FDL\_Timebase Timer is an internal free-running counter that generates an interrupt after every time interval (10 ms). All FDL-SAPs are then scanned and the enabled FDL\_Monitoring timer is decremented. **Only SAPs 0 - 54d are considered.** 

# 5.3.2 Time of Day Synchronization

Figure 5.3-1 presents the main sequence. However, this service is only enabled with 'En\_Clock\_Sync=1' in the Param Register. Otherwise, the SM\_Time0/1 frames are filtered by the MAC.





A time of day master first sends the SM2\_Time0 frame (broadcast, FC=40h). If the SM\_Time-SAP is enabled in the SAP\_SCB, the delay timer is reloaded and started in the DPC31 directly after the receipt of SM2\_Time0<sup>4</sup>, and the receipt is indexed. In addition, the MAC saves the Remote-Adr of this Time of Day\_Master. With the SM2\_Time1 frame (Broadcast, FC=C0h), the Time of Day\_Master now communicates the time at which it sent the SM2\_Time0 frame (time of send completion) and, thus, the time at which the DPC31 started its delay timer. Upon receipt, the MAC checks to determine whether SM2\_Time1 has come from the same Time of Day\_Master as SM2\_Time0. If so, the MAC enters this Indication in the Indication queue and goes to 'Wait\_New\_Enable' state. Otherwise, this frame is ignored.

<sup>&</sup>lt;sup>4</sup> max. 280ns nach ED-Ende

If the user now processes the indication, he must stop and read out the delay timer (see Mode Register1). The real time of day is now calculated by adding the received time of day to the value in the delay timer. Then, the user must enable another time of day synchronization. For this purpose, the command 'En\_New\_SM\_Time-Sync' must be transferred via the request interface.

The delay timer is a 16-bit timer with a resolution of  $1\mu s$ . This enables implementation of a time of 65.5 ms. If an overflow occurs, the 'Delay\_Timer-Overrun' interrupt is generated and the timer starts over.

If the MAC receives another SM2\_Time0 frame from the same time of day master, a fault occurs. For example, it is possible that the SM2\_Time1 frame has been lost due to a bus malfunction. The 'Ignore\_Delay\_Timer\_ Overrun' interrupt is thereby generated to the user. The user must then stop the delay timer and enable a new synchronization with the 'En\_New\_SM\_Time-Sync' request.

# 5.3.2.1 Support of MSACS1 SAPs

To support Master Slave Acyclic Class 1, opening and closing of SAPs 50, 51, and 52d can be coupled to the cyclic machine. To do so, the user must set Bit 'Check\_DPV1\_Enable=1' in the Param Register. If the DPC31 is now assigned in DPV1 mode (DPV1-Enable=1 in the Set\_Param frame, DPV1\_Status\_1, Bit 7) and this frame contains at least 10 data bytes, DPS opens these SAPs for the DP master (Master\_Add) upon entrance in 'Data\_Exchange'. No message is sent to the user. When the 'Data\_Ex' state is left, these SAPs are again locked and any buffered Indications are deleted (Buffer\_In\_Use=0). However, the buffer control (Buffer\_State, Response in Buffer\_Control Byte) is not changed. In addition, an Indication is made to the user, 'Stop\_C1-Ind' in the Indication\_Queue. The user must then readjust the buffers of SAPs 50-52 and confirm this to the DPC31. 'Stop\_C1-Con' in the Instruction\_Queue. Return to 'Data\_Ex' is only possible after this confirmation!

If the acyclic machine does not require all of the SAPs (50-52), the user must lock them in the SAP\_List (SAPx\_Ptr=FFh). This means they will not be controlled by the DPC31 either.!

'Check\_En\_Prm\_Cmd=1' in the Param Register enables the check of 'Enable\_Prm\_Cmd' in the Set\_Prm frame (DPV1\_Status\_3, Bit 7). However, this only occurs in the 'Data\_Ex' state and 'Operation-Mode=V1' when a new Prm frame (V1) is received from the same master. If 'Enable\_Prm\_Cmd=1', DPS remains in the 'Data\_Ex' state. When 'Enable\_Prm\_Cmd=0' a Leave\_Master is executed.

# 6 User Functions on the C31 Controller

The DPC31 contains an integrated C31 core that is available entirely for user functions. One of the two external interrupts (XINT0) is already being used for interfacing the communication component and is therefore no longer available to the application.

# 7 Description of the Hardware Blocks

## 7.1 Universal Processor Interface

The DPC31 has a parallel 8-bit interface with a 13-bit address bus. It supports all 8-bit processors and micro-controllers as follows: 80C31/32 by Intel and the Motorola HC11 family. It also supports the 8/16 bit processors and micro-controllers of the 80C166 family by Siemens, X86 by Intel and the HC16/HC916 family by Motorola.

In addition, a clock pulse scaler is integrated which makes the internal work clock pulse (divided by 2 (pin CLKOUT1X2) or 4 (pin CLKOUT1X4) available as system clocks in order to be able to connect a slower controller without additional effort in a lowcost application (refer to Chapter 7.8.1). Both clock outputs can be switched off separately via Mode Register1. For asynchronous physics, the DPC31 is wired to a quartz of 12MHz (XTAL1\_CLK, XTAL2). An integrated PLL generates the internally needed work clock pulse (48MHz: refer to Chapter 7.8.1). In the case of synchronous physics, the DPC31 can be operated in a mode that is particularly low in power loss. This can be achieved only

for low clock pulse rates. The PLL is switched off in this case (XPLLEN = VDD) and the variable supply clock pulse of (2), 4, 8, or 16 MHz is applied directly to XTAL1\_CLK.

# 7.1.1 Bus Interface Unit (BIU)

The BIU is the interface to the connected processor/microcontroller. It allows the CPU accesses to the internal 5.5kByte dual port RAM and the registers. It is a synchronous or asynchronous 8-Bit interface with a 13-Bit address bus. The interface can be configured via 3 bus type pins (BusType2..0) (refer to Table 7.1-1). With it, the connected processor family (Intel/Motorola bus control signals such as XWR,XRD, and R\_W, the – data format) and the synchronous (rigid) or asynchronous bus timing is specified.

Figure 7.1-1, Figure 7.1-2, Figure 7.1-3, and Figure 7.1-4 show different Intel and Motorola system configurations. In the C31 mode, the internal address latch and the integrated decoder must be used. In Figure 7.1-1, the minimum configuration of a system with external  $\mu$ P and DPC31 is shown; the chip is connected to an EPROM version of the controller. In terms of additional components, only a quartz crystal is needed in this configuration. If a controller is to be used without integrated program memory, the addresses have to be latched additionally for the external memory (refer to Figure 7.1-2). The connection diagram in Figure 7.1-3 applies to all Intel/Siemens processors that offer asynchronous bus timing and interpret the Ready signal.

## Notes:

If the **DPC31 is connected to an 80286** or something similar, it is to be taken into account that the processor accesses words; that is, either a swapper is needed that switches, during reading, the corresponding characters from the DPC31 to the corresponding byte position of the 16-Bit data bus. Otherwise the least significant address bit is not connected and the 80286 must make word accesses and correspondingly only interpret the lower byte as shown in Figure 7.1-3.

## Wiring of the C31-Core Port-Pins for Unused C31-Core:

Set the pin DBX to VDD, then the internal C31 is in permanent reset. Ports A, B, C and D except for port D(2) must each be wired with a pull-up resistor.

| BusType <sub>20</sub>               | The DPC31 Processor Interface supports the following micro-controllers:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 1 1<br>(synchronous<br>Motorola)  | <ul> <li>MOTOROLA micro-controller with the following features: <ul> <li>Synchronous (rigid) bus; timing without evaluation of XDSACK (PH<sub>2</sub>)</li> <li>8-Bit non-multiplexed bus: DB<sub>7-0</sub> (PE<sub>7.0</sub>), AB<sub>12-0</sub> (PG<sub>4.0</sub>, PF<sub>7.0</sub>)</li> </ul> </li> <li>The following can be connected : <ul> <li>HC11- types: K, N, M and F1</li> <li>HC16- and HC916- types with programmable ECLK timing</li> <li>For all other HC11-types with a multiplexed bus, the addresses AB<sub>7-0</sub> have to be selected externally from the data DB<sub>7-0</sub>.</li> </ul> </li> <li>Address decoder is switched off in the DPC31; CS-signal is supplied from the outside: <ul> <li>For micro-controllers with chip select logic: K, F1, HC16, HC916, the chip selection signals can be programmed regarding the address area, priority, polarity, and the window width in the write and read cycle.</li> <li>For micro-controllers without chip selection logic: N, M and others, an external chip select logic is needed. This means additional HW effort and fixed assignments.</li> </ul> </li> <li>Condition: <ul> <li>The DPC31 output clock (CLKOUT1X2/4) has to be at least four times larger than the E Clock. The DPC31 clock (48MHz) has to be at least ten times larger than the desired system clock (E Clock). Pin CLKOUT1X4 is to be wired with this (E_Clock = 3MHz at 48MHz DPC31 clock).</li> </ul> </li> </ul> |
| 0 1 0<br>(asynchronous<br>Motorola) | <ul> <li>MOTOROLA micro-controller with the following features:</li> <li>Asynchronous bus; timing with evaluation of XDSACK (PH<sub>2</sub>)</li> <li>8-Bit non-multiplexed bus: DB<sub>7-0</sub> (PE<sub>7.0</sub>); AB<sub>12-0</sub> (PG<sub>4.0</sub>, PF<sub>7.0</sub>)</li> <li>The following can be connected:</li> <li>HC16 and HC916 types</li> <li>Address decoder in the DPC31 is switched off; CS signal is applied from the outside</li> <li>Chip-select signals are present in all micro-controllers and can be programmed.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0 0 1<br>(synchronous<br>Intel)     | <ul> <li>INTEL, CPU Basis 80C31/32, micro-controllers of various manufacturers:</li> <li>Synchronous (rigid) bus timing without XRDY (PH<sub>2</sub>) evaluation</li> <li>8-Bit multiplexed bus ADB<sub>7-0</sub> (PE<sub>70</sub>),</li> <li>The following can be connected:</li> <li>Micro-controller families, such as INTEL, SIEMENS, PHILIPS</li> <li>Address decoder is switched on in the DPC31; CS signal is generated internally:</li> <li>The lower address bits AB<sub>7-0</sub> are stored with the ALE signal in an internal address latch. In the DPC31, the internal CS decoder is activated that generates its own signal from the addresses AB<sub>12-0</sub>.</li> <li>The integrated address decoder is permanently wired, so that the DPC31 Always has to be addressed under the fixed addresses AB<sub>70</sub>=000xxxxb, Whereby the DPC31 selects the corresponding address window from the Signals AB<sub>4-0</sub>.</li> <li>In this mode, the CS pin (PG<sub>6</sub>) has to be on VDD (high potential)</li> <li>Wiring: refer to Figure 7.1-1, Figure 7.1-2. Apply ADB<sub>7-0</sub> to DPC31-Pin PE<sub>70</sub>, AB<sub>15-8</sub> to DPC31-Pin PF<sub>70</sub>, and the DPC31-Pin PG<sub>40</sub> to VSS.</li> </ul>                                                                                                                                                                                                                        |
| 0 0 0<br>(asynchronous<br>Intel)    | INTEL and SIEMENS 16/8-Bit micro-controller families<br>- Asynchronous bus; timing with evaluation of XRDY (PH <sub>2</sub> )<br>- 8-Bit non-multiplexed bus: DB <sub>7</sub> -0 (PE <sub>7.0</sub> ); AB <sub>12</sub> -0 (PG <sub>4.0</sub> , PF <sub>7.0</sub> )<br>The following can be connected:<br>- Micro-controller families; for example, SIEMENS, 80C16x and INTEL X86<br>Address decoder in DPC31 is switched off; CS signal is applied from the outside<br>- External address decoding is always required<br>- External chip selection logic, if not available in micro-controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

 Table 7.1-1
 The Different Configurations of the Processor Interface



Figure 7.1-1: Low Cost System (C31 Mode)



Figure 7.1-2: C31 System with External Memory (C31 Mode)

# ComDeC

DPC31 HW

# SIEMENS



Figure 7.1-3: 80286 System as an Example for Mode X86







Figure 7.1-5: M68HC16 System as an Example for Asynchronous Motorola Mode

# 7.1.2 IO Interface

If the DPC31 is to be operated without external processor, an I/O interface is available instead of the processor interface (can be set via the bus type pins). This I/O interface consiDXB of four ports ( $PE_{7..0}$ ,  $PF_{7..0}$ ,  $PG_{7..0}$ ,  $PH_{2..0}$ ). Each port bit can be configured as input or output by the internal application (C31). The outputs can be addressed bit by bit as well as byte by byte. Reading is always byte by byte. To configure the I/O bits, each port has a Direction Register (Dir\_Reg). The output status is kept in a register bit (refer to Table 7.1-2). After reset, all ports are switched to input. The addressing of these I/O ports is provided in Chapter 7.3.2.

| BusType <sub>2.0</sub>      | PH <sub>20</sub>                                                                                                                                                                                 | PG <sub>70</sub>                                                                                                                                                                                                                                                                                                                                                                   | PF <sub>70</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PE <sub>70</sub>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 A<br>A<br>(I/O Interface) | Dir_Reg_H <sub>2.0</sub><br>0=Out;1=In)<br>Addresses:<br>Adr_H <sub>2.0</sub> =ByteAddress<br>Adr_H <sub>0</sub> =BitAddress<br>Adr_H <sub>1</sub> =BitAddress<br>Adr_H <sub>2</sub> =BitAddress | $\begin{array}{l} \mbox{Dir_Reg_G_{70}} \\ (0=Out;1=In) \\ \mbox{Addresses:} \\ \mbox{Adr_G_{70}=ByteAddress} \\ \mbox{Adr_G_{0}=BitAddress} \\ \mbox{Adr_G_{1}=BitAddress} \\ \mbox{Adr_G_{2}=BitAddress} \\ \mbox{Adr_G_{3}=BitAddress} \\ \mbox{Adr_G_{4}=BitAddress} \\ \mbox{Adr_G_{6}=BitAddress} \\ \mbox{Adr_G_{6}=BitAddress} \\ \mbox{Adr_G_{6}=BitAddress} \end{array}$ | $\begin{array}{l} \label{eq:constraints} \textbf{Dir_Reg_F_{70}} \\ (0=Out;1=In) \\ \textbf{Addresses:} \\ Adr_{70}=ByteAddress \\ Adr_{F_0}=BitAddress \\ Adr_{F_1}=BitAddress \\ Adr_{F_2}=BitAddress \\ Adr_{F_3}=BitAddress \\ Adr_{F_3}=BitAddress \\ Adr_{F_6}=BitAddress \\ Adr_{F_6}=BitAddres \\ Adr$ | $\begin{array}{l} \label{eq:bigger} \text{Dir_Reg_E}_{70} \\ (0=Out;1=In) \\ \text{Addresses:} \\ \text{Adr_E}_{70}=ByteAddress \\ \text{Adr_E}_{0}=BitAddress \\ \text{Adr_E}_{1}=BitAddress \\ \text{Adr_E}_{2}=BitAddress \\ \text{Adr_E}_{3}=BitAddress \\ \text{Adr_E}_{3}=BitAddress \\ \text{Adr_E}_{5}=BitAddress \\ \text{Adr_E}_{6}=BitAddress \\ \text{Adr_E}_{6}=BitAddress \\ \text{Adr_E}_{6}=BitAddress \\ \end{array}$ |

Table 7.1-2: IO Interface on the Processor Interface

| Pin Name             |                                        |                   | Signa             | l Names            |         |                  | Comment |                                             |
|----------------------|----------------------------------------|-------------------|-------------------|--------------------|---------|------------------|---------|---------------------------------------------|
|                      | μP Interface                           |                   |                   |                    |         | IO Inter         | face    |                                             |
|                      | Intel<br>sync.                         | Intel<br>async.   | Motorol.<br>sync. | Motorol.<br>async. |         | -                |         |                                             |
| PE <sub>70</sub>     | DB <sub>70</sub> /<br>AB <sub>70</sub> | DB <sub>70</sub>  | DB <sub>70</sub>  | DB <sub>70</sub>   | l/<br>O | PE <sub>70</sub> | I/O     | high-resistance at reset                    |
| PF <sub>70</sub>     | AB <sub>158</sub>                      | AB <sub>81</sub>  | AB <sub>70</sub>  | AB <sub>70</sub>   | I       | PF <sub>70</sub> | I/O     |                                             |
| PG <sub>40</sub>     | GND                                    | AB <sub>139</sub> | AB <sub>128</sub> | AB <sub>128</sub>  | I       | PG <sub>40</sub> | I/O     |                                             |
| PG₅                  | X/INT                                  | X/INT             | X/INT             | X/INT              | 0       | PG₅              | I/O     | Interrupt, polarity can be<br>parameterized |
| $PG_6$               | V <sub>DD</sub>                        | XCS               | XCS               | XCS                | I       | $PG_6$           | I/O     | Chip-select                                 |
| PG <sub>7</sub>      | XWR                                    | XWR               | E-Clock           | GND                | I       | PG <sub>7</sub>  | I/O     | Intel: Write / Motorola: E-Clock            |
| PH₀                  | XRD                                    | XRD               | R_W               | R_W                | I       | $PH_0$           | I/O     | Intel: Read / Motorola:<br>Read/Write       |
| PH₁                  | ALE                                    | $V_{DD}$          | $V_{DD}$          | AS                 | I       | PH₁              | I/O     | Address Latch Enable                        |
| PH <sub>2</sub>      | -                                      | XRDY              | -                 | XDSACK             | 0       | PH <sub>2</sub>  | I/O     | Ready Signal                                |
| BUSTYP <sub>20</sub> | "001"                                  | "000"             | "011"             | "010"              | I       | "1 "             | 1       | Setting of the interface                    |
| RESET                | RESET                                  | RESET             | RESET             | RESET              |         | RESET            | 1       | Reset input                                 |

# 7.1.3 Interface Signals

**Table 7.1-3:** Interface Signals for  $\mu P$  and IO Interface

The data bus outputs are high-resistance during the reset phase. In the test mode, all outputs are switched to high resistance.

## 7.1.4 Interrupt Controller of the $\mu$ P Interface in the DPC31

Via the interrupt controller, the processor is informed of various events. These consist primarily of indication messages and different error events. The controller has no prioritization level and does not provide an interrupt vector (not compatible with 8259A).

It consiDXB of the following: an interrupt request register (IRR), interrupt mask register (IMR), interrupt register (IR) and an interrupt acknowledge register (IAR). The structure is shown in Figure 7.1-6.

In the IRR, every event is stored. Via the IMR, individual events can be suppressed. If, for example, the DPS indications are evaluated only by the internal C31, the corresponding masks have to be set here and enabled for the C31 in the interrupt controller. The entry in the IRR is independent of the interrupt mask. Events that are not masked out in the IMR generate the **X/INT Interrupt** (Pin PG<sub>5</sub>) via a cumulative network.

For debugging, the user can set every event in the IRR (only those bits are activated that are to be set).

Each interrupt event that was processed by the processor has to be cleared via the IAR (except for New\_Prm\_Data, New\_DDB\_Prm\_Data, New\_Cfg\_Data). A log '1' is to be written to the corresponding bit position. If a new event and an acknowledgement of the previous event are pending at the same time at the IRR, the event remains stored. If the processor subsequently enables a mask, it has to be ensured that there is no past entry in the IRR. To make sure, the position must be cleared in the IRR prior to the mask enable.

Prior to exiting the interrupt routine, the processor has to set the "End of Interrupt Signal (EOI) = 1" in the EOI register (see below). With this edge change, the interrupt line is switched

inactive. If an event should still be stored, the interrupt output becomes active again only after an interrupt inactive time of at least 1µs or 1ms, or at most 2µs or 2ms (refer to Chapter 9.6.2.2). Via 'EOI\_Timebase' (Param Register, refer to Chapter 3.3), this interrupt inactive time can be set (EOI\_Timebase=0 -> 1µs; EOI\_Timebase=1 -> 1ms). This makes it possible to reenter the interrupt routine when using an edge-triggered interrupt input.



## Figure 7.1-6: Interrupt Controller of the µP Interface and C31 Core in the DPC31

The polarity of the interrupt input can be parameterized (Mode Register1; refer to Chapter 3.3: INT\_Pol). After the HW reset, the output is low-active.

#### Interrupt Request Register, IRR (writable, readable):

| New_GC_  | Go/Leave_ | IndQ_Full | IndQ_Entry | Ignore_Del_ | Delay_Time | Diag_    | WD_State_ |
|----------|-----------|-----------|------------|-------------|------------|----------|-----------|
| Command  | Data_     |           |            | Timer_Overr | r_Overrun  | Fetched  | Changed   |
|          | Exchange  |           |            | un          |            |          |           |
| 7        |           |           |            |             |            |          | 0         |
|          |           |           |            |             |            |          |           |
| DX_OUT_  | DX_OUT    | Diag_     | Get_Cfg_   | New_Cfg_    | New_DDB_   | New_Prm_ | New_SSA   |
| Overflow |           | Buffer_   | Buffer_    | Data        | Prm_Data   | Data     | _Data     |
|          |           | Changed   | Changed    |             |            |          |           |
| 15       |           |           |            |             |            |          | 8         |
|          |           |           |            |             |            |          |           |
| DXB7_OUT | DXB6_OUT  | DXB5_OUT  | DXB4_OUT   | DXB3_OUT    | DXB4_OUT   | DXB1_OUT | DXB0_OUT  |
| 23       |           |           |            |             |            |          | 16        |
|          |           |           |            |             |            |          |           |

ComDeC

DPC31 HW



| 0  | 0 | DX-Entered | GC_Clock | 0 | SSC_<br>Interface | RAM_<br>Access_<br>Violation | DXB_Error |  |
|----|---|------------|----------|---|-------------------|------------------------------|-----------|--|
| 28 |   |            |          |   |                   |                              |           |  |

24

| WD_State_Changed:        | The state of the WD_SM has changed (change between<br>'Baud_Search, 'Baud_Control' or 'DP_Control'.                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Diag_Fetched:            | The master fetched the diagnostic buffer                                                                                                                                             |
| Delay_Timer Overrun      | The delay timer has expired and has been started over                                                                                                                                |
| Ignore_Del_Timer Overrun | The time of day synchronization has been aborted. External Del_Timer_Overrun Timer must be deleted.                                                                                  |
| IndQ_Entry:              | An entry was made in the indication queue                                                                                                                                            |
| IndQ_Full:               | The Indication_Queue is full. The pending indication could not be<br>transferred                                                                                                     |
| Go/Leave_Data_Exchange:  | DPS has entered the 'Data_Exchange' mode or has exited it                                                                                                                            |
| New_GC_Command:          | DPS has received a Global_Control message with a modified<br>'GC_Command byte' (New_GC_Int_Mode=0) and has stored this<br>byte in the RAM cell 'GC_Command'. If 'New_GC_Int_Mode=1', |
|                          | this interrupt is set for every received Global_Control message.                                                                                                                     |
| New_SSA_Data:            | DPS has received a 'Set_Slave_Address message' and has made the data available in the User_SSA buffer.                                                                               |
| New_Prm_Data:            | DPS has received a 'Set_Param message' and has made the data available in the User_Prm buffer.                                                                                       |
| New_DDB_Prm_Data         | DPS has received a 'Set_DDB_Param Frame' and provided the data in the User_DDB_Prm Buffer.                                                                                           |
| New_Cfg_Data:            | DPS has received a 'Check_Cfg message' and has made the data                                                                                                                         |
|                          | available in the User_Cfg buffer.                                                                                                                                                    |
| Get_Cfg_Buffer_Changed:  | Upon request by 'User_New_Get_Cfg_Buf', DPS has exchanged the Get_Config buffers and has made the old buffer available                                                               |
|                          | again to the user.                                                                                                                                                                   |
| Diag_Buffer_Changed:     | Upon request by "User_New_Diag_Buf', DPS has exchanged the                                                                                                                           |
| 0 0                      | diagnostic buffers and has made the old buffer available again to the user.                                                                                                          |
| DX_OUT:                  | DPS has received a 'Write_Read_Data/GC message' and made                                                                                                                             |
|                          | the new output data available in the N buffer. In the case of                                                                                                                        |
|                          | 'Power_On', 'Clear', or 'Leave_Master', the DPS_SM makes a cleared C buffer available and generates this interrupt also. By                                                          |
|                          | parameterizing 'Enable DX_Out_Port=1' in the C31_Control                                                                                                                             |
|                          | register, the interrupt 'DX_OUT' can be applied directly to Port                                                                                                                     |
|                          | PB3.                                                                                                                                                                                 |
| DX_OUT_Overflow:         | DPS has received a 'Write_Read_Data/GC message' and has                                                                                                                              |
|                          | made the new output data available in the N buffer. However, the old data wasn't fetched and is no longer available. In the sync                                                     |
|                          | mode, the frozen output data in the D buffer was overwritten                                                                                                                         |
|                          | because there was no GC message.                                                                                                                                                     |
| DXB0-7_OUT:              | DPS has tapped data from a configured connection and provided                                                                                                                        |
|                          | the new output data in the N buffer in the appropriate                                                                                                                               |
|                          | DXB_Buffer_SM0-7.                                                                                                                                                                    |
| DXB_Error:               | During the last watchdog cycle, at least one connection failed or was returned.                                                                                                      |
| RAM_Access_Violation:    | The memory was accessed outside the communication memory.                                                                                                                            |
| SSC_Interface:           | The SSC interface generated an interrupt.                                                                                                                                            |
| GC_Clock                 | The Sync_Clock (clock pulse beater) has been triggered at Port                                                                                                                       |
| DV Entered               | PB <sub>2</sub><br>Compare offer the transition to Date Evenence synchronously with                                                                                                  |
| DX-Entered               | Comes after the transition to Data-Exchange synchronously with the first DX_OUT interrupt in which diagnostics are not pending                                                       |
|                          |                                                                                                                                                                                      |

After reset, the IR is cleared.

# SIEMENS

## Interrupt Register, IR (readable only):

For bit assignment, refer to Interrupt Request Register.

**Interrupt Mask Register, IMR (writable, can be changed during operation):** For bit assignment, refer to Interrupt Request Register.

Bit = 1: Mask is set and the interrupt is disabled Bit = 0: Mask is cleared and the interrupt is enabled.

After reset, all bits are set.

**Interrupt Acknowledge Register, IAR ( writable, can be changed during operation):** For bit assignment, refer to Interrupt Request Register.

Bit = 1: The IRR bit is cleared.

Bit = 0: The IRR bit remains unchanged.

After reset, all bits are cleared.

## Interrupt EOI Register, EOI (writable, can be changed during operation)

EOI is triggered based on the write operation to the register cell 'Interrupt EOI Register'. The write data is don't care.

## 7.2 Synchronous Serial Interface (SSC Interface)

In the DPC31, a universal synchronous serial interface is integrated. In addition, several SPI slave blocks (ser. E<sup>2</sup>PROMs or AD transformers) can be connected to this interface (Figure 7.2-1). This SSC interface has full duplex capability, and only supports the master mode.



#### Figure 7.2-1: SPI Interface at the DPC31

To connect **SPI devices** (ser. E<sup>2</sup>PROM, AD transformer), an output port is needed per SPI device, in addition to the SSC channel, in order to generate the chip select signal.

#### **Description of the SSC Module:**

The SSC module consiDXB of a transmit channel and a receive channel. Each channel contains a 9bit shift register, and an 8-bit buffer. Character widths of 1 to 8-bit are supported.

The user operates the transmit buffer. If the transmit buffer is empty, the transmitter generates the Transmit Buffer Empty which can be polled via the status register, or which, with a corresponding enable in the Interrupt Enable Register, activates the SSC interrupt. After loading the transmit buffer, Transmit Buffer Empty enters inactive. As soon as the transmit shift register is free, the data byte is

transferred there and shifted out. The clock (SSCLK) is generated only as long as the shift process is running. During continuous sending, the user always writes the next data byte to the transmit buffer while one is being shifted out.

In the receiver, the arriving bits are shifted to the Receiver Shift Register. After 8 data bits have been received, or 9 bits with enabled parity, this data byte is accepted in the receive buffer and Receive Buffer Full is generated. This state can be polled via the status register or it can be activated as SSC \_Interface interrupt if there is a corresponding enable in the Interrupt Enable Register.

If there is continuous receiving, the user reads a data byte from the receive buffer while the next one is arriving at the receiver shift register. Error states (Receive Buffer Overflow, RECERR; or Parity Error, PERR) can be polled in the status register or can be generated as SSC\_Interface interrupt (enable in the Interrupt Enable Register).

Because of the full duplex channel in the SSC module, it can receive while it is sending. However, the protocols process only half-duplex (SPI E<sup>2</sup>PROM, etc.). For that reason, the received data is to be ignored (disable the corresponding interrupts). The last received data byte is always in the receive buffer. To receive user data, dummy data bytes have to be sent so that the SSC module generates a clock pulse.

## Register Assignment of the SSC Module:

The user (external  $\mu$ P or C31) addresses the SSC module in the address range from 0020h to 0025h. It can be polled or operated with interrupt output. The interrupt runs to the two interrupt controllers (refer to Chapter 7.1.4).

## Control1 Register:

| CPHA<br>1<br>rw |
|-----------------|
| •               |
| rw              |
|                 |
| the             |
|                 |
| (               |
|                 |
| edge.           |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
|                 |
| nber of         |
| ineven          |
| 1               |

# SIEMENS

BREN:

#### Baud rate Enable Bit

- =0 Baud rate generator is disabled (power save).
- =1 Baud rate generator is enabled.

## Control2 Register:

| Bit Position | on 7                                                                                                                                                                                                                                                                | 6                                                                                                         | 5                                                                                            | 4                                            | 3 | 2      | 1               | 0               |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------|---|--------|-----------------|-----------------|
|              | -                                                                                                                                                                                                                                                                   | -                                                                                                         | -                                                                                            | -                                            | - | $DW_2$ | DW <sub>1</sub> | DW <sub>0</sub> |
| Default      | 0                                                                                                                                                                                                                                                                   | 0                                                                                                         | 0                                                                                            | 0                                            | 0 | 0      | 0               | 0               |
|              | r                                                                                                                                                                                                                                                                   | r                                                                                                         | r                                                                                            | r                                            | r | r/w    | r/w             | r/w             |
|              | 001:         Transf           010:         Transf           011:         Transf           100:         Transf           101:         Transf           101:         Transf           101:         Transf           101:         Transf           110:         Transf | lection<br>er data wi<br>er data wi<br>er data wi<br>er data wi<br>er data wi<br>er data wi<br>er data wi | th 1 bit ler<br>th 2 bit ler<br>th 3 bit ler<br>th 4 bit ler<br>th 5 bit ler<br>th 6 bit ler | ngth<br>ngth<br>ngth<br>ngth<br>ngth<br>ngth |   |        |                 |                 |

#### **Status Register:**

| Bit F   | Position           | 7                                                             | 6                                      | 5    | 4 | 3           | 2    | 1    | 0    |  |
|---------|--------------------|---------------------------------------------------------------|----------------------------------------|------|---|-------------|------|------|------|--|
|         |                    | BUSY                                                          | -                                      | -    | - | REC-<br>ERR | PERR | RBFU | TBEM |  |
| Defa    | ault               | 0                                                             | 0                                      | 0    | 0 | 0           | 0    | 0    | 1    |  |
|         |                    | r                                                             | r                                      | r    | r | r/w         | r/w  | r    | r    |  |
| TBEM:   | Trans<br>=0<br>=1  |                                                               | Empty Fl<br>buffer is f<br>buffer is e | ull. |   |             |      |      |      |  |
| RBFU:   | Rece<br>=0<br>=1   | Receive Buffer Full Flag<br>=0 Receive buffer is empty.       |                                        |      |   |             |      |      |      |  |
| PERR:   | Parity<br>=0<br>=1 | Parity Error Flag<br>=0 No parity error in data byte.         |                                        |      |   |             |      |      |      |  |
| RECERR: | Rece<br>=0<br>=1   | Receive Error Flag<br>=0 No receive buffer overflow.          |                                        |      |   |             |      |      |      |  |
| BUSY:   | Busy<br>=0<br>=1   | Busy Flag<br>=0 No action; SSC module can be reparameterized. |                                        |      |   |             |      |      |      |  |

These bits are ORed to the interrupt 'SSC\_Interface'. They must have been enabled in the Interrupt Enable Register.

#### Interrupt Enable Register:

| Bit Position | 7 | 6 | 5 | 4 | 3      | 2    | 1    | 0    |
|--------------|---|---|---|---|--------|------|------|------|
|              | - | - | - | - | EN-    | EN-  | EN-  | EN-  |
|              |   |   |   |   | RECERR | PERR | RBFU | TBEM |
| Default      |   |   |   |   | 0      | 0    | 0    | 0    |
|              |   |   |   |   | w      | W    | W    | w    |
|              |   |   |   |   |        |      |      |      |

| ENTBEM:   | Enab | leTransmit Buffer Empty Interrupt            |
|-----------|------|----------------------------------------------|
|           | =0   | Transmit Buffer Empty Interrupt is disabled. |
|           | =1   | Transmit Buffer Empty Interrupt is enabled.  |
| ENRBFU:   | Enab | le Receive Buffer Full Interrupt             |
|           | =0   | Receive Buffer Full Interrupt is disabled.   |
|           | =1   | Receive Buffer Full Interrupt is enabled.    |
| ENPERR:   | Enab | le Parity Error Interrupt                    |
|           | =0   | Parity Error Interrupt is disabled.          |
|           | =1   | Parity Error Interrupt is enabled.           |
| ENRECERR: | Enab | le Receive Error Interrupt                   |
|           | =0   | Receive Error Interrupt is disabled.         |
|           | =1   | Receive Error Interrupt is enabled.          |
|           |      |                                              |

## Baud rate Register:

An 8-bit division factor (G) is loaded in the baud register. This value specifies the baud rate according to the following formula: ( $f_{sys}$  = internal system clock). At 48 MHz, synchronous transmission of 12 MBaud maximum is possible.

 $BR = f_{sys} / 4(G+1)$ 

# 7.3 80C31 Core and Interface

The internal C31 core is SW-compatible with Industrial Standard 8031 (including command execution times). In addition, it has Timer2 from the 80C32 and the internal work memory consisting of 256 bytes. *Below, this internal processor is called "C31"*. All functions of the controller can be used by the user except port PD2, where the interrupt of the sequential control system is located. The C31 runs with half of the input frequency (for asynchronous with 24MHz, for synchronous with 2, 4, or 8 MHz).

In order to get the original performance of the C31, Ports A, B, and D must be wired with <u>external</u> pull-up resistors. Address Port C is always on Output and thus does not have to be wired with pull-up resistors. The same applies to Port D2 (XINT0), Port D6 (XWR) and Port D7 (XRD).

## Notes:

The ports E, F, G and H are configured as input or output channels by the user program if the interface is set to I/O (BUSTYPE<sub>2..0</sub> = "1 - -").

## 7.3.1 Reset Phase of the C31

The reset phase of the C31 needs a minimum time span of 30 elementary periods. The build-up time of the PLL is at 200  $\mu$ s after the supply voltage and the external quartz have stabilized.

## 7.3.1.1 Boot Type Setting

In order to start the DPC31, the boot type has to be set. **Presently, only Boot Type 2 is permissible.** 

| BOOT  | TYPE  |                                 |
|-------|-------|---------------------------------|
| Bit 1 | Bit 0 |                                 |
| 0     | 0     | Type 1a                         |
| 0     | 1     | Type 1b                         |
| 1     | 0     | <i>Type 1b</i><br><b>Type 2</b> |
| 1     | 1     | Type 3                          |

 Table 7.3-1:
 Boot Type Settings

## 7.3.1.2 Boot Type 2

Two variants are possible for Boot Type 2:

- 1. The internal C31 core processes the program that is stored in the externally connected EPROM (Port A .. D). Ports E .. H are free and can be used for I/O.
- The μP/I/O interface (ports E .. H) can be used for connection to an external μP system (with EPROM) or as I/O channels. Via the SPI interface, an A/D transformer and/or an EPROM can be connected in addition.

Figure 7.3-1: Operation in Boot Type 2

## 7.3.2 80C31 Core

## 7.3.2.1 Data Area

The processor has an "internal" work memory consisting of 256 bytes.

The data area of the processor is broken down into different blocks (Figure 7.3-2): The register cells (interrupt controller, DPS control units, etc.) are located from Address 000h to 004Fh. From Address 0050h to 008Fh, the I/O ports E, F, G, and H can be addressed. From 0090h to 07FFh is an unused area. The internal RAM follows starting with address 0800h broken down into the block: work cells, parameter cells, and buffer management, which consiDXB of approx. 0.5 kByte, and the communication area, which consiDXB of 5.5 kByte.

Starting with 2000h, the external RAM is accessed (signal pin: XCSDATA = low).

ComDeC

| External RAM<br>(Data Memory)                                                                                                                                                                                                                       | FFFFh                                                                                  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                     | 2000h                                                                                  |
| int. CRAM<br>(5.5 kByte)                                                                                                                                                                                                                            | 1FFFh                                                                                  |
| S/R_UnitTemp Buffer<br>Internal Stack (for sequential control system)<br>Buffer Management<br>Parameter Cells                                                                                                                                       | approx. 09FFh                                                                          |
| Internal Variables                                                                                                                                                                                                                                  | Start internal RAM                                                                     |
| Area that can't be used                                                                                                                                                                                                                             | 07FFh                                                                                  |
|                                                                                                                                                                                                                                                     | 0090h                                                                                  |
| Port H<br>Direction Register Port H (1 = Input, 0 = Output)<br>ByteAddress $H_{20}$<br>BitAddress $H_2$<br>BitAddress $H_1$                                                                                                                         | 0089h<br>0088h<br>0082h<br>                                                            |
| BitAddress H <sub>0</sub>                                                                                                                                                                                                                           | 0080h                                                                                  |
| Port G<br>Direction Register Port G (1 = Input, 0 = Output)<br>ByteAddress $G_{70}$<br>BitAddress $G_7$                                                                                                                                             | 0079h<br>0078h<br>0077h                                                                |
| <br>BitAddress G <sub>0</sub>                                                                                                                                                                                                                       | <br>0070h                                                                              |
| Port F                                                                                                                                                                                                                                              |                                                                                        |
| Direction Register Port F (1 = Input, 0 = Output)<br>ByteAddress $F_{7.0}$<br>BitAddress $F_7$                                                                                                                                                      | 0069h<br>0068h<br>0067h                                                                |
| <br>BitAddress F <sub>0</sub>                                                                                                                                                                                                                       | <br>0060h                                                                              |
| Port E<br>Direction Register Port E (1 = Input, 0 = Output)<br>ByteAddress $E_{70}$<br>BitAddress $E_7$<br>BitAddress $E_6$<br>BitAddress $E_5$<br>BitAddress $E_4$<br>BitAddress $E_3$<br>BitAddress $E_2$<br>BitAddress $E_1$<br>BitAddress $E_0$ | 0059h<br>0058h<br>0057h<br>0056h<br>0055h<br>0055h<br>0053h<br>0052h<br>0051h<br>0050h |
| DPS Control Units<br>SSC Interface<br>Parameter Register / Delay Timor                                                                                                                                                                              | 004Fh                                                                                  |
| Parameter Register / Delay Timer<br>Interrupt Controller                                                                                                                                                                                            | 0000h                                                                                  |

Figure 7.3-2: X Data Area of the Internal Processor

## 7.3.2.2 Code Area

The code area normally includes all 64 Kbytes of the address space. The XCS\_CODE and XPSEN signals are active when the code memory is accessed.

If a code RAM is programmed by means of the C31 control register, the address area 0000H - 1000H is reserved for the code RAM and the external code memory is no longer addressed in address area 0000H - 1000H.

## 7.3.3 Code RAM

During normal operation (no code RAM), all accesses go in the code area on the external program memory (XCSCODE = low).

However, the 'C31 Control Register' can be used to show a portion of the internal RAM in the code area as so-called 'Code RAM'. The C31 then no longer obtains the program code from the external code memory but rather from the internal code RAM shown on the same address.



## Table7.3-1: Allocation Between KRAM and Code RAM

When Code RAM is used, the following must be observed:

- Code RAM is composed of the individual blocks of the multiport RAM.
- Prior to programming as Code RAM, the program code must be landed in the RAM through accesses on the data memory.
- As long as a RAM bank is used as code RAM, access to the relevant RAM bank via the data area is no longer permitted.
- If a code RAM is used, the lowest 4 Kbytes can no longer be addressed by the external code memory.
- A reset resets the register settings for the code RAM. The content of the internal RAM can also be affected by a reset.

# 7.3.4 Expansion Interface to the 80C31 Core

Via the ports A, B, C, and D, the ALE and XPSEN signal, all signals of the C31 are taken outside. The C31 must always be operated with address and data bus because the external memory of the DPC31 is connected to it. The exact assignment is provided in Table 7.3-2 (function/alternative function). PD2 is not to be used; here, the interrupt of the sequential control system is located that is always taken permanently to the outside. In addition, the following signals are generated: "XCSDATA" (chip select external data memory (RAM)) and "XCSCODE" (chip select external program memory (ROM)). XCSDATA = low if the access is made to the external data area (starting with address 2000h). XSCODE = low, if the external code area is accessed (if code RAM is not used, starting at address 0000h to the end; otherwise, starting at address 1000h). These signals are always to be connected so that there will not be driver conflicts when connecting an In Circuit Emulator (ICE).

This makes connecting a standard In Circuit Emulator for an 8052 controller (24 MHz) possible. For this, the pin has to be wired DBX = high.

| Pin Name         |      | Function                                |      | Alternative    | Fct. | DebugMode<br>DBX = '1'                 | (ICE) | Comment                           |
|------------------|------|-----------------------------------------|------|----------------|------|----------------------------------------|-------|-----------------------------------|
|                  | Туре | Signal<br>Name                          | Туре | Signal<br>Name | Туре | Signal<br>Name                         | Туре  |                                   |
| PA <sub>70</sub> | I/O  | AB <sub>70</sub> /<br>DB <sub>7.0</sub> | I/O  | -              |      | AB <sub>70</sub> /<br>DB <sub>70</sub> | I/O   | Multiplexed address/data bus      |
| PB <sub>0</sub>  | I/O  | P1.0                                    | I/O  | T2             | I    | -                                      | 1     |                                   |
| PB <sub>1</sub>  | I/O  | P1.1                                    | I/O  | T2EX           | I    | -                                      | I     |                                   |
| PB <sub>27</sub> | I/O  | P1.2 P1.7                               | I/O  | -              |      | -                                      | I     |                                   |
| PC <sub>70</sub> | I/O  | AB <sub>158</sub>                       | 0    | -              |      | AB <sub>158</sub>                      | I     | Address bus more significant byte |
| PD <sub>0</sub>  | I/O  | P3.0                                    | I/O  | RXD            | I    | -                                      | I     | -                                 |
| PD <sub>1</sub>  | I/O  | P3.1                                    | I/O  | TXD            | 0    | -                                      | I     |                                   |
| PD <sub>2</sub>  | I/O  | XINT0                                   | 0    | -              |      | XINT0                                  | 0     | Interrupt of the seq. ctrl. syst. |
| $PD_3$           | I/O  | P3.3                                    | I/O  | XINT1          | I    | -                                      | I     | Ext. interrupt                    |
| PD <sub>4</sub>  | I/O  | P3.4                                    | I/O  | Т0             | I    |                                        | I     |                                   |
| PD <sub>5</sub>  | I/O  | P3.5                                    | I/O  | T1             | I    |                                        | I     |                                   |
| PD <sub>6</sub>  | I/O  | XWR                                     | 0    | -              |      | XWR                                    | I     |                                   |
| PD <sub>7</sub>  | I/O  | XRD                                     | 0    | -              |      | XRD                                    | I     |                                   |
| ALE              | I/O  | ALE                                     | 0    | -              |      | ALE                                    | I     | Address Latch Enable              |
| XPSEN            | I/O  | XPSEN                                   | 0    | -              |      | XPSEN                                  | I     | Output Enable for Code-<br>Memory |
| XCSDATA          | 0    | XCSDATA                                 | 0    | -              |      | XCSDATA                                | 0     | Chip Select for Data Memory       |
| XCSCODE          | 0    | XCSCODE                                 | 0    | -              |      | XCSCODE                                | 0     | Chip Select for Code Memory       |
| DBX              | Ι    | DBX                                     | I    | -              |      | DBX                                    | I     | In Circuit Emulator debug mode    |

## 7.3.5 Interface Signals

 Table7.3-2:
 Interface Signals of the C31

# 7.4 C31 Interrupt Controller in the DPC31

Via this interrupt controller, the C31 can be provided with the same interrupt events as the external  $\mu$ P (refer to Chapter 7.1.4).

It is structured exactly as the other interrupt controller. Each event is stored in the IRR. Via the IMR, individual events can be suppressed. If, for instance, the DPS indications are to be evaluated by the external processor, the corresponding masks have to be set here and be enabled in the interrupt controller for the external processor. The entry in the IRR is independent of the interrupt mask. The event signals that are not masked out in the IMR generate the **C31 interrupt** via a summation network.

For debugging, the user can set any event in the IRR (activate only the bits that are to be reset).

Before leaving the interrupt routine, the C31 has to set the "**End of Interrupt signal (EOI) = 1**" in the EOI register. With this edge change, the interrupt line is switched inactive. If an event should still be stored, the interrupt output becomes active again only after an interrupt inactive time of at least 1  $\mu$ s but no more than 2  $\mu$ s (refer to Section 9.6.2.2).

The interrupt registers IRR, IR, IMR, IAR, and the EOI register are described in Chapter 7.1.4.

The  $PD_2/XINTO$  pin is always an output (negative active). The state of the C31 interrupt controller can be observed externally at this output. In contrast to a normal C31, this pin can be used neither as an IO port nor as an interrupt input.

These interrupt registers -assigned only to the C31- can be accessed by the C31 under the same addresses as the interrupt registers assigned to the host interface. Only the interrupt outputs (ports PG5 and PD2) are different.

# 7.5 Serial PROFIBUS Interface

# 7.5.1 Asynchronous Physics Unit (NRZ)

## 7.5.1.1 Transmitter

The transmitter converts the parallel data structure into a serial data stream. The asynchronous UART process processes with a start bit and a stop bit that frame 9 information bits (8 data bits; 1 even parity bit). The start bit is always log '0', and the stop bit as well as the idle state are always log '1'. The least significant bit is transmitted first.

The transmitter switches the request to send (RTS) active first. After a minimum waiting time of 4 elementary periods (at XCTS active), it then starts the transmission process. (To connect a modem, the XCTS input is available. After RTS is active, the transmitter must hold back the first message character until the modem activates XCTS. During message transmission, the transmitter no longer queries the XCTS.)

When closing transmission, the transmitter deactivates the RTS.

## 7.5.1.2 Receiver

The receiver converts the serial data stream into the parallel data structure. It scans the serial data stream with the 4-fold transmission speed. One requirement of the PROFIBUS protocol is that no idle states are permitted between the message characters. The DPC31 transmitter ensures that this specification is adhered to. In order to check outside systems (for example, S/W solutions) with respect to this point, supplementary logic is implemented in the DPC31 receiver. The receiver checks whether start bit synchronization takes place (not at the ED character of a message) after the stop bit. By parameterizing "DIS\_START\_CONTROL=1" (in the param register, or 'Set\_Param message' for DP), this subsequent start bit check is switched off.

Due to the 4-fold scan, a maximum distortion of the serial input signal of X = -47% to y = +22% in reference to the falling start bit edge is permissible.

# 7.5.1.3 Interface Signals

| Pin Name | Signal Name | Input=I<br>Output=O | Comment                    |
|----------|-------------|---------------------|----------------------------|
| TXD_TXS  | TxD         | 0                   | Send Data                  |
| RXD_RXS  | RxD         | 1                   | Receive Data               |
| RTS_TXE  | RTS         | 0                   | Enable of the send drivers |
| XCTS_RXA | XCTS        | I                   | Sender Enable              |

## Table7.5-1: Asynchronous PROFIBUS Interface of the DPC31

In the test mode, all outputs are switched to high resistance.

# 7.5.2 Synchronous Physics Unit (Manchester)

The synchronous interface makes data transmission according to IEC 1158-2 possible. It includes services of the interface -defined in this standard- between the following: data link layer and physical layer ((FDL Ph layer interface), the sublayers Ph DIS (DCE independent sublayer) and Ph MDS (medium dependent sublayer) for wire media and the corresponding MDS-MAU interface. In addition, the station management physical layer interface is implemented (parts of the service primitives, optionally defined in Standard IEC 1158-2). The so-called "medium access unit (MAU)" is not implemented, which includes the following: the initial pulse shaper, the line driver, the receive amplifier, the receive filters and the line coupling (if needed, with remote supply setup). The MAU can be set up with little effort with the SIM1 Analog ASIC.



 Table7.5-2:
 Block Diagram of the Synchronous Interface.

# 7.5.2.1 Transmitter

The transmitter converts the parallel data structure into a serial data stream. The synchronous transmission procedure according to IEC 1158-2 processes with Manchester coding and start and end delimiters. Each message is preceded by a preamble. The length of the preamble is stored in the preamble register (refer to 3.3). In contrast to the asynchronous interface, the most

significant data bit is transmitted first<sup>5</sup>. The transmitter generates a 16-bit CRC field and attaches it to the data field.



## Table7.5-3: Frame Structure of the Serial Interface

Figure 7.5-5 shows the coding rules . Figure 7.5-6 shows the structure of the preamble and of the delimiters. These figures show that the elementary characters (= smallest quantization unit) at the transmitter output have the length of half a bit period. Their generation requires the double bit clock.



Table7.5-4: Bit Coding of the Synchronous Interface



## Table7.5-5: Preamble and Delimiters

The transmitter makes different output signals available (Figure 7.5-6). In addition to the signals RTS (enable of the send driver) and TxS (send signal), the signal ADD can be utilized. With the combination of TxS and ADD, an adder circuit for activating a current control unit can easily be established as it is used for the interface of an intrinsically safe bus station. The combination RxS/TxS is an advantage when activating a transformer.

It is useful to make the signals RTS and ADD available at a joint output (RTS/ADD). Switching between the two modes can be parameterized (Param Register; refer to 3.3).

In order to ensure the minimum gap between two messages, the transmitter is disabled at the end of a message for the duration of a minimum interframe gap time. The gap timer is loaded with the current value for the interframe gap time from the interframe GAP\_Time register (Chapter 3.3).

<sup>&</sup>lt;sup>5</sup> according to IEC 1158-2, Chapter 7.



Table7.5-6: Output Signals of the Synchronous Transmitter

### 7.5.2.2 Receiver

#### **Receive Filter**

The receive filter conditions the receive signal RxS for clock recovery and for decoding.

#### Manchester Decoder and Clock Recovery

This unit includes all the resources that are needed to decode the data from the filtered receive signal.

The **Clock Recovery** recovers the clock CLK1 from the filtered receive signal and the system clock CLK16 (whose nominal frequency corresponds to the 16-fold data rate). Because of the ambiguity of the zero crossings<sup>6</sup> and because of the normally relatively long "catch time" of a phase control loop, it is necessary to provide the clock recovery with a quick synchronization setup (quick synchronizer) which, at the beginning of each receive process, quickly synchronizes the recovered clock with the receive signal.

The signal RxA, generated by the line activity detector, switches the synchronizer into a "quick synchronization mode" at the beginning of a message. In this mode, **the fourth zero crossing** (or the first four zero crossings)<sup>7</sup> of the signal supplied by the preamble filter leads to resynchronization(Zero\_Phase=transition to the initial state) respectively. After the quick synchronization phase, the receive clock is corrected only with  $\pm$  1/16 clock period regarding phase deviation from the signal FRxS<sup>8</sup>. This state is retained until the next falling edge of the signal RxA.

The DPC31 has an improved quick synchronizer. To activate it, the user must set the bit 'Quick\_Sync\_New=1' in the param register (refer to Chapter 3.3). In this mode, the DPC31 attempts to more accurately determine the bit center during the preamble phase by recording the duration of the last high and low phase before the 4<sup>th</sup> edge. From the average of these two numbers, it calculates a correction value which is taken into account when the bit center is specified.

The **data decoder** scans the filtered receive signal with the recovered receive clock (positive edge), and passes on the scan value, weighted with the polarity information (POL=1, or POL=0) that was transferred by the decoder state machine as receive signal RxD.

<sup>&</sup>lt;sup>6</sup> Only the zero crossings in bit center can be utilized for clock recovery.

<sup>&</sup>lt;sup>7</sup> According to IEC 1158-2 (Chapter 9.6), at least four bits are available to the preamble for synchronization. Multiple synchronization during this phase does not provide advantages. A decrease in the error frequency would be attainable through notification via several bits (three maximum). The estimated improvement, however, does not justify the probably much greater effort. In the example shown ,it is assumed that the spike that possibly occurs at the start of the preamble is to be counted with two transitions (worst case). The signal QSync indicates the duration of the synchronization process.

<sup>&</sup>lt;sup>8</sup> Through this rigid phase control loop, the required detection according to IEC 1158-2 (Chapter 9.7) of half-bit slip errors is ensured .

### 7.5.2.3 Power-Saving Serial Interface

Figure 7.5-8 shows three different interfaces of the SIM1 at the DPC31.

If no galvanic isolation of the bus interface (SIM1) is required by the application-specific electronics, the send signals (TxS, TxE) and receive signals (RxS, RxA) are passed on without processing in the DPC31 to the synchronous bus physics unit (Figure 7.5-8a) with the parameter assignment  $GIM_EN='0'$  (Galvanic Isolation Mode, refer to Param Register, Chapter 3.3) in the interface of the power-saving serial interface. The output levels RxA and RxS are adjusted via the supply input V<sub>IF</sub> (SIM1).

To galvanically isolate the lines for the data- and auxiliary signals, different isolated components and circuits can be used (Figure 7.5-7b and c). The conventional type provides for an optocoupler each for the signals TxS, TxE, RxS (and RxA). Otherwise, processing the send and receive signals in the interface of the power-saving serial interface is as shown in Figure 7.5-7a.

To implement a power-saving method of working with optocouplers, an interface logic was conceived (Figure 7.5-7c) which is to be activated via the parameter assignment GIM\_EN='1'.

This circuit generates short pulse-width modulated transmission pulses only in the case of edge transitions of the data stream from which the data signal is recovered in the secondary circuit. The mean power input can thus be reduced to low values. The following are pointed out as special features:

- Combination of the control and data signals in a transmission channel (TxSD, RxSD); thus, reducing the interface width for send and receive direction from 4 to 2 optocoupler channels.
- Suitable for 5V and 3V engineering
- Use of conventional optocoupler blocks with simple selection at the manufacturer; can also be used for optocouplers with higher power requirements and approval for intrinsically safe circuits.
- The power-saving interface can be used only for a transmission rate of 31.25kBd (refer to Param Register, Chapter 3.3).



c) Stromsparende Trennung mit Optokopplern

#### Table7.5-7:Interface to communication-controller DPC31

The interface logic of the power-saving serial interface includes a pulse modulator and a pulse demodulator as in the SIM1. The comparator for regeneration of the analog receive signal behind the optocoupler is not integrated into the DPC31 but must be set up externally.

#### **Pulse Duration Modulator:**

In the galvanic isolation mode (GIM\_EN='1'), the PDM (Figure 7.5-8) converts the serial signal that is to be transmitted into a duration-modulated pulse sequence; the rising edge of the send signal (TxS1) is assigned a long pulse and the falling edge is assigned a short pulse. Likewise with the edges of the static auxiliary signal (TxE1 or RTS/ADD), a long and short pulse is generated which are added to the pulse sequence of the data signal. The summation signal thus generated (TxS\_IM) is used for sampling the LED of an optocoupler.





Table7.5-8: Signal Shaping in the Modulator

### Pulse Duration Demodulator:

In the galvanic isolation mode (GIM\_EN='1'), the useful signal for the PDM is recovered from the collector signal of the optocoupler transistors by using a comparator.

The following digital circuit component (integrated into the DPC31) evaluates the length of the output pulses of the comparator and recovers from it the data signal and the auxiliary signal. The circuit diagram of the demodulator is shown in Figure 7.5-9. The signal characteristic with respect to time is shown in Figure 7.5-10.

When using RxS\_IM, the pin RxA is to be applied to GND.



### Table7.5-9: Circuit of the Demodulator in principle

Table7.5-10: Signal Evaluation of the Demodulator

The rising edge of each incoming pulse (2) triggers a monoflop at runtime t3. The following condition applies: t1 < t3 < t2. When t3 elapses, a scan is made to see if the pulse is still pending, that is, the input signal still corresponds to a logical '1':

- If the pulse is no longer pending, a **short pulse** is detected (t1)
- If the pulse is still pending, a **long pulse** is detected (t2)

Depending on the detected pulse duration t1 (falling edge) or t2 (rising edge), the flip-flop FF 1 is set to L or H. The output of the flipflop thus corresponds to the serial data signal RxS1 (4). The output signal (5) of an additional flip-flop FF 2 is logically connected to the signal (4) via an OR function. When two short pulses in a row occur, both flip-flops are reset (frame end). The OR function yields an L which is recognized as the end of static signal RxE1 (6).

At scan time t3, an uncertainty window is specified because a jitter in the amount of the pending clock pulse period always occurs in the switching system. In this case, the jitter is  $0.5 \,\mu$ s. Time t3 is permanently set in Step A/B of the DPC31. However, because the time durations t1 and t2 can change due to distortions caused by the optical coupler interface module, an assignable time window was implemented in Step C. This corresponds exactly to the values that were implemented in SPC4-2. (see Table 7-5-1.

The various scan times t3 are set by the bits within the expanded parameter register designated for scan mode (see Section "Organizational Parameters – Expanded Parameter Register"). The scan mode set by default after reset deviates from the permanently set scan mode in Step A/B.

| Scan Mode<br>(1 0)       | Uncertainty Window<br>min max |        |  |
|--------------------------|-------------------------------|--------|--|
| 01<br>(after a<br>Reset) | 3.0 μs                        | 3.5 μs |  |
| 00                       | 2.5 μs                        | 3.0 μs |  |
| 10                       | 3.5 µs                        | 4.0 μs |  |
| 11                       | 4.0 μs                        | 4.5 μs |  |

 Table 7.5-11: Uncertainty Window

### Alternative Suggestion regarding Comparator Circuitry:

The wiring of the comparator output described under Figure 7.5-? has the disadvantage that the comparator has to be supplied with the external voltage 5V via the input  $V_{IF}$ , and a level adaptation is necessary at the output. In addition, a control area up to the positive supply voltage has to be ensured. The circuit variant below (Figure 7.5-11) avoids these disadvantages. The two voltage dividers R2 / R3 and R4 / R5 move the work area of the comparator to the center of the internal supply voltage  $V_{CC}$ ; an offset results from the difference of the values R2 and R4 in the idle state; R6 causes a decrease in amplitude; C2 a delay of the reference voltage in the active circuit state. The capacitor C1 decouples the external voltage 5V and the internal  $V_{CC}$ . This comparator circuit is not integrated into the DPC31 and must be implemented externally.



Table7.5-12: Wiring of the Comparator with Bridge Network

### 7.5.2.4 Interface Signals

| Pin Name | Signal Name  | Input=I<br>Output=O | Comment                                                                                                                         |
|----------|--------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------|
|          |              | -                   |                                                                                                                                 |
| TXD_TXS  |              | 0                   | Send signal (for asyn. physics TxD)                                                                                             |
| RXD_RXS  | RxS (RxS_IM) | I                   | Receive signal (for asyn. physics RxD)                                                                                          |
| RTS_TXE  | TxE          | 0                   | Enable of the send drivers/addition signal (for asyn. physics RTS)                                                              |
| XCTS_RXA | RxA          | 1                   | Auxiliary signal for receive<br>(has not been needed so far in the syn. physics unit (apply to GND); for<br>asyn. physics XCTS) |

Figure 7.5-13: Synchronous PROFIBUS Interface of the DPC31

In the test mode, all outputs are switched to high resistance.

### 7.6 DPS Watchdog Timer

### 7.7 Watchdog Timer

### 7.7.1 Automatic Baud Rate Detection

The DPC31 is able to recognize the baud rate automatically. The "Baud\_Search" mode is entered after each RESET as well as after the expiration of the Watchdog(WD) timer in the 'Baud\_Control' mode.

The DPC31 starts the search for the set baud rate always with the highest baud rate. If during the monitoring time no SD1, SD2, or SD3 message has been received completely and faultlessly, the search is continued with the next lower baud rate.

After detecting the correct baud rate, the DPC31 switches to the "Baud\_Control" mode and monitors the baud rate. The monitoring time can be parameterized (WD\_Baud\_Control\_Val). The watchdog processes in this case with a clock of 100 Hz (10 msec). Each faultlessly received message to its own station address resets the watchdog. If the timer expires, the DPC31 reswitches to the Baud\_Search mode.

### 7.7.2 Baud rate Monitoring

In 'Baud\_Control', the baud rate that was found is monitored **continuously**. With each faultless address to the DPC31s own station address, the watchdog is reset. The monitoring time is the result of multiplying 'WD\_Baud\_Control\_Val' (to be parameterized by the user) by the time base (10 ms). If the monitoring time expires, the WD\_SM reenters 'Baud\_Search'. If the user handles the DP protocol with the DPC31 (DP\_Mode =1; refer to Mode Register 0), the watchdog is used for the 'DP\_Control' mode after a 'Set\_Param message' with enabled response monitoring 'WD\_On = 1' was received. If the master monitoring 'WD\_On = 0' is switched off, the watchdog timer remains in the baud rate monitoring mode. The PROFIBUS DP state machine is not reset if the timer expires; that is, the slave remains in the DATA\_Exchange mode.

## 7.7.3 Response Monitoring

The 'DP\_Control' mode is used for response monitoring of the DP master (Master\_Add). The set monitoring time is the result of multiplying both watchdog factors and then multiplying by the time base valid at the moment (1 ms or 10 ms):

T<sub>WD</sub> = (1 ms or 10 ms) \* WD\_Fact\_1 \* WD\_Fact\_2 (refer to Byte 7 of the parameter assignment message).

The two watchdog factors (WD\_Fact\_1, WD\_Fact\_2) and the time base that represent a value for the monitoring time can be loaded by the user with the 'Set\_Param message' with any value between 1 and 255.

**Exception: the setting WD\_Fact\_1=WD\_Fact\_2=1 is not permissible.** This setting is not checked by the circuit.

With the permissible watchdog factors, monitoring timing between 2 ms and 650s can thus be implemented regardless of the baud rate.

If the monitoring time expires, the DPC31 reenters 'Baud\_Control' and the DPC31 generates the 'WD\_DP\_Control\_Timeout interrupt'. In addition, the state machine is reset; that is, the reset modes of buffer management are generated.

If another master takes over the DPC31, it either switches to 'Baud\_Control' (WD\_On = 0) or it remains in 'DP\_Control' (WD\_On =1) depending on the enabled response monitoring.

### 7.8 Clock Supply

### 7.8.1 PLL

In the <u>asynchronous mode</u>, the clock pulse is generated with an integrated oscillator and an analog-PLL in the DPC31. The oscillator pins (XTAL1\_CLK and XTAL2) are, as shown in Figure 7.8-1, wired with the values according to Table 7.8.2. The following PLL quadruples the input frequency of 12 MHz (pin XPLLEN = low). The DPC31 now has the internal system frequency of  $f_{SYS}$  = 48MHz. It is not possible to connect the PLL with an external clock pulse generator. The internal system clock has an inaccuracy from the external quartz (here assumed to be ± 150 ppm) plus the inaccuracy of the PLL (± 200 ppm). The rise time of the PLL is at 1 ms after the supply voltage and the external quartz have stabilized.

In the <u>synchronous mode</u>, the lower system frequency ( $f_{SYS} = 16/8/4(/2)MHz$ ) is supplied via an external clock pulse generator directly at pin XTAL1\_CLK. The integrated oscillator and the PLL are switched off in that case (pin XPLLEN = high, power-save mode). (2 MHz system frequency is not enabled.)

To connect an external  $\mu$ Processor, the output CLKOUT1X2 (f<sub>SYS</sub> /2 or f<sub>sys</sub>) and/or CLKOUT1X4 (f<sub>SYS</sub> /4) can be used. The outputs are active after being switched on -also during the reset phase- and can be switched off via Mode Register0.

The internal processing clock pulse is  $f_{SYS}/2$ . The bus physics unit is operated with the scanning frequency (4-fold for asynchronous, 16-fold for synchronous).



Figure 7.8-1: Block Diagram of Clock Supply

| Pin Name  | Pad | Comment                                                                          |
|-----------|-----|----------------------------------------------------------------------------------|
| XTAL1_CLK | I   | Quartz connection / direct clock input (for syn. mode)                           |
| XTAL2     | 0   | Quartz connection                                                                |
| XPLLEN    | I   | Selection PLL or clock input                                                     |
| CLKOUT1X2 | 0   | Half of the internal clock (clock for In Circuit Emulator) or the internal clock |
| CLKOUT1X4 | 0   | Quarter of the internal clock                                                    |
| AVDD      | -   | Supply pin of PLL                                                                |
| AGND      | -   | Supply pin of PLL                                                                |

Table 7.8-1: Pins for the Clock Supply



| Component | Value                                   |
|-----------|-----------------------------------------|
| Q1        | 12 MHz quartz;                          |
|           | Epson type: MA505, MA506, MA406, MA406H |
| Rs        | 2,7 ΚΩ                                  |
| Rf        | 1,0 ΜΩ                                  |
| C1        | 22 pF                                   |
| C2        | 22 pF                                   |

 Table 7.8-2:
 Component Values of Oscillator Wiring

#### Notes on PCB layout:

- Place all components of the quartz interface connection as close as possible to Pins 98 and 99.
- No other signals should cross the area of the quartz interface connection nor the other signal positions.
- The CLKOUT1X2 signal (Pin 100) should be routed in the maximum possible clearance to the quartz interface connection.
- Shield the entire quartz interface connection and Pins 98 and 99 against possible interferences.
- The voltage supply of PLL should be as free of interference as possible. If required, provide external support or filtering.

## 8 Test Support

The DPC31 has three test pins (TST1,NTEST1, NTEST2). For operation, all pins are to be at 0 Volt. To switch the outputs to high-resistance (In Circuit Test), NTEST1/2 are to be at 1.

### 8.1 Emulator Connection for the C31

To emulate the C31 that is integrated in the DPC31, a standard emulator (such as Hitex MX51AH) can be connected. The interfacing is shown in Figure 8.1-1. The emulator must be used with the SAB-C501-40 or a type compatible with the timing, because of the more relaxed timing of the processor.

**Problem Case:** If the C165 (@20MHz) without tristate time waitstate for DPC31 accesses <u>and</u> the C31 emulator (@24MHz) are operated together, there may be access conflicts to the internal DPC31 RAM.

**Remedy:** For accesses by the C165 to the DPC31, the tristate time waitstate is to be set accordingly.





#### **Electrical Specifications** 9

### 9.1 Maximum Limits

| Parameter                            | Name                    | Condition                | Limits                       | Unit |
|--------------------------------------|-------------------------|--------------------------|------------------------------|------|
| DC voltage supply                    | V <sub>DD</sub>         |                          | -0.3 to +4.0                 | V    |
| Input voltage <sup>9</sup>           |                         |                          |                              |      |
| All inputs except Pin 98             | VI                      |                          | -0.3 to +6.0                 | V    |
| Pin 98 (XTAL1_CLK)                   | VI                      |                          | -0.3 to V <sub>DD</sub> +0.3 | V    |
| Output voltage <sup>10</sup>         |                         |                          |                              |      |
| All outputs except Pin 95,<br>96, 99 | Vo                      |                          | -0.3 to +6.0 <sup>11</sup>   | V    |
| • Pin 95, 96, 99                     | Vo                      |                          | -0.3 to V <sub>DD</sub> +0.3 | V    |
| DC output current (min)              | Ιo                      | $I_{OL} = 4.0 \text{mA}$ | -13                          | mA   |
| ( @ $V_0 = 0V$ = short circuit)      | Ιo                      | $I_{OL} = 8.0 \text{mA}$ | -26                          | mA   |
| Ambient temperature                  | T <sub>opt</sub>        |                          | -40 to +85                   | °C   |
| Storage temperature                  | T <sub>stg</sub>        |                          | -55 to +125                  | °C   |
| Power loss for PQFP-100              | $P_{vmax}$              |                          | 800                          | mW   |
| Junction temperature                 | $\vartheta_{jmax}$      |                          | 125                          | °C   |
| R <sub>th</sub> junction case        | $R_{thj \rightarrow c}$ |                          |                              | K/W  |
| R <sub>th</sub> case-ambient         | $R_{thc  ightarrow a}$  |                          |                              | K/W  |
| R <sub>th</sub> junction-ambient     | R <sub>thj→a</sub>      |                          | 27                           | K/W  |

Table 9.1-1: Maximum Limits

### 9.2 Permitted Operating Values

 <sup>&</sup>lt;sup>9</sup> In DPC31 Step A/B, Pin 98 was not examined separately in this table.
 <sup>10</sup> In DPC31 Step A/B, Pins 95, 96, and 99 were not examined separatedly in this table
 <sup>11</sup> The output itself can supply a maximum voltage of V<sub>DD</sub>+0.3 V. Higher voltages at the output pins have an external cause, e.g., pull up resistors.

## ComDeC

| Parameter                                        | Name.           | Min. | Max. | Unit |
|--------------------------------------------------|-----------------|------|------|------|
| DC supply voltage                                | V <sub>DD</sub> | 3.0  | 3.6  | V    |
| Input voltage (Low-Level) <sup>12</sup>          | V <sub>IL</sub> | 0    | 0.8  | V    |
| Input voltage (High-Level)12 <sup>12</sup>       | V <sub>IH</sub> | 2.0  | 5.5  | V    |
| Input voltage (Low-Level trigger) <sup>13</sup>  | V <sub>IL</sub> | 0    | 0.7  | V    |
| Input voltage (High-Level trigger) <sup>13</sup> | V <sub>IH</sub> | 2.1  | 5.5  | V    |
| Hysteresis <sup>13</sup>                         | V <sub>H</sub>  | 0.4  |      | V    |
| Input rise time                                  | tr              | 0    | 200  | ns   |
| Input dropout time                               | t <sub>f</sub>  | 0    | 200  | ns   |
| Bus fight time                                   | t <sub>BF</sub> | 0    | 20   | ns   |
| Schmitt trigger input rise time                  | t <sub>r</sub>  | 0    | 10   | ms   |
| Schmitt trigger input dropout time               | t <sub>f</sub>  | 0    | 10   | ms   |

Table 9.2-1: Permitted Operating Values

### 9.3 Guaranteed Operating Range for the Specified Parameters

| Parameters            | Name             | Min. | Max. | Unit |
|-----------------------|------------------|------|------|------|
| DC Supply Voltage     | V <sub>DD</sub>  | 3.0  | 3.6  | V    |
| Operating Temperature | T <sub>opt</sub> | -40  | +85  | °C   |

 Table 9.3-1:
 Guaranteed Operating Range of the Specified Parameters

### 9.4 Power Loss

Power Loss: (all values worst case estimate)Asynchronous:approx. 325 mW at 12 MBdSynchronous:approx. 7 mW at 31.25 kBd and 2MHz clock (C31 switched off)approx. 11 mW at 31.25 kBd and 2MHz clock (C31 core @ 1MHz)approx. 35 mW at 31.25 kBd and 16MHz clock (C31 core @ 8MHz)

| Power Loss:   | (all values measured typically) |
|---------------|---------------------------------|
| Asynchronous: | no values                       |
| Synchronous:  | no values                       |

### 9.4.1 Power-Up of the Supply Voltage

If the DPC31 is used in modules with mixed voltage supply (3.3V and 5V), the voltage difference between the supply pins ( $V_{DD} = 3.3V \pm 10\%$ ) and the signal pins ( $V_{I/O}$ ) is to be no larger than +3.0V at any time ( $V_{I/O} - V_{DD} < 3.0V$ ). If this value is exceeded, the DPC31 will be destroyed.

All pins except Pin 95, 96, 98, and 99:

<sup>&</sup>lt;sup>12</sup> DPC31-Step C: does <u>not</u> apply to Input Pins 6, 87, 88, and 98.

<sup>&</sup>lt;sup>13</sup> DPC31-Step C: <u>only</u> applies to Input Pins 6, 87, and 88.





During switching on and off, the voltage at the 5 V-tolerant signal pins must not exceed a value of +6.0 V or fall below a value of -0.3 V.

The 5V-tolerant outputs can themselves only cause a voltage of -0.3 V up to VDD+0.3 V to flow. A higher voltage at the pin can only be brought about by external components, e.g., pull-up resistors.

These values must not be exceeded; otherwise the DPC31 may be destroyed.

Pins 95, 96, 98, and 99 only:



### Table 9.4-2: Voltage Ramp for LVTTL I/O

During switching on and switching off, the voltage at the indicated signal pins must not exceed a value of  $V_{DD}$ +0.3 V or fall below a value of -0.3 V.

These values must not be exceeded; otherwise the DPC31 may be destroyed.

### 9.4.2 Structure of the Pad Cells with 5V Tolerance

The input pad cells used have a tolerance of 5V; that is, they are provided with a protective circuit. This means that, although they are supplied internally with only 3.3V, the input level may be 6 V maximum. Table 9.5-1 shows the operating points.

The 5V-tolerant output pad cells are also provided with a special protective circuit. When driving the 0-level, there is no difference with respect to the conventional pad cells. The 1-level is driven actively up to  $V_{DD}$  - 0.3V. Starting with this voltage, the external pull-up resistor pulls the level to  $V_{DD2}$  (5V). This pull-up is needed only if a 5V-CMOS input is to be driven. For reasons of interference immunity, *TTL-level is recommended*.



Figure 9.5-2: Wiring of an Output Pad Cell with 5V Tolerance

## 9.4.3 DC Specification of the Pad Cells

| Parameter                                          | Na<br>me.        | Condition                                                                            | Min.           | Туре | Max.              | Unit |
|----------------------------------------------------|------------------|--------------------------------------------------------------------------------------|----------------|------|-------------------|------|
| Input voltage 0-level <sup>14</sup>                | V <sub>IL</sub>  |                                                                                      | 0              |      | 0.8               | V    |
| Input voltage 1-level <sup>14</sup>                | VIH              |                                                                                      | 2.0            |      | 5.5               | V    |
| Output voltage 0-level <sup>15</sup>               | $V_{OL}$         | $I_{OL} = 0 \text{ mA}$                                                              |                |      | 0.1               | V    |
| Output voltage 1-level                             | V <sub>OH</sub>  | I <sub>ОН</sub> = 0 mA                                                               | $V_{DD} - 0.2$ |      | 5.5 <sup>16</sup> | V    |
| Output voltage 1-level <sup>17</sup>               | V <sub>OH</sub>  | $I_{OH} = 0 \text{ mA}$                                                              | $V_{DD} - 0.2$ |      | $V_{\text{DD}}$   | V    |
| Schmitt trigger. +ve threshold <sup>18</sup>       | VP               |                                                                                      |                |      | 2.1               | V    |
| Schmitt Trigve threshold <sup>18</sup>             | $V_N$            |                                                                                      | 0.7            |      |                   | V    |
| Schmitt Trig. hysteresis <sup>18</sup>             | V <sub>H</sub>   |                                                                                      | 0.4            |      |                   | V    |
| Schmitt Trig. input voltage <sup>18</sup>          | VIH              |                                                                                      |                |      | 5.5               | V    |
| Input leakage current                              | h                | $V_{I} = V_{DD}$ or GND                                                              |                |      | ±1                | μA   |
| Output current 0-level                             | I <sub>OL</sub>  | V <sub>OL</sub> = 0.4 V; T <sub>J</sub> =95°C                                        | 3.84           |      |                   | mA   |
| 4 mA cell/ 5 V-tolerant                            |                  | $V_{DD} = 3V$                                                                        |                |      |                   |      |
| Output current 1-level<br>4 mA cell / 5 V-tolerant | I <sub>ОН</sub>  | V <sub>OH</sub> = 2.4 V; T <sub>J</sub> =95°C<br>V <sub>DD</sub> = 3V                | -3.84          |      |                   | mA   |
| Output current 0-level<br>8 mA cell / 5 V-tolerant | I <sub>OL</sub>  | V <sub>OL</sub> = 0.4 V; T <sub>J</sub> =95°C<br>V <sub>DD</sub> = 3V                | 7.68           |      |                   | mA   |
| Output current 1-level<br>8 mA cell / 5 V-tolerant | I <sub>он</sub>  | $V_{OH} = 2.4 \text{ V}; \text{ T}_{J} = 95^{\circ}\text{C}$<br>$V_{DD} = 3\text{V}$ | -7.68          |      |                   | mA   |
| Output current 0-level<br>8 mA cell/ 3.3 V         | I <sub>OL</sub>  | $V_{OL} = 0.4 \text{ V}; \text{ T}_{J} = 95^{\circ}\text{C}$<br>$V_{DD} = 3\text{V}$ | 7.68           |      |                   | mA   |
| Output current 1-level<br>8 mA cell / 3.3 V        | I <sub>ОН</sub>  | V <sub>OH</sub> = 2.4 V; T <sub>J</sub> =95°C<br>V <sub>DD</sub> = 3V                | -7.68          |      |                   | mA   |
| Output current 0-level<br>XTAL2 pin / 3.3 V        | I <sub>OL</sub>  | V <sub>OL</sub> = 0.4 V; T <sub>J</sub> =95°C<br>V <sub>DD</sub> = 3.3V              | 1.92           |      |                   | mA   |
| Output current 1-level<br>XTAL2 pin / 3.3 V        | I <sub>ОН</sub>  | V <sub>OH</sub> = 2.4 V; T <sub>J</sub> =95°C<br>V <sub>DD</sub> = 3.3V              | -1.92          |      |                   | mA   |
| Tristate output leakage current                    | l <sub>oz</sub>  | $V_{O} = V_{DD}$ or GND                                                              |                |      | ±10               | μA   |
| Short circuit current                              | los              | $V_0 = 0 V$                                                                          |                |      | -145              | mA   |
|                                                    |                  | V <sub>DD</sub> =3.6V T=-40°C                                                        |                |      |                   |      |
| Input capacity                                     | CIN              | @ f = 1 MHz                                                                          |                | 10   | 20                | рF   |
| Output capacity                                    | C <sub>OUT</sub> | @ f = 1 MHz                                                                          |                | 10   | 20                | pF   |
| I/O capacity                                       | C <sub>I/O</sub> | @ f = 1 MHz                                                                          |                | 10   | 20                | pF   |

| Table 9.5-1: DC Specification of the Pad Cells | Table 9.5-1: | <b>DC</b> Specification | of the Pad Cells |
|------------------------------------------------|--------------|-------------------------|------------------|
|------------------------------------------------|--------------|-------------------------|------------------|

<sup>&</sup>lt;sup>14</sup> All inputs except Pins 6, 87, 88, and 98 <sup>15</sup> All outputs except Pins 95, 96, and 99

<sup>&</sup>lt;sup>16</sup> Each output can cause a maximum level of  $V_{DD}$  to flow; if a higher level exists at an ouput, this is dependent on an external component, e.g., pull-up resistors

<sup>&</sup>lt;sup>17</sup> Applies to Pins 95, 96, and 99 <sup>18</sup> Applies to Pins 6, 87, and 88

### 9.5 AC Specification

### 9.5.1 Driver Capability

The run times at the chip outputs always depend on the driver capacity of the pad cells as well as on the assumed capacitive load. The capacitive load that was used as a basis for the following timing specifications is shown in Table 9.6-1. To specify the maximum and minimum runtimes, the variations of temperature range and supply voltage range shown in Table 9.3-1 were included also.

| Signal Name | Direction | Driver Type | Voltage     | Capacity | Load      |
|-------------|-----------|-------------|-------------|----------|-----------|
| PA          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 120 pF ** |
| PB          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| PC          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| PD          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| ALE         | In/Out    | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| XPSEN ***   | In/Out    | Tristate    | 5V tolerant | 4 mA     | 10 pF     |
| XCSDATA     | Out       | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| XCSCODE     | Out       | Tristate    | 5V tolerant | 4 mA     | 80 pF     |
| PE          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 100 pF    |
| PF          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 100 pF    |
| PG          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 100 pF    |
| PH          | In/Out    | Tristate    | 5V tolerant | 4 mA     | 100 pF    |
| SSCLK       | Out       | Tristate    | 5V tolerant | 8 mA     | 100 pF    |
| SSDO        | Out       | Tristate    | 5V tolerant | 8 mA     | 100 pF    |
| CLKOUT1X2   | Out       | Tristate    | 5V tolerant | 8 mA     | 50 pF     |
| CLKOUT1X4   | Out       | Tristate    | 5V tolerant | 8 mA     | 50 pF     |
| RTS_TXE     | Out       | Tristate    | 3.3V *      | 8 mA     | 50 pF     |
| TXD_TXS     | Out       | Tristate    | 3.3V *      | 8 mA     | 50 pF     |

\*) No pull-up resistors! \*\*) including the capacity of the emulation connection (70 pF)

\*\*\*) XPSEN to be used only for activating the emulator; otherwise, XCSCODE is to be used

### Table 9.5-1: ID Data of the Outputs

If, in reality, the capacitive load deviates from the assumed values, the result will be a change of 0.7 ns maximum per 10pF.

### 9.5.2 Timing Diagrams, Signal Run Times

In general, the following applies: all signals that start with 'X' are 'low active'. The signal runtimes are based on the capacitive loads shown in Table 9.6-1. All timing that refers to the elementary period "T" is defined according to Table 9.6-2.

| XPLLEN | Comment                              | Т        |
|--------|--------------------------------------|----------|
| 1      | Direct Clock Supply                  | 1/CLK    |
| 0      | Quartz Connection (12 MHz)           |          |
|        | $\Rightarrow$ Internal Clock: 48 MHz | 20.83 ns |

### Table 9.5-2: Definition of the Elementary Period T

### 9.5.2.1 Clock Supply (XPLLEN = '1')

| No. | Parameters      | Min | Max | Unit |
|-----|-----------------|-----|-----|------|
| 1   | Clock High Time | 7.5 |     | ns   |
| 2   | Clock Low Time  | 9.8 |     | ns   |
| 3   | Rise Time       |     | 1   | ns   |
| 4   | Fall Time       |     | 1   | ns   |
|     | Max. frequency  |     | 48  | MHz  |

Table 9.5-3: Input Clock

CLK



Figure 9.5-1: Clock Timing

### 9.5.2.2 Clock Outputs

The clock outputs (CLKOUT1X2 and CLKOUT1X4) are active during the RESET also. For switched on PLL (XPLLEN = '0'):

In this mode, the two clock outputs are derived from the output clock of the PLL. The clock outputs thus have the inaccuracy of the PLL (frequency stability +/- 200 ppm; phase jitter: maximum of 3 ns). The electrical characteristics are shown in Table 9.6-4.

| Parameter                      | Min   | Max   | Unit |
|--------------------------------|-------|-------|------|
| Duty factor CLKOUT1X2 (Hi:Low) | 35:65 | 65:35 |      |
| Duty factor CLKOUT1X4 (Hi:Low) | 35:65 | 65:35 |      |
| Response time (of PLL)         |       | 1     | ms   |
| Frequency stability (of PLL)   |       | ±200  | ppm  |

### Table 9.5-4: Clock Outputs

For switched off PLL (XPLLEN = '1'):

In this mode, both clock outputs are derived from the input clock at the XTAL1\_CLK pin. The clock outputs thus have the inaccuracy of the pending clock. The data for the duty factor is shown in Table 9.6-4.

### 9.5.2.3 Reset

For switched on PLL (XPLLEN = '0'):

The reset does not reset the PLL. After voltage is restored, the reset duration should be a multiple of the build-up duration for safety reasons (see Table 9.6-4).

For switched off PLL (XPLLEN = '1'):

The reset duration should be greater than 40 clock cycles at the XTAL1\_CLK pin.

### 9.5.2.4 Interrupt

After acknowledging an interrupt with EOI, there is at least a 1us or 1 ms wait in the DPC31 prior to a new interrupt being read out.

| No. | Parameters                                    | Min | Max | Unit |
|-----|-----------------------------------------------|-----|-----|------|
| 1   | Interrupt Inactive Time (if EOI_Timebase = 0) | 1   | 2   | μs   |
|     | Interrupt Inactive Time (if EOI_Timebase = 1) | 1   | 2   | ms   |

### Table 9.5-5: Interrupt Inactive Time after EOI



### Figure 9.5-2: Peripheral Mode, Interrupt EOI Timing

### **Profibus Interface**

| No. | Parame                            | eters            | Min | Max                   | Unit |
|-----|-----------------------------------|------------------|-----|-----------------------|------|
| 1   | RTS ↑ to TXD Setup Time           | XAsyn/Syn = low  | 7T  | 7T + T <sub>BIT</sub> | ns   |
|     |                                   | XAsyn/Syn = high | 0   |                       | ns   |
| 2   | RTS $\downarrow$ to TXD Hold Time | XAsyn/Syn = low  | 5T  | 6T                    | ns   |
|     |                                   | XAsyn/Syn = high | 0   |                       | ns   |

T:= elementary period

TBIT: elementary period of the transition clock pulse of the Profibus Interface  $XCTS_RXA = '0'!$ 

### Table 9.5-6: Specification of the Profibus Interface



Figure 9.5-3: Transmit Timing, XCTS constant log. '0'

### 9.5.2.5 µP Interface

9.5.2.5.1 Synchronous Intel Mode (80C32)

| No. | Parameters                                                                    | Min     | Max   | Unit |
|-----|-------------------------------------------------------------------------------|---------|-------|------|
| 1   | Address to ALE $\downarrow$ Setup time                                        | 10      |       | ns   |
| 2   | Address (AB <sub>815</sub> ) hold time after XRD $\uparrow$ or XWR $\uparrow$ | 5       |       | ns   |
| 3   | XRD $\downarrow$ to Data Out (access to RAM)                                  |         | 4T+14 | ns   |
|     | XRD $\downarrow$ to Data Out (access to the registers)                        |         | 4T+14 | ns   |
| 4   | ALE $\downarrow$ to XRD $\downarrow$                                          | 20      |       | ns   |
| 5   | Data hold time after XRD $\uparrow$                                           | 1.5     | 5     | ns   |
| 6   | Data hold time after XWR $\uparrow$                                           | 10      |       | ns   |
| 7   | Data setup time to XWR ↑                                                      | 10      |       | ns   |
| 8   | XRD ↑ to ALE ↑                                                                | 10      |       | ns   |
| 10  | XRD Pulse Width                                                               | 6T – 10 |       | ns   |
| 11  | XWR Pulse Width                                                               | 4T      |       | ns   |
| 12  | Address hold time after ALE $\downarrow$                                      | 10      |       | ns   |
| 13  | ALE Pulse Width                                                               | 10      |       | ns   |
| 14  | XRD, XWR cycle time                                                           | 6T + 30 |       | ns   |
| 15  | ALE $\downarrow$ to XWR $\downarrow$                                          | 20      |       | ns   |
| 16  | XWR $\uparrow$ to ALE $\uparrow$                                              | 10      |       | ns   |

### Table 9.5-7: Timing Values in the Synchronous Intel Mode

In the synchronous Intel mode, the DPC31 stores the least significant address bits with the falling edge of ALE. At the same time, it expects the most significant address bits at the address bus; from them, it generates itself a chip select signal.

The request for an access to the DPC31 is generated from the falling edge of the read signal or the rising edge of the write signal.



Figure 9.5-4: Synchronous Intel Mode, Processor Read Timing



Figure 9.5-5: Synchronous Intel Mode, Processor Write Timing

### 9.5.2.5.2 Asynchronous Intel Mode (X86 Mode)

In 80X86 operation, the DPC31 in principle behaves like a memory with Ready logic; the access timing depends on the type of access.

The request for an access to the DPC31 is generated from the falling edge of the Read signal or the rising edge of the Write signal.

| No. | Parameters                                                          | Min     | Max     | Unit |
|-----|---------------------------------------------------------------------|---------|---------|------|
| 20  | Address setup time to XRD $\downarrow$ or XWR $\downarrow$          | 0       |         | ns   |
| 21  | XRD $\downarrow$ to Data valid (access to RAM)                      |         | 4T+14   | ns   |
|     | XRD $\downarrow$ to Data valid (access to the registers)            |         | 4T+14   | ns   |
| 22  | Address (AB <sub>120</sub> ) hold time after XRD or XWR $\uparrow$  | 0       |         | ns   |
| 23  | XCS $\downarrow$ Setup time to XRD $\downarrow$ or XWR $\downarrow$ | 0       |         | ns   |
| 24  | XRD Pulse Width                                                     | 6T – 10 |         | ns   |
| 25  | Data hold time after XRD $\uparrow$                                 | 1.5     | 5       | ns   |
| 26  | Read/Write inactive Time                                            | 10      |         | ns   |
| 27  | XCS hold time after XRD $\uparrow$ or XWR $\uparrow$                | 0       |         | ns   |
| 28  | XRD/XWR $\downarrow$ to XRDY $\downarrow$ (normal Ready)            | 4T      | 5T + 14 | ns   |
| 29  | XRD/XWR $\downarrow$ to XRDY $\downarrow$ (early Ready)             | 3T      | 4T + 14 | ns   |
| 30  | XREADY hold time after XRD or XWR                                   | 7       | 19      | ns   |
| 31  | Data setup time to XWR $\uparrow$                                   | 10      |         | ns   |
| 32  | Data hold time after XWR $\uparrow$                                 | 10      |         | ns   |
| 33  | XWR Pulse Width                                                     | 4T      |         | ns   |
| 34  | XRD, XWR cycle time                                                 | 6T      |         | ns   |
| 35  | last XRD $\downarrow$ to XCS $\downarrow$                           | 4T+10   |         | ns   |
| 36  | XCS ↑ to next XWR ↑                                                 | 4T      |         | ns   |
| 37  | XWR $\uparrow$ to next XWR $\uparrow$ (XCS don't care)              | 6T      |         | ns   |

 Table 9.5-8:
 Timing Values in the Asynchronous Intel Mode

DPC31 HW



Figure 9.5-6: Asynchronous Intel Mode, Processor Read Timing

The Ready signal is generated by the DPC31 synchronously to the clock supplied and reset by the deactivation the Read or Write signal. With XRD = 1, the data bus is switched to Tristate.





9.5.2.5.3 Synchronous Motorola Mode (E\_Clock mode; for example, 68HC11) If the DPC31 supplies the CPU with the clock, the output clock has to be 4 times larger than the E\_CLOCK. The DPC31 input clock (CLK) has to be **at least 10 times** larger than the desired system clock (E\_Clock). Therefore, the clock output CLKOUT1x4 that specifies the E\_Clock of 3 MHz is to be used (asyn. physics).

The request for a read access to the DPC31 is generated from the rising edge of the E\_Clock (in addition: XCS = '0',  $R_W = '1'$ ) and for a write access from the falling edge of the E\_Clock (in addition: XCS = '0',  $R_W = '0'$ ).

## ComDeC

| No. | Parameters                                                         | Min     | Max     | Unit |
|-----|--------------------------------------------------------------------|---------|---------|------|
| 40  | E_Clock Pulse Width                                                | 4T + 67 |         | ns   |
| 41  | Address (AB <sub>12.0</sub> ) setup time to E_Clock $\uparrow$     | 10      |         | ns   |
| 42  | Address (AB <sub>12.0</sub> ) hold time after E_Clock $\downarrow$ | 5       |         | ns   |
| 43  | E_Clock ↑ to Data Active Delay                                     | 3.5     | 10      | ns   |
| 44  | E_Clock $\uparrow$ to Data valid (access to RAM)                   | 3T      | 4T + 14 | ns   |
|     | E_Clock $\uparrow$ to Data valid (access to the registers)         | 3Т      | 4T + 14 | ns   |
| 45  | Data hold time after E_Clock $\downarrow$                          | 2       | 5.5     | ns   |
| 46  | R_W setup time to E_Clock $\uparrow$                               | 10      |         | ns   |
| 47  | R_W hold time after E_Clock $\downarrow$                           | 5       |         | ns   |
| 48  | XCS setup time to E_Clock ↑                                        | 0       |         | ns   |
| 49  | XCS hold time after E_Clock $\downarrow$                           | 0       |         | ns   |
| 50  | Data setup time to E_Clock $\downarrow$                            | 10      |         | ns   |
| 51  | Data hold time after E_Clock $\downarrow$                          | 10      |         | ns   |

Table 9.5-9: Timing Values for the Synchronous Motorola Mode



Figure 9.5-8: Synchronous Motorola Mode, Processor Read Timing





### 9.5.2.5.4 Asynchronous Motorola Mode (for example, 68HC16)

In the asynchronous Motorola mode, the DPC31 behaves in principle like a memory with Ready logic and the access timing depends on the type of accesses.

The request for a Read access to the DPC31 is generated from the rising edge of the AS signal (in addition: XCS = '0',  $R_W = '1'$ ) and for a write access from the rising edge of the AS signal (in addition: XCS = '0',  $R_W = '1'$ ).

| No. | Parameters                                                  | Min     | Max     | Unit |
|-----|-------------------------------------------------------------|---------|---------|------|
| 60  | Address setup time to AS $\downarrow$                       | 0       |         | ns   |
| 61  | AS $\downarrow$ to Data valid (access to RAM)               |         | 4T + 14 | ns   |
|     | AS $\downarrow$ to Data valid (access to the registers)     |         | 4T + 14 | ns   |
| 62  | Address (AB <sub>120</sub> ) hold time after AS $\uparrow$  | 10      |         | ns   |
| 63  | R_W $\downarrow$ setup time to AS $\downarrow$              | 10      |         | ns   |
| 64  | AS Pulse Width                                              | 6T – 10 |         | ns   |
| 65  | Data hold time after AS ↑                                   | 2       | 5       | ns   |
| 66  | AS inactive time                                            | 10      |         | ns   |
| 67  | R_W hold time after AS ↑                                    | 10      |         | ns   |
| 68  | XCS $\downarrow$ setup time to AS $\downarrow$              | -5      |         | ns   |
| 69  | XCS hold time after AS ↑                                    | 0       |         | ns   |
| 70  | AS $\downarrow$ to XDSACK $\downarrow$ (standard Ready)     | 4T      | 5T + 14 | ns   |
| 71  | AS $\downarrow$ to XDSACK $\downarrow$ (early Ready)        | 3Т      | 4T + 14 | ns   |
| 72  | XDSACK hold time after AS $\uparrow$                        | 7.5     | 19      | ns   |
| 73  | AS cycle time                                               | 6T      |         | ns   |
| 74  | Data setup time to AS ↑                                     | 10      |         | ns   |
| 75  | Data hold time after AS ↑                                   | 10      |         | ns   |
| 76  | AS Pulse Width                                              | 4T      |         | ns   |
| 77  | last AS $\downarrow$ (Read) to XCS $\downarrow$             | 4T+10   |         | ns   |
| 78  | XCS ↑ to next AS ↑ (Write)                                  | 4T      |         | ns   |
| 79  | AS $\uparrow$ to next AS $\uparrow$ (Write, XCS don't care) | 6T      |         | ns   |

### Table 9.5-10: Timing Values for the Asynchronous Motorola Mode



Figure 9.5-10: Asynchronous Motorola Mode, Processor Read Timing

The Ready signal XDSACK is generated by the DPC31 synchronously to the supplied clock pulse and it is reset with the deactivation of the AS signal. AS = 1 switches the data bus to Tristate.



Figure 9.5-11: Asynchronous Motorola Mode, Processor Write Timing

| Symbol              | Parameters                            | Min      | Max        | Unit |
|---------------------|---------------------------------------|----------|------------|------|
| t <sub>LHLL</sub>   | ALE pulse width                       | 4T – 4.5 |            | ns   |
| t <sub>AVLL</sub>   | Address setup to ALE                  | 2T – 9.5 |            | ns   |
| t <sub>LLAX</sub>   | Address hold after ALE                | 2T – 4.3 |            | ns   |
| t <sub>LLIV</sub>   | ALE low to valid instr in             |          | 8T – 31.6  | ns   |
| t <sub>LLPL</sub>   | ALE to XPSEN                          | 2T – 3.5 |            | ns   |
| t <sub>PLPH</sub>   | XPSEN pulse width                     | 6T – 0.8 |            | ns   |
| t <sub>PLIV</sub>   | XPSEN to valid instr in               |          | 6T – 27.0  | ns   |
| t <sub>PXIX</sub>   | Input instruction hold after XPSEN    | 0        |            | ns   |
| t <sub>PXIZ</sub>   | Input instruction float after XPSEN   |          | 2T + 4.0   | ns   |
| t <sub>AVIV</sub>   | Address to valid instr in             |          | 10T – 45.6 | ns   |
| t <sub>AZPL</sub>   | Address float to XPSEN                | 0.3      |            | ns   |
| t <sub>PLSCL</sub>  | XPSEN to XCSCODE                      |          | 5.0        | ns   |
| t <sub>SCLSCH</sub> | XCSCODE pulse width                   | 6T +1.6  |            | ns   |
| t <sub>SCXIX</sub>  | Input instruction hold after XCSCODE  | 0        |            | ns   |
| t <sub>SCXIZ</sub>  | Input instruction float after XCSCODE |          | 2T +1.9    | ns   |

### 9.5.2.6 C31 Memory Interface (internal C31 on external memory)

( $C_L$  for Port A = 120pF;  $C_L$  for XPSEN = 10pF;  $C_L$  for all others = 80pF) Table 9.5-11: Timing Values for Accesses to Code Memory





ComDeC

DPC31 HW

| Symbol              | Parameters                     | Min       | Max        | Unit |
|---------------------|--------------------------------|-----------|------------|------|
| t <sub>LHLL</sub>   | ALE pulse width                | 4T – 4.5  |            | ns   |
| t <sub>RLRH</sub>   | XRD pulse width                | 12T +1.8  |            | ns   |
| t <sub>WLWH</sub>   | XWR pulse width                | 12T +1.9  |            | ns   |
| t <sub>LLAX2</sub>  | Address hold after ALE         | 4T + 4.3  |            | ns   |
| t <sub>RLDV</sub>   | XRD to valid data in           |           | 10T – 33.9 | ns   |
| t <sub>RHDX</sub>   | Data hold after XRD            | 0         |            | ns   |
| t <sub>RHDZ</sub>   | Data float after XRD           |           | 4T -2.3    | ns   |
| t <sub>LLDV</sub>   | ALE low to valid data in       |           | 16T – 31.7 | ns   |
| t <sub>AVDV</sub>   | Address to valid data in       |           | 18T – 41.7 | ns   |
| t <sub>LLWL</sub>   | ALE to XWR or XRD              | 6T + 0.3  | 6T + 1.5   | ns   |
| t <sub>AVWL</sub>   | Address valid to XWR or XRD    | 8T – 9.6  |            | ns   |
| t <sub>WHLH</sub>   | XWR or XRD high to ALE high    | 2T – 1.8  | 2T – 0.3   | ns   |
| t <sub>QVWX</sub>   | Data valid to XWR $\downarrow$ | 2T – 8.0  |            | ns   |
| t <sub>QVWH</sub>   | Data setup to XWR              | 14T – 3.3 |            | ns   |
| t <sub>WHQX</sub>   | Data hold after XWR            | 2T -3.1   |            | ns   |
| t <sub>RLAZ</sub>   | Address float after XRD        |           | 0          | ns   |
| t <sub>AVSDL</sub>  | Address valid to XCSDATA       |           | 14.0       | ns   |
| t <sub>SDLSDH</sub> | XCSDATA pulse width            | 24T – 0.4 |            | ns   |

( $C_L$  for Port A = 120pF;  $C_L$  for XPSEN = 10pF;  $C_L$  for all others = 80pF)









## 9.5.2.7 Emulator-Interface

| Symbol             | Parameter                                          | Min | Max     | Unit |
|--------------------|----------------------------------------------------|-----|---------|------|
| t <sub>LHLL</sub>  | ALE pulse width                                    | 3T  |         | ns   |
| t <sub>AVLL</sub>  | Address setup to ALE                               | 1T  |         | ns   |
| t <sub>LLAX</sub>  | Address hold after ALE                             | 1T  |         | ns   |
| t <sub>LLPL</sub>  | ALE to XPSEN                                       | 1T  |         | ns   |
| t <sub>PLPH</sub>  | XPSEN pulse width                                  | 5T  |         | ns   |
| t <sub>LLIV</sub>  | ALE↓ to valid instr out                            |     | 4T + 24 | ns   |
| t <sub>PXIX</sub>  | Output instruction hold after XPSEN                | 2   |         | ns   |
| t <sub>PXIZ</sub>  | Output instruction float after XPSEN <sup>19</sup> |     | 10      | ns   |
| t <sub>AZPL</sub>  | Address float to XPSEN <sup>19</sup>               | 0   |         | ns   |
| t <sub>PLSCL</sub> | XPSEN↓ to XCSCODE↓                                 | 3   | 10      | ns   |
| t <sub>PHSCH</sub> | XPSEN <sup>↑</sup> to XCSCODE <sup>↑</sup>         | 5   | 15      | ns   |

( $C_{L}$  for Port A = 120pF;  $C_{L}$  for XPSEN = 10pF;  $C_{L}$  for all others = 80pF) **Table 9.5-13:** Timing Values for Emulator Accesses to Code Memory

<sup>&</sup>lt;sup>19</sup> After this time, the output driver of the DPC31 is switched off. The signal level at the bust then depends on the bus load the size of the pull-up resistors.



### Figure 9.5-15: Emulator Code Read-Cycle

PA(=data bus) of DPC31 is only active if

- Internal code RAM is programmed
- Address created by emulator is < 1000H
- In this case, XCSCODE = konst. = 1

| Symbol             | Parameter                                             | Min | Мах     | Unit |
|--------------------|-------------------------------------------------------|-----|---------|------|
| t <sub>LHLL</sub>  | ALE pulse width                                       | 3T  |         | ns   |
| t <sub>AVLL</sub>  | Address setup to ALE $\downarrow$                     | 1T  |         | ns   |
| t <sub>RLRH</sub>  | XRD pulse width                                       | 6T  |         | ns   |
| t <sub>wLwH</sub>  | XWR pulse width                                       | 6T  |         | ns   |
| t <sub>LLAX2</sub> | Address hold after ALE $\downarrow$                   | 1T  |         | ns   |
| t <sub>RLDV</sub>  | XRD $\downarrow$ to valid data out                    |     | 4T + 24 | ns   |
| t <sub>RHDX</sub>  | Data hold after XRD↑                                  | 2   |         | ns   |
| t <sub>RHDZ</sub>  | Data float after XRD <sup>20</sup>                    |     | 10      | ns   |
| t <sub>LLWL</sub>  | ALE to XWR↓ or XRD↓                                   | 1T  |         | ns   |
| t <sub>AVWL</sub>  | Address valid to XWR $\downarrow$ or XRD $\downarrow$ | 2T  |         | ns   |
| t <sub>WHLH</sub>  | XWR↑ or XRD↑ high to ALE high                         | 1T  |         | ns   |
| t <sub>QVWH</sub>  | Data setup to XWR↑                                    | 2T  |         | ns   |
| t <sub>WHQX</sub>  | Data hold after XWR↑                                  | 1T  |         | ns   |
| t <sub>RLAZ</sub>  | Address float after XRD $\downarrow^{20}$             |     | 0       | ns   |
| t <sub>AVSDL</sub> | Address valid to <code>XCSDATA</code> $\downarrow$    | 3   | 15      | ns   |

(C<sub>L</sub> for Port A = 120pF; C<sub>L</sub> for XPSEN = 10pF; C<sub>L</sub> for all others = 80pF)

 Table 9.5-14: Timing Values for Emulator Accesses to Data Memory

<sup>&</sup>lt;sup>20</sup> After this time, the output driver of the DPC31 is switched off. The signal level on the bus depends on the bus load and the size of the pull-up resistors.



Figure 9.5-16: Emulator Data Read-Cycle



Figure 9.5-17: Emulator Data Write Cycle

PA (=data bus) of DPC31 is only active if

- Access is to the internal register or the area of the multiport RAM,
- In this case, XCSDATA = konst. = 1

### 9.5.2.8 SSC Interface (SPI)

| Symbol             | Parameters                                  | Min  | Max | Unit |
|--------------------|---------------------------------------------|------|-----|------|
| f <sub>SSCLK</sub> | Operating Frequency                         |      | 12  | MHz  |
| t <sub>CYC</sub>   | Cycle Time                                  | 83,3 |     | ns   |
| t <sub>WH</sub>    | Clock High Time                             | 40   |     | ns   |
| t <sub>WL</sub>    | Clock Low Time                              | 40   |     | ns   |
| t <sub>SU</sub>    | Data Setup Time (Inputs)                    |      | 28  | ns   |
| t <sub>H</sub>     | Data Hold Time (Inputs)                     | 0    |     | ns   |
| t <sub>V</sub>     | Data Valid Time after Enable Edge           |      | 1,0 | ns   |
| t <sub>HO</sub>    | Data Hold Time (Outputs, after Enable Edge) | -1,0 |     | ns   |

#### Table 9.5-15: Timing Values of the SSC Interface



Figure 9.5-18: SSC Interface Timing Diagram

## **10 Mechanical Specification**

### 10.1 PQFP 100 Casing

100 pin plastic QFP (14 x 20) pin pitch = 0.65mm (NEC CODE: S100GF-65-JBT)





Figure 10.1-1: QFP-100 Housing



Figure 10.1-2: Detail A on Housing

DPC31 HW

| ANAM 1.6 P/N 31767 |           |        |       |  |
|--------------------|-----------|--------|-------|--|
| SYMBOL             | MIN       | NOM    | MAX   |  |
| A                  | _         | 3.04   | 3.40  |  |
| A1                 | 0.25      | 0.33   | _     |  |
| A2                 | 2.57      | 2.71   | 2.87  |  |
| D                  | 22.95     | 23.20  | 23.45 |  |
| D1                 | 19.90     | 20.00  | 20.10 |  |
| E                  | 16.95     | 17.20  | 17.45 |  |
| E1                 | 13.90     | 14.00  | 14.10 |  |
| L                  | 0.65      | 0.70   | 0.95  |  |
| е                  | 0         | .65 BS | С     |  |
| В                  | 0.22      | -      | 0.38  |  |
| С                  | 0.13      | _      | 0.23  |  |
| α                  | 12        | -      | 16    |  |
| β                  | 0         | —      | 7     |  |
| $\gamma^{\circ}$   | Û         | _      | _     |  |
| G                  | 0.13      |        | -     |  |
| Н                  | 1.60 REF. |        |       |  |
| L                  | —         | 0.30   | _     |  |
| К                  | 0.40      | —      | _     |  |
| 2H                 |           | 3.2    |       |  |

Table 10.1-1: Dimensions of PQFP Housing of AMI (in mm)

## 11 DPC31 Pinout

| Pin | Name            | Тур    | Remarks       | Pin | Name                 | Тур    | Remarks          |
|-----|-----------------|--------|---------------|-----|----------------------|--------|------------------|
| 1   | GND             | Supply |               | 51  | PA <sub>7</sub>      | In/Out | 4mA              |
| 2   | VDD             | Supply |               | 52  | VDD                  | Supply |                  |
| 3   | NTEST1          | In     |               | 53  | GND                  | Supply |                  |
| 4   | NTEST2          | In     |               | 54  | PB <sub>0</sub>      | In/Out | 4mA              |
| 5   | TST1            | In     |               | 55  | PB <sub>1</sub>      | In/Out | 4mA              |
| 6   | RESET           | In     | Schmitt-Trig. | 56  | PB <sub>2</sub>      | In/Out | 4mA              |
| 7   | AGND            | Supply |               | 57  | PB <sub>3</sub>      | In/Out | 4mA              |
| 8   | AVDD            | Supply |               | 58  | PB <sub>4</sub>      | In/Out | 4mA              |
| 9   | GND             | Supply |               | 59  | PB <sub>5</sub>      | In/Out | 4mA              |
| 10  | PE <sub>0</sub> | In/Out | 9mA           | 60  | PB <sub>6</sub>      | In/Out | 4mA              |
| 11  | PE <sub>1</sub> | In/Out | 9mA           | 61  | PB <sub>7</sub>      | In/Out | 4mA              |
| 12  | PE <sub>2</sub> | In/Out | 9mA           | 62  | GND                  | Supply |                  |
| 13  | PE <sub>3</sub> | In/Out | 9mA           | 63  | PC <sub>0</sub>      | In/Out | 4mA              |
| 14  | PE <sub>4</sub> | In/Out | 9mA           | 64  | PC <sub>1</sub>      | In/Out | 4mA              |
| 15  | PE₅             | In/Out | 9mA           | 65  | PC <sub>2</sub>      | In/Out | 4mA              |
| 16  | PE <sub>6</sub> | In/Out | 9mA           | 66  | PC <sub>3</sub>      | In/Out | 4mA              |
| 17  | PE <sub>7</sub> | In/Out | 9mA           | 67  | PC <sub>4</sub>      | In/Out | 4mA              |
| 18  | PF <sub>0</sub> | In/Out | 3mA           | 68  | PC₅                  | In/Out | 4mA              |
| 19  | PF <sub>1</sub> | In/Out | 3mA           | 69  | PC <sub>6</sub>      | In/Out | 4mA              |
| 20  | PF <sub>2</sub> | In/Out | 3mA           | 70  | PC <sub>7</sub>      | In/Out | 4mA              |
| 21  | PF₃             | In/Out | 3mA           | 71  | PD <sub>0</sub>      | In/Out | 4mA              |
| 22  | PF <sub>4</sub> | In/Out | 3mA           | 72  | PD <sub>1</sub>      | In/Out | 4mA              |
| 23  | PF₅             | In/Out | 3mA           | 73  | PD <sub>2</sub>      | In/Out | 4mA              |
| 24  | PF <sub>6</sub> | In/Out | 3mA           | 74  | PD <sub>3</sub>      | In/Out | 4mA              |
| 25  | PF <sub>7</sub> | In/Out | 3mA           | 75  | PD <sub>4</sub>      | In/Out | 4mA              |
| 26  | PG <sub>0</sub> | In/Out | 3mA           | 76  | PD₅                  | In/Out | 4mA              |
| 27  | PG <sub>1</sub> | In/Out | 3mA           | 77  | PD <sub>6</sub>      | In/Out | 4mA              |
| 28  | GND             | Supply |               | 78  | PD <sub>7</sub>      | In/Out | 4mA              |
| 29  | VDD             | Supply |               | 79  | VDD                  | Supply |                  |
| 30  | PG <sub>2</sub> | In/Out | 3mA           | 80  | GND                  | Supply |                  |
| 31  | PG <sub>3</sub> | In/Out | 3mA           | 81  | BOOTTYP <sub>0</sub> | In     |                  |
| 32  | PG <sub>4</sub> | In/Out | 3mA           | 82  | BOOTTYP <sub>1</sub> | In     |                  |
| 33  | PG₅             | In/Out | 3mA           | 83  | DBX                  | In     |                  |
| 34  | PG <sub>6</sub> | In/Out | 3mA           | 84  | BUSTYP <sub>0</sub>  | In     |                  |
| 35  | PG <sub>7</sub> | In/Out | 3mA           | 85  | BUSTYP1              | In     |                  |
| 36  | PH₀             | In/Out | 3mA           | 86  | BUSTYP <sub>2</sub>  | In     |                  |
| 37  | PH <sub>1</sub> | In/Out | 3mA           | 87  | RXD_RXS              | In     | Schmitt-Trig.    |
| 38  | PH <sub>2</sub> | In/Out | 3mA           | 88  | XCTS_RXA             | In     | Schmitt-Trig.    |
| 39  | XCSDATA         | Out    | 3mA           | 89  | XPLLEN               | In     |                  |
| 40  | GND             | Supply |               | 90  | SSDI                 | In     |                  |
| 41  | XCSCODE         | Out    | 3mA           | 91  | GND                  | Supply |                  |
| 42  | XPSEN           | In/Out | 3mA           | 92  | SSCLK                | Out    | 8mA              |
| 43  | ALE             | In/Out | 3mA           | 93  | SSDO                 | Out    | 8mA              |
| 44  | PA <sub>0</sub> | In/Out | 3mA           | 94  | CLKOUT1X4            | Out    | 8mA              |
| 45  | PA <sub>1</sub> | In/Out | 3mA           | 95  | TXD_TXS              | Out    | 8mA, <b>3.3V</b> |
| 46  | PA <sub>2</sub> | In/Out | 3mA           | 96  | RTS_TXE              | Out    | 8mA, <b>3.3V</b> |
| 47  | PA <sub>3</sub> | In/Out | 3mA           | 97  | GND                  | Supply |                  |
| 48  | PA <sub>4</sub> | In/Out | 3mA           | 98  | XTAL1_CLK            | In     |                  |
| 49  | PA <sub>5</sub> | In/Out | 3mA           | 99  | XTAL2                | Out    |                  |
| 50  | PA <sub>6</sub> | In/Out | 3mA           | 100 | CLKOUT1X2            | Out    | 8mA              |

Table 11-1: Pin Assignment of the QFP-100 Casing (signals starting with 'X' are low active)

## **12 Application Notes**

## 12.1 DPC31 Wiring



## 12.2 PROFIBUS Interface

### 12.2.1 Pin Assignment

Data is transmitted in the operating mode RS485 (RS485 physics). The DPC31 is connected to the galvanically isolated interface driver via the following signals:

| Signal Name | Input/<br>Output | Function        |
|-------------|------------------|-----------------|
| RTS         | Output           | Request to Send |
| TXD         | Output           | Send Data       |
| RXD         | Input            | Receive Data    |

The PROFIBUS interface is implemented as 9-pole SUB D connector with the following pin assignment:

Pin 1 - free Pin 2 - free Pin 3 - B line

Pin 4 - Request to Send (RTS)

Pin 5 - Ground 5V (M5)

Pin 6 - Potential 5V (potential free P5)

Pin 7 - free Pin 8 - A line

Pin 9 - free

The line shield is to be connected to the connector housing.

The free pins are used optionally in the EN 50170 Vol.2 and should correspond to this description if the user uses them.

### Attention:

The designations  $\bf{A}$  and  $\bf{B}$  for the lines at the connector correspond to the names in the RS485 standard and not to the pin name of driver ICs.

The line length from the driver to the connector is to be kept as short as possible.

If the higher baudrates of 3 to 12 MBaud are used, suitable connectors are to be used. These connectors compensate for line influences regarding all possible line combinations.

#### 12.2.2 Optimizations of the bus cycle

For optimizations of the bus cycle the following adjustments of the max TSDR timings can be done in the GSD file.

| Transmission<br>rate (kbit/s) | 187.5 | 500 | 1500 | 3000 | 6000 | 12000 |
|-------------------------------|-------|-----|------|------|------|-------|
| Optimized<br>Max TSDR         | 15    | 15  | 25   | 50   | 100  | 200   |

### 12.2.2 Wiring Example RS485 Interface

**SIEMENS** 



#### Explanation of the Circuit:

At the bus driver 75ALS176D, the EN2 input is to be connected to ground so that the DPC31 can listen in during transmission.

No additional filters are to be installed in the send and receive line in order to keep the capacity of the lines as low as possible (15 .. 25 pF).

## **13 Appendix**

### 13.1 Addresses

PROFIBUS Trade Organization PNO Office Haid-und-Neu-Strasse 7 76131 Karlsruhe/Germany Phone: (0721) 9658-590

**Technical Contact Persons at the Interface Center in Germany** Siemens AG A&D SE RD73 Mr. Putschky

Mailing Address: Postfach 2355 90713 Fuerth/Germany

Street Address: Wuerzburger Strasse 121 90766 Fuerth/Germany

Phone: (0911) 750 2078 Fax: (0911) 750 2100

EMail: Gerd.Putschky@siemens.com

### Technical Contact Persons at the Interface Center in the USA

PROFIBUS Interface Center One Internet Plaza Johnson City, TN 37602-4991

Fax: (423) 461-2103

Your Partner: Phone: (423) 461-2576

E-Mail: profibus.center@sea.siemens.com

### 13.2 General Definitions of Terms

ASPC2Advanced Siemens PROFIBUS Controller, 2nd GenerationDPSDP SlaveDinInput Data

| Dout  | Output Data                                                   |
|-------|---------------------------------------------------------------|
| MAC   | Medium Access Control                                         |
| MSAC1 | Master Slave Acyclic Communication Class1 Master              |
| SPC2  | Siemens PROFIBUS Controller, 2 <sup>nd</sup> Generation       |
| SPC3  | Siemens PROFIBUS Controller, 3rd Generation                   |
| SPM2  | Siemens PROFIBUS Multiplexer, 2 <sup>nd</sup> Generation      |
| LSPM2 | Lean Siemens PROFIBUS Multiplexer, 2 <sup>nd</sup> Generation |
| DP    | Distributed IO                                                |
| FMS   | Fieldbus Message Specification                                |
| MS    | Micro-Sequencer                                               |
| PLL   | Phase Lock Loop                                               |
| SM    | State Machine                                                 |
|       |                                                               |

### 13.3 Order Numbers

The DPC31 Step C can be ordered via your Siemens contact person on location. Please use the order numbers with the number of units reference provided below:

| Product                       | Order Number                                                                                                     | Delivery Units                                                     | No. of Units           |
|-------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|------------------------|
| ASIC DPC 31<br>FW DPV1 DPC 31 | 6ES7 195-0BF00-0XA0<br>6ES7 195-0BF10-0XA0<br>6ES7 195-0BF20-0XA0<br>6ES7 195-0BF301-0XA0<br>6ES7 195-2BB00-0XA0 | Mini Package.<br>Single Tray<br>Tray Box<br>7-Tray Box<br>Diskette | 6<br>66<br>660<br>4620 |
|                               |                                                                                                                  | Biolitette                                                         |                        |

Siemens AG Division Automation Engineering Combination Engineering PO Box 23 55, D-90713 Fuerth/Germany

© Siemens AG Subject to change without prior notice

SIEMENS Aktiengesellschaft

Printed in the Fed. Rep. of Germany Order No. J31070-E2257-R300-A1-0009