# SIMATIC NET SPC3 Siemens PROFIBUS Controller

Hardware Description

Date 2005/12/13

Achtung: nichts an Spaltengröße oder anderen Formatierungen ändern

# **SIEMENS**



#### Liability Exclusion

We have tested the contents of this document regarding agreement with the hardware and software described. Nevertheless, there may be deviations, and we don't guarantee complete agreement. The data in the document is tested periodically, however. Required corrections are included in subsequent versions. We gratefully accept suggestions for improvement

Copyright Copyright © Siemens AG 2003. All Rights Reserved.

Unless permission has been expressly granted, passing on this document or copying it, or using and sharing its content are 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.

Subject to technical changes.

# SIEMENS

# <u>Versions</u>

| Release | Date     | Changes                                                      |
|---------|----------|--------------------------------------------------------------|
| V 1.1   | 12/23/99 | Chapter 8.2 Current consumption without bus accesses         |
|         |          | Chapter 10.1 Contact persons                                 |
| V 1.2   | 09/25/02 | Included the specification of the different manufacturers in |
|         |          | Chap. 8.1, 8.3, 8.5 and 10.3 Order numbers                   |
|         |          | chap 10.1 contact persons                                    |
| V 1.3   | 2003/04  | Included the specification of the different manufacturers in |
|         |          | Chap. 8.1, 8.3, 8.5 and 10.3                                 |
| V 1.4   | 2005/12  | Order numbers for the lead free version                      |

| Directory                                                                           |          |
|-------------------------------------------------------------------------------------|----------|
| 1 INTRODUCTION                                                                      | 6        |
| 2 FUNCTION OVERVIEW                                                                 | 7        |
| 3 PIN DESCRIPTION                                                                   | 8        |
| 4 MEMORY ALLOCATION                                                                 | 10       |
| 4.1 Memory Area Distribution in the SPC3                                            | 10       |
| 4.2 Processor Parameters (Latches/Register)                                         | 12       |
| 4.3 Organizational Parameters (RAM)                                                 | 14       |
| 5 ASIC INTERFACE                                                                    | 15       |
| 5.1 Mode Register                                                                   | 15       |
| 5.1.1 Mode Register 0                                                               | 15       |
| 5.1.2 Mode Register 1 (Mode-REG1, writable):                                        | 17       |
| 5.2 Status Register                                                                 | 18       |
| 5.3 Interrupt Controller                                                            | 20       |
| 5.4 Watchdog Timer                                                                  | 23       |
| 5.4.1 Automatic Baud Rate Identification<br>5.4.2 Baud Rate Monitoring              | 23<br>23 |
| <ul><li>5.4.2 Baud Rate Monitoring</li><li>5.4.3 Response Time Monitoring</li></ul> | 23       |
| 6 PROFIBUS-DP INTERFACE                                                             | 24       |
| 6.1 DP_Buffer Structure                                                             | 24       |
| 6.2 Description of the DP Services                                                  | 27       |
| 6.2.1 Set_Slave_Address (SAP55)                                                     | 27       |
| 6.2.2 Set_Param (SAP61)                                                             | 28       |
| 6.2.3 Check_Config (SAP62)<br>6.2.4 Slave_Diagnosis (SAP60)                         | 29<br>30 |
| 6.2.5 Write_Read_Data / Data_Exchange (Default_SAP)                                 | 30       |
| 6.2.6 Global_Control (SAP58)                                                        | 33       |
| 6.2.7 Read_Inputs (SAP56)                                                           | 34       |
| 6.2.8 Read_Outputs (SAP57)<br>6.2.9 Get_Config (SAP59)                              | 34<br>34 |
| 7 HARDWARE INTERFACE                                                                | 35       |
| 7.1 Universal Processor Bus Interface                                               | 35       |
| <ul><li>7.1.1 General Description</li><li>7.1.2 Bus Interface Unit (BIU)</li></ul>  | 35<br>35 |
| 7.1.2 Switching Diagram Principles                                                  | 35<br>37 |
| 7.1.4 Application with the 80 C 32                                                  | 39       |
| 7.1.5 Application with th 80 C 165                                                  | 40       |
| 7.1.6 Interface Signals                                                             | 41       |

### SPC3 Hardware Description

# **SIEMENS**

| 7.2 UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 41                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| 7.3 ASIC Test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 41                                                  |
| 8 TECHNICAL DATA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 42                                                  |
| 8.1 Maximum Limit Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 42                                                  |
| 8.2 Permitted Operating Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 42                                                  |
| 8.3 DC-Specifikation of the I/O- Drivers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 42                                                  |
| 8.4 AC-Specification for the Output Drivers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 43                                                  |
| <ul> <li>8.5 Timing Characteristics</li> <li>8.5.1 SYS Bus Interface</li> <li>8.5.2 Timing in the Synchronous C32-Mode:</li> <li>8.5.3 Timing in the Asynchronous Intel Mode (X86 Mode) :</li> <li>8.5.4 Timing in the Synchronous Motorola Mode (E_Clock-Mode, for example, 68HC11) :</li> <li>8.5.5 Timing in the Asynchronous Motorola-Mode (for example, 68HC16) :</li> <li>8.5.6 Serial Bus Interface</li> <li>8.5.7 Housing</li> <li>8.5.8 Processing Instructions</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>44</b><br>45<br>47<br>48<br>50<br>52<br>53<br>54 |
| 9 PROFIBUS INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 55                                                  |
| 9.1 Pin Assignment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 55                                                  |
| 9.2 Example for the RS 485 Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 56                                                  |
| 10 APPENDIX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 57                                                  |
| 10.1 Addresses                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 57                                                  |
| 10.2 General Definition of Terms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 58                                                  |
| <b>10.3 Ordering of ASICs</b><br>10.3.1 SPC3 (AMI)<br>10.3.2 SPC3 (ST)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | <b>58</b><br>58<br>58                               |
| 11 APPENDIX A: DIAGNOSTICS PROCESSING IN PROFIBUS DP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 59                                                  |
| 11.1 Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 59                                                  |
| <ul> <li>11.2 Diagnostics Bits and Expanded Diagnostics</li> <li>11.2.1 STAT_DIAG</li> <li>11.2.2 EXT_DIAG</li> <li>11.2.3 EXT_DIAG_OVERFLOW</li> <li>11.3 Diagnostics Processing from the System View</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>59</b><br>59<br>61<br><b>61</b>                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                     |
| 8.5       Timing Characteristics       44         8.5.1       SYS Bus Interface       44         8.5.2       Timing in the Synchronous C32-Mode:       45         8.5.3       Timing in the Synchronous Motorola Mode (E_Clock-Mode, for example, 68HC11):       47         8.5.5       Timing in the Synchronous Motorola-Mode (for example, 68HC16):       50         8.5.6       Serial Bus Interface       52         8.5.7       Housing       53         8.5.8       Processing Instructions       54         9.1       Pin Assignment       55         9.2       Example for the RS 485 Interface       56         9.1       Addresses       57         10.1       Addresses       57         10.2       General Definition of Terms       58         10.3       Ordering of ASICs       58         10.3.1       SPC3 (AMI)       58         10.3.2       SPC3 (ST)       58         11.1       Introduction       59         11.2.1       STA TDIAG       59         11.2.1       STA TDIAG       59         11.2.3       EXT_DIAG       59         11.2.3       EXT_DIAG       59         11.3       Diagnostics |                                                     |

SPC3

# 1 Introduction

For simple and fast digital exchange between programmable logic controllers, Siemens offers its users several ASICs. These ASICs are based on and are completely handled on the principles of the EN 50170 Vol. 2, of data traffic between individual programmable logic controller stations.

The following ASICs are available to support intelligent slave solutions, that is, implementations with a microprocessor.

The **ASPC2** already has integrated many parts of Layer 2, but the **ASPC2** also requires a processor's support. This ASIC supports baud rates up to 12 Mbaud. In its complexity, this ASIC is conceived primarily for master applications.

Due to the integration of the complete PROFIBUS-DP protocol, the **SPC3** decisively relieves the processor of an intelligent PROFIBUS slave. The **SPC3** can be operated on the bus with a baud rate of up to 12 MBaud.

However, there are also simple devices in the automation engineering area, such as switches and thermoelements, that do not require a microprocessor to record their states.

There are two additional ASICs available with the designations **SPM2** (Siemens Profibus Multiplexer, Version 2) and **LSPM2** (Lean Siemens PROFIBUS Multiplexer) for an economical adaptation of these devices. These blocks work as a DP slave in the bus system (according to DIN E 19245 T3) and work with baud rates up to 12 Mbaud. A master addresses these blocks by means of Layer 2 of the 7 layer model. After these blocks have received an error-free telegram, they independently generate the required response telegrams.

The LSPM2 has the same functions as the SPM2, but the LSPM2 has a decreased number of I/O ports and diagnostics ports.

# 2 Function Overview

The SPC3 makes it possible to have a price-optimized configuration of intelligent PROFIBUS-DP slave applications.

The processor interface supports the following processors:

 Intel:
 80C31, 80X86

 Siemens:
 80C166/165/167

 Motorola:
 HC11-,HC16-,HC916 types

In SPC3, the transfer technology is integrated (Layer 1), except for analog functions (RS485 drivers), the FDL transfer protocol (Fieldbus Data Link) for slave nodes (Layer 2a), a support of the interface utilities (Layer 2b), some Layer 2 FMA utilities, and the complete DP slave protocol (USIF: User Interface, which makes it possible for the user to have access to Layer 2). The remaining functions of Layer 2 (software utilities and management) must be handled via software.

The **integrated 1.5k Dual-Port-RAM** serves as an interface between the SPC3 and the software/application. The entire memory is subdivided into 192 segments, with 8 bytes each. Addressing from the user takes place directly and from the internal microsequencer (MS) by means of the so-alled base pointer. The base-pointer can be positioned at any segment in the memory. Therefore, all buffers must always be located at the beginning of a segment.

If the SPC3 carries out a DP communication the SPC3 automatically sets up all DP-SAPs. The various telegram information is made available to the user in separate data buffers (for example, parameter setting data and configuration data). Three change buffers are provided for data communication, both for the output data and for the input data. A change buffer is always available for communication. Therefore, no resource problems can occur. For optimal diagnostics support, SPC3 has two diagnostics change buffers into which the user inputs the updated diagnostics data. One diagnostics buffer is always assigned to SPC3 in this process.

The **bus interface** is a parameterizable synchronous/asynchronous 8-bit interface for various Intel and Motorola microcontrollers/processors. The user can directly access the internal 1.5k RAM or the parameter latches via the 11-bit address bus.

After the processor has been switched on, procedural-specific parameters (station address, control bits, etc.) must be transferred to the **Parameter Register File** and to the **mode registers**.

The MAC status can be scanned at any time in the status register.

Various events (various indications, error events, etc.) are entered in the **interrupt controller**. These events can be individually enabled via a mask register. Acknowledgement takes place by means of the acknowledge register. The SPC3 has a common interrupt output.

The integrated **Watchdog Timer** is operated in three different states: 'Baud\_Search', 'Baud\_Control,' and 'DP\_Control'.

The Micro Sequencer (MS) controls the entire process.

Procedure-specific parameters (buffer pointer, buffer lengths, station address, etc.) and the data buffer are contained in the integrated **1.5kByte RAM** that a controller operates as Dual-Port-RAM.

In **UART**, the parallel data flow is converted into the serial data flow, or vice-versa. The SPC3 is capable of automatically identifying the baud rates (9.6 kBd - 12 MBd).

The **Idle Timer** directly controls the bus times on the serial bus cable.

# SIEMENS

# 3 Pin Description

The SPC3 has a 44-pin PQFP housing with the following signals:

| Pin      | Signal Name   | In/Out   | Description                                                         |                    | Source / Destination                                                         |                       |
|----------|---------------|----------|---------------------------------------------------------------------|--------------------|------------------------------------------------------------------------------|-----------------------|
| 1        | XCS           | I©       | Chip-Select                                                         | C32 Mod            |                                                                              |                       |
|          |               |          | •                                                                   | C165 Mo            | CPU (80C165)                                                                 |                       |
| 2        | XWR/E_Clock   | l©       | Write signal /EI_Cloc                                               |                    |                                                                              | CPU                   |
| 3        | DIVIDER       | I©       | Setting the scaler factors low potential means of                   |                    |                                                                              |                       |
| 4        | XRD/R_W       | I©       | Read signal / Read_V                                                |                    |                                                                              | CPU                   |
| 5        | CLK           | I(TS)    | Clock pulse input                                                   |                    |                                                                              | System                |
| 6        | VSS           |          |                                                                     |                    |                                                                              |                       |
| 7        | CLKOUT2/4     | 0        | Clock pulse divided b                                               |                    |                                                                              | System, CPU           |
| 8        | XINT/MOT      | I©       | <log> 0 = Intel interfa<br/><log> 1 = Motorola in</log></log>       |                    |                                                                              | System                |
| 9        | X/INT         | 0        | Interrupt                                                           |                    |                                                                              | CPU, Interrupt-Contr. |
| 10       | AB10          | I(CPD)   | Address bus                                                         |                    | C32 mode: <log> 0<br/>C165 mode: address bus</log>                           |                       |
| 11       | DB0           | I©/O     | Data bus                                                            | C32 Mod            | e: Data/address bus multiplexed                                              | CPU, memory           |
| 12       | DB1           | I©/O     |                                                                     |                    | de: Data/address bus separated                                               |                       |
| 13       | XDATAEXCH     | 0        | Data_Exchange state                                                 | ofor PROF          | IBUS-DP                                                                      | LED                   |
| 14       | XREADY/XDTACK | 0        | Ready for external CF                                               | <u>י</u> ט         |                                                                              | System, CPU           |
| 15       | DB2           | I©/O     | Data bus                                                            |                    | C32 mode: data bus/address<br>bus multiplexed<br>C165 mode: data/address bus | CPU, memory           |
| 16       | DB3           | I©/O     |                                                                     |                    |                                                                              |                       |
| 17       | VSS           |          |                                                                     |                    |                                                                              |                       |
| 18       | VDD           |          |                                                                     |                    |                                                                              |                       |
| 19       | DB4           | I©/O     | Data bus                                                            |                    |                                                                              |                       |
| 20       | DB5           | I©/O     |                                                                     | CPU, memory        |                                                                              |                       |
| 21       | DB6           | I©/O     |                                                                     |                    |                                                                              |                       |
| 22       | DB7           | I©/O     |                                                                     |                    |                                                                              |                       |
| 23       | MODE          | I        | <li>log&gt; 0 = 80C166 Da<br/><log> 1 = 80C32<br/>timing</log></li> | System             |                                                                              |                       |
| 24       | ALE/AS        | I©       | Address latch enable                                                | C32 mod<br>C165 mo | e: ALE<br>de: <log> 0</log>                                                  | CPU (80C32)           |
| 25       | AB9           | I        | Address bus                                                         |                    | e: <log> 0<br/>de: address bus</log>                                         | CPU (C165), memory    |
| 26       | TXD           | 0        | Serial send port                                                    |                    |                                                                              | RS 485 sender         |
| 27       | RTS           | 0        | Request to Send                                                     |                    |                                                                              | RS 485 sender         |
| 28       | VSS           |          |                                                                     |                    |                                                                              |                       |
| 29       | AB8           | I©       | Address bus                                                         |                    | e: <log> 0<br/>de:address bus</log>                                          |                       |
| 30       | RXD           | I©       | Serial receive port                                                 |                    |                                                                              | RS 485 receiver       |
| 31       | AB7           | l©       | Address bus                                                         |                    |                                                                              | System, CPU           |
| 32       | AB6           | l©       | Address bus                                                         |                    |                                                                              | System, CPU           |
| 33       | XCTS          | I©       | Clear to send <log></log>                                           |                    | FSK modem                                                                    |                       |
| 34       | XTEST0        | I©       | Pin must be placed fit                                              |                    |                                                                              |                       |
| 35       | XTEST1        | I©       | Pin must be placed fit                                              |                    |                                                                              |                       |
| 36       | RESET         | I(CS)    | Connect reset input w                                               | vith CPU's         |                                                                              |                       |
| 37       | AB4           | I©       | Address bus                                                         |                    | System, CPU                                                                  |                       |
| 38       | VSS           |          |                                                                     |                    |                                                                              |                       |
| 39       | VDD           |          |                                                                     |                    |                                                                              |                       |
| 40       | AB3           | I©       | Addroop hus                                                         |                    |                                                                              | Sustem CDU            |
| 41       | AB2           | IC<br>IC | Address bus                                                         |                    |                                                                              | System, CPU           |
| 42       | AB5<br>AB1    | IC<br>IC | Address bus                                                         |                    |                                                                              | System, CPU           |
| 43<br>44 |               | IC       | Address bus                                                         |                    |                                                                              | System, CFU           |
| 44       | AB0           | IU IU    |                                                                     |                    |                                                                              |                       |

Figure 3.1: SPC3 Pin Assignment

- **Note:** All signals that begin with X.. are LOW active
  - VDD = +5V, VSS = GND

Input levels: I ©:

CMOS

| I (CS):  | CMOS Schmitt trigger |  |
|----------|----------------------|--|
| I (CPD): | CMOS with pull down  |  |
| I (TS):  | TTLt Schmitt trigger |  |

# 4 Memory Allocation

### 4.1 Memory Area Distribution in the SPC3

The figure displays the division of the SPC3 1.5k internal address area.

The internal latches/register are located in the first 21 addresses. The internal latches/register either come from the controller or influence the controller. Certain cells can be only read or written. The internal work cells to which the user has no access are located in RAM at the same addresses.

The organizational parameters are located in RAM beginning with address 16H. The entire buffer structure (for the DP-SAPS) is written based on these parameters. In addition, general parameter setting data (station address, Ident no., etc.) are transferred in these cells and the status displays are stored in these cells (global control command, etc.).

Corresponding to the parameter setting of the organizational parameters, the user-generated buffers are located beginning with address 40H. All buffers or lists must begin at segment addresses (48 bytes segmentation).

| Address | Function                                          |                                                                                               |                     |  |  |  |  |
|---------|---------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------|--|--|--|--|
| 000H    | Processor parar<br>Latches/register<br>(22 bytes) |                                                                                               | internal work cells |  |  |  |  |
| 016H    | Organizational<br>parameters<br>(42 bytes)        | parameters                                                                                    |                     |  |  |  |  |
| 040H    | DP- buffer:                                       | DP- buffer: Data In (3) *<br>Data Out (3) *<br>Diagnostics (2)                                |                     |  |  |  |  |
| 5FFH    |                                                   | Parameter setting data (1)<br>Configuration data (2)<br>Auxiliary buffer (2)<br>SSA-buffer(1) |                     |  |  |  |  |

Figure 4.1: SPC3 Memory Area Distribution

### Caution:

The HW prohibits overranging the address area. That is, if a user writes or reads past the memory end, 400H is subtracted from this address and the user therefore accesses a new address. This prohibits overwriting a process parameter. In this case, the SPC3 generates the RAM access violation interrupt. If the MS overranges the memory end due to a faulty buffer initialization, the same procedure is executed.

\* Data In is the input data from PROFIBUS slave to master Data out is the output data from PROFIBUS master to slave

# SIEMENS

The complete internal RAM of the SPC 3 is divided logically into 192 segments. Each segment consists of 8 bytes. For more informations about the contents of the 3 memory areas see previous chapter. The physical address is build by multiplikation with 8.



### 4.2 Processor Parameters (Latches/Register)

These cells can be either read only or written only. SPC3 carries out "address swapping" for an access to the address area 00H - 07H (word register) in the Motorola mode. That is, the SPC3 exchanges

address bit 0 (generated from an even address, one uneven, and vice-versa). The following sections more clearly explain the significance of the individual registers.

| Addr         | ess                          | Name B                | Bit No. | Significance (Read Access!)                         |
|--------------|------------------------------|-----------------------|---------|-----------------------------------------------------|
| Intel / I    | Motorla                      |                       |         |                                                     |
| 00H          | 01H                          | Int-Req-Reg           | 70      | Interrupt Controller Register                       |
| 01H          | 00H                          | Int-Req-Reg           | 158     |                                                     |
| 02H          | 03H                          | Int—Reg               | 70      |                                                     |
| 03H          | 02H                          | Int—Reg               | 158     |                                                     |
| 04H          | 05H                          | Status-Reg            | 70      | Status Register                                     |
| 05H          | 04H                          | Status-Reg            | 158     |                                                     |
| 06H          | 07H                          | Reserved              |         |                                                     |
| 07H          | 06H                          |                       |         |                                                     |
| 08           | 3H                           | DIN_Buffer_SM         |         | Buffer assignment of the                            |
|              |                              | 70                    |         | DP_Din_Buffer_State_Machine                         |
| 09           | ЭH                           | New_DIN_Buffer_Cmd 10 |         | The user makes a new DP Din buffer available in the |
|              |                              |                       |         | N state.                                            |
| 0A           | λH                           | DOUT_Buffer_SM        | 70      | Buffer assignment of the                            |
|              |                              |                       |         | DP_Dout_Puffer_State_Machine                        |
| 0E           | ЗH                           | Next_DOUT_Buffer_Cmd  | 10      |                                                     |
|              |                              |                       |         | state.                                              |
| 00           | CH                           | DIAG_Buffer_SM        | 30      |                                                     |
|              |                              |                       |         | DP_Diag_Puffer_State_Machine                        |
| 0DH          |                              | New_DIAG_Puffer_Cmd   |         | The user makes a new DP Diag Buffer available to    |
|              |                              | 10                    |         | the SPC3.                                           |
| 0EH          |                              | User_Prm_Data_OK      | 10      |                                                     |
|              |                              |                       | 4.0     | parameter setting data of a Set_Param-Telegram.     |
| 0F           | ·H                           | UserPrmDataNOK        | 10      | 5 , 5                                               |
|              |                              |                       | 1.0     | parameter setting data of a Set_Param-Telegram.     |
| 10           | )H                           | User_Cfg_Data_OK      | 10      | The user positively acknowledges the configuration  |
|              |                              |                       | 1 0     | data of a Check_Config-Telegram.                    |
| 11           | 11H User_Cfg_Data_NOK        |                       | 10      | The user negatively acknowledges the configuration  |
| 4.0          | A011 Decerved                |                       |         | data of a Check_Config-Telegram.                    |
|              | 12H Reserved                 |                       |         |                                                     |
|              | 13H<br>14H SSA Bufferfreecmd |                       |         | The user has fetched the data from the SSA buffer   |
| 14           | HT I                         | SSA_Bufferfreecmd     |         |                                                     |
| 15H Reserved |                              | Deserved              |         | and enables the buffer again.                       |
| 15           | п                            | Reserved              |         |                                                     |

Figure 4.2: Assignment of the Internal Parameter Latches for READ

| Address<br>Intel |                     | Name              | Bit No. | Significance (Write Access !)          |  |  |  |  |  |
|------------------|---------------------|-------------------|---------|----------------------------------------|--|--|--|--|--|
| /Motoro          | la                  |                   |         |                                        |  |  |  |  |  |
| 00H              | 01H                 | Int-Req-Reg       | 70      | Interrupt- Controller - Register       |  |  |  |  |  |
| 01H              | 00H                 | Int-Req_Reg       | 158     |                                        |  |  |  |  |  |
| 02H              | 03H                 | Int-Ack-Reg       | 70      |                                        |  |  |  |  |  |
| 03H              | 02H                 | Int-Ack-Reg       | 158     |                                        |  |  |  |  |  |
| 04H              | 05H                 | Int-Mask-Reg      | 70      |                                        |  |  |  |  |  |
| 05H              | 04H                 | Int-Mask-Reg      | 158     |                                        |  |  |  |  |  |
| 06H              |                     |                   |         | Setting parameters for individual bits |  |  |  |  |  |
| 07H              | 07H 06H Mode-Reg0-S |                   |         |                                        |  |  |  |  |  |
| 08               | H                   | Mode-Reg1-S       | 70      |                                        |  |  |  |  |  |
| 09               | Н                   | Mode-Reg1-R 70    |         |                                        |  |  |  |  |  |
| 0A               | 'H                  | WD Baud Ctrl -Val | 70      | Root value for baud rate monitoring    |  |  |  |  |  |
|                  |                     |                   |         |                                        |  |  |  |  |  |
| 0B               | sН                  | MinTsdr_Val       | 70      | MinTsdr time                           |  |  |  |  |  |
| 00               | ЭН                  |                   |         |                                        |  |  |  |  |  |
| 00               | ЭH                  | Reserved          |         |                                        |  |  |  |  |  |
| 0E               | Η                   |                   |         |                                        |  |  |  |  |  |
| 0F               | Ή                   |                   |         |                                        |  |  |  |  |  |
| 10               | H                   |                   |         |                                        |  |  |  |  |  |
| 11H              |                     |                   |         |                                        |  |  |  |  |  |
| 12               | Η                   |                   |         |                                        |  |  |  |  |  |
| 13               | H                   |                   |         |                                        |  |  |  |  |  |
| 14               | H                   |                   |         |                                        |  |  |  |  |  |
| 15               | Н                   |                   |         |                                        |  |  |  |  |  |

Figure 4.3: Assignment of the Internal Parameter Latches for WRITE

# 4.3 Organizational Parameters (RAM)

The user stores the organizational parameters in RAM under the specified addresses. These parameters can be written and read.

| Address           | 3                                       | Name                         | Bit No. | Significance                                                   |  |  |  |  |
|-------------------|-----------------------------------------|------------------------------|---------|----------------------------------------------------------------|--|--|--|--|
| Intel<br>/Motorol |                                         |                              |         |                                                                |  |  |  |  |
| 16                |                                         | D TO Adr                     | 7.0     | Set up station address of the relevant SPC3                    |  |  |  |  |
| 10                |                                         | R_TS_Adr<br>reserved         | 70      | Pointer to a RAM address which is presetted with 0FFH          |  |  |  |  |
| 18H               | <u>п</u><br>19Н                         | R_User_Wd_Value              | 70      | Based on an internal 16-bit wachdog timer, the user is         |  |  |  |  |
| 1011              | 1911                                    |                              | 70      | monitored in the DP_Mode.                                      |  |  |  |  |
| 19H               | 18H                                     | R_User_Wd_Value              | 158     |                                                                |  |  |  |  |
| 14                |                                         | R Len Dout Puf               | 10      | Length of the 3 Dout buffers                                   |  |  |  |  |
| 1B                | SH                                      | R_Dout_buf_Ptr1              |         | Segment base address of Dout buffer 1                          |  |  |  |  |
| 1C                |                                         | R Dout buf Ptr2              |         | Segment base address of Dout buffer 2                          |  |  |  |  |
| 1D                |                                         | R_Dout_buf_Ptr3              |         | Segment base address of Dout buffer 3                          |  |  |  |  |
| 1E                |                                         | R_Len_Din_buf                |         | Length of the 3 Din buffers                                    |  |  |  |  |
| 1F                | Ή                                       | R_Din_buf_Ptr1               |         | Segment base address of Din buffer 1                           |  |  |  |  |
| 20                | H                                       | R Din buf Ptr2               |         | Segment base address of Din buffer 2                           |  |  |  |  |
| 21                | Н                                       | R_Din_buf_Ptr3               |         | Segment base address of Din buffer 3                           |  |  |  |  |
| 22                | H                                       | reserved                     |         | Preset with 00H.                                               |  |  |  |  |
| 23                | H                                       | reserved                     |         | Preset with 00H.                                               |  |  |  |  |
| 24H               |                                         | R Len Diag buf1              |         | Length of Diag buffer 1                                        |  |  |  |  |
| 25H               |                                         | R Len Diag buf2              |         | Length of Diag buffer 2                                        |  |  |  |  |
| 26H               |                                         | R_Diag_Puf_Ptr1              |         | Segment base address of Diag buffer 1                          |  |  |  |  |
| 27H               |                                         | R_Diag_Puf_Ptr2              |         | Segment base address of Diag buffer 2                          |  |  |  |  |
| 28H               |                                         | R Len Cntrl Pbuf1            |         | Length of Aux buffer 1 and the control buffer belonging to it, |  |  |  |  |
|                   |                                         |                              |         | for example, SSA-Buf, Prm-Buf, Cfg-Buf, Read-Cfg-Buf           |  |  |  |  |
| 29H               |                                         | R Len Cntrl Puf2             |         | Length of Aux-Buffer 2 and the control buffer belonging to it, |  |  |  |  |
|                   |                                         |                              |         | for example, SSA-Buf, Prm-Buf, Cfg-Buf, Read-Cfg-Buf           |  |  |  |  |
| 2AH               |                                         | R Aux Puf Sel                |         | Bit array, in which the assignments of the Aux-buffers ½ are   |  |  |  |  |
|                   |                                         |                              |         | defined to the control buffers, SSA-Buf, Prm-Buf, Cfg-Buf      |  |  |  |  |
| 2B                |                                         | R_Aux_buf_Ptr1               |         | Segment base address of auxiliary buffer 1                     |  |  |  |  |
| 2C                |                                         | R_Aux_buf_Ptr2               |         | Segment base address of auxiliary buffer 2                     |  |  |  |  |
| 2D                |                                         | R_Len_SSA_Data               |         | Length of the input data in the Set_Slave_Address-buffer       |  |  |  |  |
| 2E                |                                         | R SSA buf Ptr                |         | Segment base address of the Set_Slave_Address-buffer           |  |  |  |  |
| 2F                |                                         | R_Len_Prm_Data               |         | Length of the input data in the Set_Param-buffer               |  |  |  |  |
| 30                |                                         | R_Prm_buf_Ptr                |         | Segment base address of the Set_Param-buffer                   |  |  |  |  |
| 31                |                                         | R_Len_Cfg_Data               |         | Length of the input data in the Check_Config-buffer            |  |  |  |  |
| 32                |                                         | R Cfg Buf Ptr                |         | Segment base address of the Check_Config-buffer                |  |  |  |  |
| 33                |                                         | R_Len_Read_Cfg_E             |         | Length of the input data in the Get_Config-buffer              |  |  |  |  |
| 34<br>35          |                                         | R_Read_Cfg_buf_P             | u       | Segment base address of the Get_Config-buffer                  |  |  |  |  |
|                   |                                         | reserved                     |         | Preset with 00H                                                |  |  |  |  |
| 36                |                                         | reserved                     |         | Preset with 00H<br>Preset with 00H.                            |  |  |  |  |
|                   | 37H     reserved       38H     reserved |                              |         | Preset with 00H.                                               |  |  |  |  |
| 30                |                                         | reserved<br>R_Real_No_Add_Cl | ango    | This parameter specifies whether the DP slave address may      |  |  |  |  |
| 39                |                                         |                              | lange   | again be changed at a later time point.                        |  |  |  |  |
| 3AH R_Ident_Lo    |                                         | R_Ident_Low                  |         | The user sets the parameters for the Ident_Low value.          |  |  |  |  |
| 3B                |                                         | R_Ident_High                 |         | The user sets the parameters for the Ident_High value.         |  |  |  |  |
| 3C                |                                         | R_GC_Command                 |         | The Global Control Command last received                       |  |  |  |  |
| 3D                |                                         | R_Len_Spec_Prm_t             | ouf     | If parameters are set for the Spec_Prm_Buffer_Mode (see        |  |  |  |  |
|                   |                                         |                              |         | mode register 0), this cell defines the length of the param    |  |  |  |  |
|                   |                                         |                              |         | buffer.                                                        |  |  |  |  |

Figure 4.4: Assignment of the Organizational Parameters

# 5 ASIC Interface

The registers that determine both the hardware function of the ASIC as well as telegram processing are described in the following.

## 5.1 Mode Register

Parameter bits that access the controller directly or which the controller directly sets are combined in two mode registers (0 and 1) in the SPC3.

### 5.1.1 Mode Register 0

**Setting parameters for Mode Register 0 takes place in the offline state only** (for example, after switching on). The SPC3 may not exit *offline* until Mode Register 0, all processor parameters, and organizational parameters are loaded (START\_SPC3 = 1, Mode-Register 1).

| Address        |                           | Bit Position            |               |             |         |   |                              |                               |                 |  |  |  |
|----------------|---------------------------|-------------------------|---------------|-------------|---------|---|------------------------------|-------------------------------|-----------------|--|--|--|
| Control        | 7                         | 6                       | 5             | 4           | 3       | 2 | 1                            | 0                             |                 |  |  |  |
| Register       |                           |                         |               |             |         |   |                              |                               |                 |  |  |  |
| 06H<br>(Intel) | Freeze_<br>Support-<br>ed | Sync_<br>Support-<br>ed | EARLY_<br>RDY | INT_<br>POL | MinTSDR |   | DIS_<br>STOP_<br>CON<br>TROL | DIS_<br>START_<br>CON<br>TROL | Mode Reg0<br>70 |  |  |  |

| Address             |    | Bit Position |                           |                              |            |                      |                     |            |                   |  |  |
|---------------------|----|--------------|---------------------------|------------------------------|------------|----------------------|---------------------|------------|-------------------|--|--|
| Control<br>Register | 15 | 14           | 13                        | 12                           | 11         | 10                   | 9                   | 8          |                   |  |  |
| 07H<br>(Intel)      |    |              | Spec_Cle<br>ar_Mode<br>*) | Spec_Prm_<br>Puf_Mode<br>**) | WD<br>Test | User<br>Time<br>base | EOI<br>Time<br>base | DP<br>Mode | Mode-Reg0<br>13 8 |  |  |

\*) When Spec\_Clear\_Mode (Fail Safe Mode ) = 1 the SPC3 will accept data telegramm with a data unit=0 in the state Data Exchange. The reaction to the outputs can be parameterized f.e. in the parameterization telegram ( only available from version Step C).

\*\*) When using a big number of parameters to be transmitted from the PROFIBUS-Master to the slave the Auxiliary buffer ½ has to have the same size like the Parameterization buffer. Sometimes this could reach the limit of the available memory space in the SPC3. When Spec\_Prm\_Puf\_Mode = 1 the parameterization data are processed directly in this special buffer and the Auxiliary buffers can be held compact.



| Bit 0                                               | DIS_START_C                                                                                 | ONTROL                                                                                   |  |  |  |  |  |  |  |
|-----------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 2                                                   |                                                                                             | the following start bit in UART. Set-Param Telegram overwrites this memory cell in the   |  |  |  |  |  |  |  |
|                                                     |                                                                                             | (Refer to the user-specific data.)                                                       |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Monitoring the following start bit is enabled.                                           |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Monitoring the following start bit is switched off.                                      |  |  |  |  |  |  |  |
| Bit 1                                               | DIS_STOP_CO                                                                                 |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Stop bit monitoring in UART. Set-Param telegram overwrites this memory cell in the DP mode. |                                                                                          |  |  |  |  |  |  |  |
|                                                     | (Refer to the                                                                               | ne user-specific data.)                                                                  |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Stop bit monitoring is enabled.                                                          |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Stop bit monitoring is switched off.                                                     |  |  |  |  |  |  |  |
| Bit 2                                               | EN_FDL_DDB                                                                                  |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Reserved                                                                                    |                                                                                          |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | The FDL_DDB receive is disabled.                                                         |  |  |  |  |  |  |  |
| Bit 3                                               | MinTSDR                                                                                     |                                                                                          |  |  |  |  |  |  |  |
|                                                     |                                                                                             | ting for the MinTSDR after reset for DP operation or combi operation                     |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Pure DP operation (default configuration!)                                               |  |  |  |  |  |  |  |
| <b>D</b> <sup>1</sup> / <sub>1</sub> / <sub>1</sub> | 1 =                                                                                         | Combi operation                                                                          |  |  |  |  |  |  |  |
| Bit 4                                               | INT_POL                                                                                     |                                                                                          |  |  |  |  |  |  |  |
|                                                     |                                                                                             | the interrupt output                                                                     |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | The interrupt output is low-active.                                                      |  |  |  |  |  |  |  |
| D:4 C                                               |                                                                                             | The interrupt output is high-active.                                                     |  |  |  |  |  |  |  |
| Bit 5                                               | EARLY_RDY                                                                                   | ready signal                                                                             |  |  |  |  |  |  |  |
|                                                     |                                                                                             | ready signal                                                                             |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Ready is generated when the data are valid (read) or when the data are accepted (write). |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Ready is moved up by one clock pulse.                                                    |  |  |  |  |  |  |  |
| Bit 6                                               | Sync_Supported                                                                              |                                                                                          |  |  |  |  |  |  |  |
| DILO                                                | Sync_Mod                                                                                    |                                                                                          |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Sync_Mode is not supported.                                                              |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Sync_Mode is supported.                                                                  |  |  |  |  |  |  |  |
| Bit 7                                               | Freeze_Support                                                                              |                                                                                          |  |  |  |  |  |  |  |
|                                                     |                                                                                             | ode support                                                                              |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | Freeze_Mode is not supported.                                                            |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Freeze_Mode is supported.                                                                |  |  |  |  |  |  |  |
| Bit 8                                               | DP MODE                                                                                     |                                                                                          |  |  |  |  |  |  |  |
|                                                     | DP Mode                                                                                     | enable                                                                                   |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | DP_Mode is disabled.                                                                     |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | DP_Mode is enabled. SPC3 sets up all DP_SAPs.                                            |  |  |  |  |  |  |  |
| Bit 9                                               | EOI_Time base                                                                               |                                                                                          |  |  |  |  |  |  |  |
|                                                     |                                                                                             | for the end of interrupt pulse                                                           |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | The interrupt inactive time is at least 1 usec long.                                     |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | The interrupt inactive time is at least 1 ms long.                                       |  |  |  |  |  |  |  |
| Bit 10                                              | User_Time base                                                                              |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Time base                                                                                   | for the cyclical User_Time_Clock-Interrupt                                               |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | The User_Time_Clock-Interrupt occurs every 1 ms.                                         |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | The User_Time_Clock-Interrupt occurs every 10 ms.                                        |  |  |  |  |  |  |  |
| Bit 11                                              | WD_Test                                                                                     |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Test mode                                                                                   | for the Watchdog-Timer, no function mode                                                 |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | The WD runs in the function mode.                                                        |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Not permitted                                                                            |  |  |  |  |  |  |  |
| Bit 12                                              | Spec_Prm_Puf_                                                                               |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Special pa                                                                                  | rameter buffer                                                                           |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | No special parameter buffer.                                                             |  |  |  |  |  |  |  |
|                                                     | 1 =                                                                                         | Special parameter buffer mode .Parameterization data will be stored directly in the      |  |  |  |  |  |  |  |
|                                                     |                                                                                             | special parameter buffer.                                                                |  |  |  |  |  |  |  |
| Bit 13                                              | Spec_Clear_Mc                                                                               |                                                                                          |  |  |  |  |  |  |  |
|                                                     | Special Cl                                                                                  | ear Mode (Fail Safe Mode)                                                                |  |  |  |  |  |  |  |
|                                                     | 0 =                                                                                         | No special clear mode.                                                                   |  |  |  |  |  |  |  |
|                                                     |                                                                                             | Special clear mode. SPC3 will accept datea telegramms with data unit = 0.                |  |  |  |  |  |  |  |

Figure 5.1: Mode-Register 0 Bit 12 .. 0.(can be written to, can be changed in offline only)

### 5.1.2 Mode Register 1 (Mode-REG1, writable):

Some control bits must be changed during operation. These control bits are combined in Mode-Register 1 and can be set independently of each other (Mode\_Reg\_S) or can be deleted independently of each other (Mode\_Reg\_R). Various addresses are used for setting and deleting. Log '1' must be written to the bit position to be set or deleted.

| Address             |   | Bit Position |                 |                                  |                           |                |     |                |                  |  |
|---------------------|---|--------------|-----------------|----------------------------------|---------------------------|----------------|-----|----------------|------------------|--|
| Control<br>Register | 7 | 6            | 5               | 4                                | 3                         | 2              | 1   | 0              |                  |  |
| 08H                 |   |              | Res_<br>User_WD | EN_<br>Change_<br>Cfg_<br>Puffer | User_<br>Leave_<br>Master | Go_<br>Offline | EOI | START_<br>SPC3 | Mode-Reg_S<br>70 |  |
| 09H                 |   |              | Res_<br>User_WD | EN_<br>Change_<br>Cfg_<br>Puffer | User_<br>Leave_<br>Master | Go_<br>Offline | EOI | START_<br>SPC3 | Mode-Reg_R<br>70 |  |

|       | 1            |                                                                              |
|-------|--------------|------------------------------------------------------------------------------|
| Bit 0 | START_SPC3   |                                                                              |
|       | Exiting the  | e Offline state                                                              |
|       | 1 =          | SPC3 exits offline and goes to passive-idle. In addition, the idle timer and |
|       |              | Wd timer are started and 'Go_Offline = 0' is set.                            |
| Bit 1 | EOI          |                                                                              |
|       | End of Inte  | errupt                                                                       |
|       | 1 =          | End of Interrupt: SPC3 switches the interrupt outputs to inactive and again  |
|       |              | sets EOI to log.'0.'                                                         |
| Bit 2 | Go_Offline   |                                                                              |
|       | Going into   | the offline state                                                            |
|       | 1 =          | After the current requests ends, SPC3 goes to the offline state and again    |
|       |              | sets Go_Offline to log.'0.'                                                  |
| Bit 3 | User_Leave_N | laster                                                                       |
|       | Request to   | o the DP_SM to go to 'Wait_Prm.'                                             |
|       | 1 =          | The user causes the DP_SM to go to 'Wait_Prm.' After this action, SPC3       |
|       |              | sets User_Leave_Master to log.'0.'                                           |
| Bit 4 | En_Change_C  | fg_Puffer                                                                    |
|       | Enabling I   | puffer exchange (Cfg buffer for Read_Cfg buffer)                             |
|       | 0 =          | With 'User_Cfg_Data_Okay_Cmd,' the Cfg buffer may not be exchanged for       |
|       |              | the Read_Cfg buffer.                                                         |
|       | 1 =          | With 'User_Cfg_Data_Okay_Cmd,' the Cfg buffer must be exchanged for the      |
|       |              | Read_Cfg buffer.                                                             |
| Bit 5 | Res_User_Wd  |                                                                              |
|       | Resetting    | the User_WD_Timers                                                           |
|       | 1 =          |                                                                              |
|       |              | 'User_Wd_Value150.' After this action, SPC3 sets Res_User_Wd to log.'0.'     |

Figure 5..2: Mode Register1 S and Mode Register1 R Bit7..0.(writable)

15 .. 8

0

# 5.2 Status Register

3

2

1

(Intel)

The status register mirrors the current SPC3 status and can be read only.

| Address             |              | Bit Position |          |        |                            |               |                |                              |                  |
|---------------------|--------------|--------------|----------|--------|----------------------------|---------------|----------------|------------------------------|------------------|
| Control<br>Register | 7            | 6            | 5        | 4      | 3                          | 2             | 1              | 0                            |                  |
| 04H<br>(Intel)      | WD_State     |              | DP_State |        | RAM<br>access<br>violation | Diag_<br>Flag | FDL_<br>IND_ST | Offline/<br>Passive-<br>Idle | Status-Reg<br>70 |
|                     | 1            | 0            | 1        | 0      |                            |               |                |                              |                  |
| Address             |              |              |          | Bit Po | osition                    |               |                |                              | Designation      |
| Control<br>Register | 15           | 14           | 13       | 12     | 11                         | 10            | 9              | 8                            | 2 00.9.1000      |
| 05H                 | SPC3 Release |              |          |        |                            | Baud          | Rate           |                              | Status-Reg       |

3

2

1

0

| Bit 0       | Offline/Passive-Idle                                                         |
|-------------|------------------------------------------------------------------------------|
|             | Offline-/Passive-Idle state                                                  |
|             | 0 = SPC3 is in offline.                                                      |
|             | 1 = SPC3 is in passive idle.                                                 |
| Bit 1       | FDL_IND_ST                                                                   |
|             | FDL indication is temporarily buffered.                                      |
|             | 0 = No FDL indication is temporarily buffered.                               |
|             | 1 = No FDL indication is temporarily buffered.                               |
| Bit 2       | Diag_Flag                                                                    |
|             | Status diagnostics buffer                                                    |
|             |                                                                              |
|             | 0 = The DP master fetches the diagnostics buffer.                            |
| DV 0        | 1 = The DP master has not yet fetched the diagnostics buffer.                |
| Bit 3       | RAM Access Violation                                                         |
|             | Memory access > 1.5kByte                                                     |
|             | 0 = No address violation                                                     |
|             | 1 = For addresses > 1536 bytes, 1024 is subtracted from the current address, |
|             | and there is access to this new address.                                     |
| Bits<br>4,5 | DP-State10                                                                   |
|             | DP-State Machine state                                                       |
|             | 00 = 'Wait_Prm' state                                                        |
|             | 01= 'Wait_Cfg' state                                                         |
|             | 10 = 'DATA EX' state                                                         |
|             | 11= Not possible                                                             |
| Bits<br>6,7 | WD-State10                                                                   |
| 0,1         | Watchdog-State-Machine state                                                 |
|             | $00 = $ 'Baud_Search' state                                                  |
|             | $00 = Baud_Search state$<br>$01 = Baud_Control' state$                       |
|             | 10 = 'DP Control' state                                                      |
|             | 11= Not possible                                                             |
| D'L.        |                                                                              |
| Bits        | Baud rateso:                                                                 |
| 8,9         |                                                                              |
| 10,11       | The baud rates SPC3 found                                                    |
|             | 0000 = 12 MBaud                                                              |
|             | 0001 = 6 MBaud                                                               |
|             | 0010 = 3 MBaud                                                               |
|             | 0011 = 1.5 MBaud                                                             |
|             | 0100 = 500 kBaud                                                             |
|             | 0101 = 187.5 kBaud                                                           |
|             | 0110 = 93.75 kBaud                                                           |
|             | 0111 = 45.45 kBaud                                                           |
|             | 1000 = 19.2 kBaud                                                            |
|             | 1001 = 9.6 kBaud                                                             |
|             | Rest = Not possible                                                          |
| Bit 12      | SPC3-Release30:                                                              |
| 13,14,      | Release no. for SPC3                                                         |
| 15,11,      | 0000 = Release  0                                                            |
|             | Rest = Not possible                                                          |
| 1           |                                                                              |

Figure 5.3: Status Register Bit15 .. 0.(readable)

### 5.3 Interrupt Controller

The processor is informed about indication messages and various error events via the interrupt controller. Up to a total of 16 events are stored in the interrupt controller. The events are carried out on an interrupt output. The controller does not have a prioritization level and does not provide an interrupt vector (not 8259A compatible!).

The controller consists of an Interrupt Request Register (IRR), an Interrupt Mask Register (IMR), an Interrupt Register (IR), and an Interrupt Acknowledge Register (IAR).



Each event is stored in the IRR. Individual events can be suppressed via the IMR. The input in the IRR is independent of the interrupt masks. Event signals not masked out in the IMR generate the X/INT interrupt via a sum network. The user can set each event in the IRR for debugging.

Each interrupt event the processor processed must be deleted via the IAR (except for New\_Prm\_Data, New\_DDB\_Prm\_Data, and New\_Cfg\_Data). Log '1' must be written on the relevant bit position. If a new event and an acknowledge from the previous event are present at the IRR at the same time, the event remains stored. If the processor subsequently enables a mask, it must be ensured that no prior input is present in the IRR. For safety purposes, the position in the IRR must be deleted prior to the mask enable.

Prior to exiting the interrupt routine, the processor must set the "end of interrupt signal (E01) = 1" in the mode register. The interrupt cable is switched to inactive with this edge change. If another event must be stored, the interrupt output is not activated again until after an interrupt inactive time of at least 1 usec or 1-2 ms. This interrupt inactive time can be set via 'EOI\_Timebase.' This makes it possible to again come into the interrupt routine when an edge-triggered interrupt input is used.

The polarity for the interrupt output is parameterized via the INT\_Pol mode bit. After the hardware reset, the output is low-active.

| Address             |     | Bit Position |     |                          |                            |                          |                         |               |                   |  |  |
|---------------------|-----|--------------|-----|--------------------------|----------------------------|--------------------------|-------------------------|---------------|-------------------|--|--|
| Control<br>Register | 7   | 6            | 5   | 4                        | 3                          | 2                        | 1                       | 0             |                   |  |  |
| 00H<br>(Intel)      | Res | Res          | Res | User_<br>Timer_<br>Clock | WD_DP_<br>Mode_<br>Timeout | Baud_<br>rate_<br>Detect | Go/Leave<br>Data_<br>EX | MAC_<br>Reset | Int-Req-Reg<br>70 |  |  |

| Address             |     | Bit Position |        |                             |                      |                      |                      |                       |                      |  |
|---------------------|-----|--------------|--------|-----------------------------|----------------------|----------------------|----------------------|-----------------------|----------------------|--|
| Control<br>Register | 15  | 14           | 13     | 12                          | 11                   | 10                   | 9                    | 8                     |                      |  |
| 01H<br>(Intel)      | Res | Res          | DX_OUT | Diag_<br>Puffer_<br>Changed | New_<br>Prm_<br>Data | New_<br>Cfg_<br>Data | New_<br>SSA_<br>Data | New_GC<br>Com<br>mand | Int-Req-Reg 7<br>158 |  |

| Bit 0  | MAC_Reset                                                                                  |
|--------|--------------------------------------------------------------------------------------------|
|        | After it processes the current request, the SPC3 has arrived at the offline state (through |
|        | setting the 'Go_Offline bit' or through a RAM access violation).                           |
| Bit 1  | Go/Leave_DATA_EX                                                                           |
|        | The DP_SM has entered or exited the 'DATA_EX' state.                                       |
| Bit 2  | Baudrate_Detect                                                                            |
|        | The SPC3 has exited the 'Baud_Search state' and found a baud rate.                         |
| Bit 3  | WD_DP_Control_Timeout                                                                      |
|        | The watchdog timer has run out in the 'DP_Control' WD state.                               |
| Bit 4  | User_Timer_Clock                                                                           |
|        | The time base for the User_Timer_Clocks has run out (1/10ms).                              |
| Bit 5  | Res                                                                                        |
|        | For additional functions                                                                   |
| Bit 6  | Res                                                                                        |
|        | For additional functions                                                                   |
| Bit 7  | Res                                                                                        |
|        | For additional functions                                                                   |
| Bit 8  | New_GC_Command                                                                             |
|        | The SPC3 has received a 'Global_Control telegram' with a changed 'GC_Command-              |
|        | Byte,' and this byte is stored in the 'R_GC_Command' RAM cell.                             |
| Bit 9  | New_SSA_Data                                                                               |
|        | The SPC3 has received a 'Set_Slave_Address telegram' and made the data available           |
|        | in the SSA buffer.                                                                         |
| Bit 10 | New_Cfg_Data                                                                               |
|        | The SPC3 has received a 'Check_Cfg telegram' and made the data available in the Cfg        |
|        | buffer.                                                                                    |
| Bit 11 | New_Prm_Data                                                                               |
|        | The SPC3 has received a 'Set_Param telegram' and made the data available in the            |
|        | Prm buffer.                                                                                |
| Bit 12 | Diag_Puffer_Changed                                                                        |
|        | Due to the request made by 'New_Diag_Cmd,' SPC3 exchanged the diagnostics buffer           |
| DI: 10 | and again made the old buffer available to the user.                                       |
| Bit 13 | DX_OUT                                                                                     |
|        | The SPC3 has received a 'Write_Read_Data telegram' and made the new output data            |
|        | available in the N buffer. For a 'Power_On' or for a 'Leave_Master,' the SPC3 deletes      |
| Bit 14 | the N buffer and also generates this interrupt.                                            |
| ы. 14  | Res<br>For additional functions                                                            |
|        | For additional functions                                                                   |
| Bit 15 | Res                                                                                        |
|        | For additional functions                                                                   |

Figure 5.4: Interrupt Request Register, IRR Bit 15..0 (writable and readable)

| Address      | Register                                      |                                                    | Reset State      | Assign                   | ment                                                                                              |
|--------------|-----------------------------------------------|----------------------------------------------------|------------------|--------------------------|---------------------------------------------------------------------------------------------------|
| 02H /<br>03H | Interrupt Register<br>(IR)                    | Readable<br>only                                   | All bits deleted |                          |                                                                                                   |
| 04H /<br>05H | Interrupt Mask<br>Register<br>(IMR)           | Writable, can<br>be changed<br>during<br>operation | All bits set     | Bit =<br>1<br>Bit =<br>0 | Mask is set and the interrupt<br>is disabled.<br>Mask is deleted and the<br>interrupt is enabled. |
| 02H /<br>03H | Interrupt<br>Acknowledge<br>Register<br>(IAR) | Writable, can<br>be changed<br>during<br>operation | All bits deleted | Bit =<br>1<br>Bit =<br>0 | The IRR bit is deleted.<br>The IRR bit remains<br>unchanged.                                      |

The other interrupt controller registers are assigned in the bit positions, like the IRR.

Figure 5.5: Additional Interrupt Registers

The 'New\_Prm\_Data', 'New\_Cfg\_Data' inputs may not be deleted via the Interrupt Acknowledge Register. The relevant state machines delete these inputs through the user acknowledgements (for example, 'User\_Prm\_Data\_Okay' etc.).

# 5.4 Watchdog Timer

### 5.4.1 Automatic Baud Rate Identification

The SPC3 is able to identify the baud rate automatically. The "baud search" state is located after each RESET and also after the watchdog (WD) timer has run out in the 'Baud\_Control\_state.'

As a rule, SPC3 begins the search for the set rate with the highest baud rate. If no SD1 telegram, SD2 telegram, or SD3 telegram was received completely and without errors during the monitoring time, the search continues with the next lowest baud rate.

After identifying the correct baud rate, SPC3 switches to the "Baud\_Control" state and monitors the baud rate. The monitoring time can be parameterized (WD\_Baud\_Control\_Val). The watchdog works with a clock of 100 Hz (10 msec). The watchdog resets each telegram received with no errors to its own station address. If the timer runs out, SPC3 again switches to the baud search state.

### 5.4.2 Baud Rate Monitoring

The located baud rate is **constantly** monitored in 'Baud\_Control.' The watchdog is reset for each error-free telegram to its own station address. The monitoring time results from multiplying both 'WD\_Baud\_Control\_Val' (user sets the parameters) by the time base (10 ms). If the monitoring time runs out, WD\_SM again goes to 'Baud\_Search'. If the user carries out the DP protocol (DP\_Mode = 1, see Mode register 0) with SPC3, the watchdog is used for the "DP\_Control' state, after a 'Set\_Param telegram' was received with an enabled response time monitoring 'WD\_On = 1.' The watchdog timer remains in the baud rate monitoring state when there is a switched off 'WD\_On = 0' master monitoring. The PROFIBUS DP state machine is also not reset when the timer runs out. That is, the slave remains in the DATA\_EXchange state, for example.

### 5.4.3 Response Time Monitoring

The 'DP\_Control' state serves response time monitoring of the DP master (Master\_Add). The set monitoring times results from multiplying both watchdog factors and multiplying the result with the momentarily valid time base (1 ms or 10 ms):

T<sub>WD</sub> = (1 ms or 10 ms) \* WD\_Fact\_1 \* WD\_Fact\_2 (See byte 7 of the parameter setting telegram.)

The user can load the two watchdog factors (WD\_Fact\_1, and WD\_Fact\_2) and the time base that represents a measurement for the monitoring time via the 'Set\_Param telegram' with any value between 1 and 255.

# **EXCEPTION:** The WD\_Fact\_1=WD\_Fact\_2=1 setting is not permissible. The circuit does not check this setting.

Monitoring times between 2 ms and 650 s - independent of the baud rate - can be implemented with the permisible watchdog factors.

If the monitoring time runs out, the SPC3 goes again to 'Baud\_Control,' and the SPC3 generates the 'WD\_DP\_Control\_Timeout-Interrupt'. In addition, the DP\_State machine is reset, that is, generates the reset states of the buffer management.

If another master accepts SPC3, then there is either a switch to 'Baud\_Control" (WD\_On = 0), or there is a delay in 'DP\_Control' (WD\_On = 1), depending on the enabled response time monitoring (WD\_On = 0).

# 6 PROFIBUS-DP Interface

### 6.1 DP\_Buffer Structure

The DP mode is enabled in the SPC3 with 'DP\_Mode = 1' (see mode Register0). In this process, the following SAPS are fixed reserved for the DP mode:

| ``` | Default SAP:<br>SAP53: | Data exchange (Write_Read_Data)<br>reserved       |
|-----|------------------------|---------------------------------------------------|
| •   | SAP55:                 | Changing the station address (Set_Slave_Address)  |
| `   | SAP56:                 | Reading the inputs (Read_Inputs)                  |
| `   | SAP57:                 | Reading the outputs (Read_Outputs)                |
| `   | SAP58:                 | Control commands to the DP-Slave (Global_Control) |
| `   | SAP59:                 | Reading configuration data (Get_Config)           |
| `   | SAP60:                 | Reading diagnostics information (Slave_Diagnosis) |
| `   | SAP61:                 | Sending parameter setting data (Set_Param)        |
| `   | SAP62:                 | Checking configuration data (Check_Config)        |

The DP Slave protocol is completely integrated in the SPC3 and is handled independently. The user must correspondingly parameterize the ASIC and process and acknowledge transferred messages. Except for the default SAP, SAP56, SAP57, and SAP58, all SAPS are always enabled. The remaining SAPS are not enabled until the the DP Slave Machine (DP\_SM) goes into the 'DATA\_EX' state. The user has the possibility of disabling SAP55. The relevant buffer pointer R\_SSA\_Puf\_Ptr must be set to '00H' for this purpose. The DDB utility is disabled by the already described initialization of the RAM cells.

The DP\_SAP buffer structure is displayed in Figure 6.1. The user configures all buffers (length and buffer beginning) in the 'offline state.' During operation, the buffer configuration must not be changed, except for the length of the Dout-/Din buffers.

The user may still adapt these buffers in the 'Wait\_Cfg' state after the configuration telegram (Check\_Config). **Only the same configuration may be accepted in the 'DATA\_EX' state.** 

The buffer structure is divided into the data buffer, diagnostics buffer, and the control buffer.

Both the output data and the input data have three buffers each available with the same length. These buffers function as change buffers. One buffer is assigned to the 'D' data transfer, and one buffer is assigned to the 'U' user. The third buffer is either in a Next 'N' state or Free 'F' state, whereby one of the two states is always unoccupied.

Two diagnostics buffers that can have varying lengths are available for diagnostics. One diagnostics buffer is always the 'D' assigned to SPC3 for sending. The other diagnostics buffer belongs to the user for preparing new diagnostics data, 'U.'

The SPC3 first reads the different parameter setting telegrams (Set\_Slave\_Address, and Set\_Param) and the configuring telegram (Check\_Config) into Aux-Puffer1 or Aux-Puffer 2.....





Data exchanged with the corresponding target buffer (SSA buffer, Prm buffer, and Cfg buffer). Each of the buffers to be exchanged must have the same length. The user defines which Aux\_buffers are to be used for the above-named telegrams in the 'R\_Aux\_Puf\_Sel' parameter cell. The Aux- buffer1 must always be available. The Aux-buffer2 is optional. If the data profiles of these DP telegrams are very different, such as the data amount in the Set\_Param telegram is significantly larger than for the other telegrams, it is suggested to make an Aux-Buffer2 available (Aux\_Sel\_Set\_Param = 1) for this telegram. The other telegrams are then read via Aux-Buffer 1 (Aux\_Sel\_..=0). If the buffers are too small, SPC3 responds with "no resources"!



| Address  |   |   |   | Bit | Positi | on            |        |      | Designation           |
|----------|---|---|---|-----|--------|---------------|--------|------|-----------------------|
| RAM      | 7 | 6 | 5 | 4   | 3      | 2             |        | 0    |                       |
| Register |   |   |   |     |        |               |        |      |                       |
| 2AH      | 0 | 0 | 0 | 0   | 0      | Set_          | Check_ | Set_ | R_Aux_Puf_Sel         |
|          |   |   |   |     |        | Slave_<br>Adr | Cfg    | Prm  |                       |
|          |   |   |   |     |        | X1            | X1     | X1   | See below for coding. |

| X1 | Coding      |
|----|-------------|
| 0  | Aux_Buffer1 |
| 1  | Aux_Buffer2 |

#### Figure 6.2: Aux-Buffer Management

The user makes the configuration data (Get\_Config) available in the Read\_Cfg buffer for reading. The Read\_Cfg buffer must have the same length as the Cfg\_buffer.

The Read\_Input\_Data telegram is operated from the Din buffer in the 'D state', and the Read\_Output\_Data telegram is operated from the Dout buffer in the 'U state.'

All buffer pointers are 8-bit segment addresses, because the SPC3 internally has only 8-bit address registers. For a RAM access, SPC3 adds an 8-bit offset address to the segment address shifted by 3 bits (result: 11-bit physical address). As regards the buffer start addresses, this results in an 8-byte graunularity from this specification.

### 6.2 Description of the DP Services

### 6.2.1 Set\_Slave\_Address (SAP55)

### 6.2.1.1 Sequence for the Set\_Slave\_Address Utility

The user can disable this utility by setting the ' $R_SSA_Puf_Ptr = 00H$ ' buffer pointer. The slave address must then be determined, for example, by reading a switch, and written in the  $R_TS_Adr$ . RAM register.

The user must make a retentive memory possibility available (for example, EEPROM) to support this utility. It must be possible to store the 'station address' and the 'Real\_No\_Add\_Change' ('True' = FFH) parameter in this external EEPROM. After each restart caused by a power failure, the user must again make these values available to SPC3 in the R\_TS\_Adr und R\_Real\_No\_Add\_Change RAM register.

If SAP55 is enabled and the Set\_Slave\_Address telegram is correctly accepted, SPC3 enters all net data in the Aux-Puffer1/2, exchanges the Aux buffer1/2 for the SSA buffer, stores the entered data length in 'R\_Len\_SSA\_Data', generates the 'New\_SSA\_Data' interrupt and internally stores the new 'station address' and the new 'Real\_No\_Add\_Change' parameter. The user does not need to transfer this changed parameter to SPC3 again. After the user has read the buffer, the user generates the 'SSA\_Puffer\_Free\_Cmd' (read operation on address 14H). This makes SPC3 again ready to receive an additional Set Slave Address telegram (such as from another master).

| Address  |   |   |   | Bit Po | sition |   |   |   | Designation         |
|----------|---|---|---|--------|--------|---|---|---|---------------------|
| Control  | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |                     |
| Register |   |   |   |        |        |   |   |   |                     |
| 14H      | 0 | 0 | 0 | 0      | 0      | 0 | 0 | 0 | SSA_Puffer_Free_Cmd |
|          |   |   |   | don 't | care   |   |   |   |                     |

SPC3 reacts independently when there are errors.

Figure 6.3: Coding SSA\_Buffer\_Free\_Cmd

### 6.2.1.2 Structure of the Set\_Slave\_Address Telegram

The net data are stored as follows in the SSA buffer:

| Byte  |   |   |   | Bit Po | osition |   |   |   | Designation                            |
|-------|---|---|---|--------|---------|---|---|---|----------------------------------------|
|       | 7 | 6 | 5 | 4      | 3       | 2 | 1 | 0 |                                        |
| 0     |   |   |   |        |         |   |   |   | New_Slave_Address                      |
| 1     |   |   |   |        |         |   |   |   | Ident_Number_High                      |
| 2     |   |   |   |        |         |   |   |   | Ident_Number_Low                       |
| 3     |   |   |   |        |         |   |   |   | No_Add_Chg                             |
| 4-243 |   |   |   |        |         |   |   |   | Rem_Slave_Data additional application- |
|       |   |   |   |        |         |   |   |   | specific data                          |

Figure 6.4: Data Format for the Set\_Slave\_Address Telegram

### 6.2.2 Set\_Param (SAP61)

### 6.2.2.1 Parameter Data Structure

SPC3 evaluates the first seven data bytes (without user prm data), or the first eight data bytes (with user prm data). The first seven bytes are specified according to the standard. The eighth byte is used for SPC3-specific characteristics. The additional bytes are available to the application.

| Byte  |             |              |             | Bit Po      | sition   |             |             |              | Designation        |
|-------|-------------|--------------|-------------|-------------|----------|-------------|-------------|--------------|--------------------|
|       | 7           | 6            | 5           | 4           | 3        | 2           | 1           | 0            |                    |
| 0     | Lock<br>Req | Unlo.<br>Req | Sync<br>Req | Free<br>Req | WD<br>on | Res         | Res         | Res          | Station status     |
| 1     |             |              |             |             |          |             |             |              | WD_Fact_1          |
| 2     |             |              |             |             |          |             |             |              | WD_Fact_2          |
| 3     |             |              |             |             |          |             |             |              | MinTSDR            |
| 4     |             |              |             |             |          |             |             |              | Ident_Number_High  |
| 5     |             |              |             |             |          |             |             |              | Ident_Number_Low   |
| 6     |             |              |             |             |          |             |             |              | Group_Ident        |
| 7     | 0           | 0            | 0           | 0           | 0        | WD_<br>Base | Dis<br>Stop | Dis<br>Start | Spec_User_Prm_Byte |
| 8-243 |             |              |             |             |          |             |             |              | User_Prm_Data      |

| Byte 7 | Spec_User_P  | rm_Byte                                                                                                                        |                                                                         |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| Bit    | Name         | Significance                                                                                                                   | Default State                                                           |
| 0      | Dis_Startbit | The start bit monitoring in the receiver is switched off with this bit.                                                        | Dis_Startbit= 1 ,<br>that is, start bit monitoring is<br>switched off.  |
| 1      | Dis_Stopbit  | Stop bit monitoring in the receiver is switched off with this bit.                                                             | Dis_Stopbit= 0,<br>that is, stop bit monitoring is not<br>switched off. |
| 2      | WD_Base      | This bit specifies the time base used<br>to clock the watchdog.<br>WD_Base = 0: time base 10 ms<br>WD_Base = 1: time base 1 ms | WD_Base= 0,<br>that is, the time base is 10 ms                          |
| 3-7    | res          | to be parameterized with 0                                                                                                     | 0                                                                       |

Figure 6.5: Data Format for the Set\_Param\_Telegram

### 6.2.2.2 Parameter Data Processing Sequence

In the case of a positive validatation for more than seven data bytes, SPC3 carries out the following reaction, among others:

SPC3 exchanges Aux-Puffer1/2 (all data bytes are input here) for the Prm buffer, stores the input data length in 'R\_Len\_Prm\_Data', and triggers the 'New\_Prm\_Data Interrupt'. The user must then check the 'User\_Prm\_Data' and either reply with the 'User\_Prm\_Data\_Okay\_Cmd' or with 'User\_Prm\_Data\_Not\_Okay\_Cmd.' The entire telegram is input in the buffer, that is, application-specific parameter data are stored beginning with data byte 8 only.

The user response (User\_Prm\_Data\_Okay\_Cmd or User\_Prm\_Data\_Not\_Okay\_Cmd) again takes back the 'New\_Prm\_Data' interrupt. The user may not acknowledge the 'New\_Prm\_Data' interrupt in the IAR register.

The relevant diagnostics bits are set with the 'User\_Prm\_Data\_Not\_Okay\_Cmd' message and are branched to 'Wait\_Prm.'

The 'User\_Prm\_Data\_Okay' and 'User\_Prm\_Data\_Not\_Okay' acknowledgements are reading accesses to defined registers with the relevant signals:

- 'User\_Prm\_Finished': No additional parameter telegram is present.
- 'Prm\_Conflict': An additional parameter telegram is present, processing again
- 'Not\_Allowed', Access not permitted in the current bus state

| Address             |   |   |   | Bit Po | sition |   |   |   | Designation        |
|---------------------|---|---|---|--------|--------|---|---|---|--------------------|
| Control<br>Register | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |                    |
| 0EH                 | 0 | 0 | 0 | 0      | 0      | 0 | ↓ | ↓ | User_Prm_Data_Okay |
|                     |   |   |   |        |        |   | 0 | 0 | User_Prm_Finished  |
|                     |   |   |   |        |        |   | 0 | 1 | PRM_Conflict       |
|                     |   |   |   |        |        |   | 1 | 1 | Not_Allowed        |

| Address             |   |   |   | Bit Po | sition |   |   |   | Designation            |
|---------------------|---|---|---|--------|--------|---|---|---|------------------------|
| Control<br>Register | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |                        |
| 0FH                 | 0 | 0 | 0 | 0      | 0      | 0 | ⇒ | ⇒ | User_Prm_Data_Not_Okay |
|                     |   |   |   |        |        |   | 0 | 0 | User_Prm_Finished      |
|                     |   |   |   |        |        |   | 0 | 1 | PRM_Conflict           |
|                     |   |   |   |        |        |   | 1 | 1 | Not_Allowed            |

Figure 6.6: Coding User\_Prm\_Data\_Not/\_Okay\_Cmd

If an additional Set-Param telegram is supposed to be received in the meantime, the signal 'Prm\_Conflict' is is returned for the acknowledgement of the first Set\_Param telegram, whether positive or negative. Then the user must repeat the validation because the SPC3 has made a new Prm buffer available.

### 6.2.3 Check\_Config (SAP62)

The user takes on the evaluation of the configuration data. After SPC3 has received a validated Check\_Config-Telegram, SPC3 exchanges the Aux-Puffer1/2 (all data bytes are entered here) for the Cfg buffer, stores the input data length in 'R\_Len\_Cfg-Data,' and generates 'New\_Cfg\_Data-Interrupt'.

The user must then check the 'User\_Config\_Data' and either respond with 'User\_Cfg\_Data\_Okay\_Cmd' or with 'User\_Cfg\_Data\_Not\_Okay\_Cmd' (acknowledgement to the Cfg\_SM). The net data is input in the buffer in the format regulation of the standard.

# The user response (User\_Cfg\_Data\_Okay\_Cmd or the User\_Cfg\_Data\_Not\_Okay\_Cmd response) again takes back the 'New\_Cfg\_Data' interrupt and may not be acknowledged in the IAR.

If an incorrect configuration is signalled back, various diagnostics bits are changed, and there is branching to 'Wait\_Prm."

For a correct configuration, the transition to 'DATA\_EX' takes place immediately, if no Din\_buffer is present (R\_Len\_Din\_Puf = 00H) and trigger counters for the parameter setting telegrams and configuration telegrams are at 0. Otherwise, the transition does not take place until the first 'New\_DIN\_Puffer\_Cmd' with which the user makes the first valid 'N buffer" available. When entering into 'DATA\_EX,' SPC3 also generates the 'Go/Leave\_Data\_Exchange-Interrupt.

If the received configuration data from the Cfg buffer are supposed to result in a change of the Read-Cfgbuffer ( the change contains the data for the Get\_Config telegram), the user must make the new Read\_Cfg data available in the Read-Cfg buffer before the 'User\_Cfg\_Data\_Okay\_Cmd" acknowledgement. After receiving the acknowledgement, SPC3 exchanges the Cfg buffer with the Read-Cfg buffer, if 'EN\_Change\_Cfg\_buffer = 1' is set in mode register1.

During the acknowledgement, the user receives information about whether there is a conflict or not. If an additional Check\_Config telegram was supposed to be received in the meantime, the user receives the 'Cfg\_Conflict' signal during the acknowledgement of the first Check\_Config telegram, whether positive or negative. Then the user must repeat the validation, because SPC3 has made a new Cfg buffer available.

The 'User\_Cfg\_Data\_Okay\_Cmd' and 'User\_Cfg\_Data\_Not\_Okay\_Cmd' acknowledgements are read accesses to defined memory cells (see Section 2.2.1) with the relevant 'Not\_Allowed', 'User\_Cfg\_Finished,' or 'Cfg\_Conflict' signals (see Figure 3.7). If the 'New\_Prm\_Data'and 'New\_Cfg\_Data' are supposed to be present simultaneously during power up, the user must maintain the Set\_Param and then the Check\_Config. acknowledgement sequence.

| Address             |   |   |   | Bit Po | sition |   |   |   | Designation        |
|---------------------|---|---|---|--------|--------|---|---|---|--------------------|
| Control<br>Register | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |                    |
| 10H                 | 0 | 0 | 0 | 0      | 0      | 0 | ⇒ | ⇒ | User_Cfg_Data_Okay |
|                     |   |   |   |        |        |   | 0 | 0 | User_Cfg_Finished  |
|                     |   |   |   |        |        |   | 0 | 1 | Cfg_Conflict       |
|                     |   |   |   |        |        |   | 1 | 1 | Not_Allowed        |
|                     |   |   |   |        |        |   |   |   |                    |
| Address             |   |   |   | Bit Po | sition |   |   |   | Designation        |
| Control<br>Register | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |                    |

| Register |   |   |   |   |   |   |              |              |                        |
|----------|---|---|---|---|---|---|--------------|--------------|------------------------|
| 11H      | 0 | 0 | 0 | 0 | 0 | 0 | $\downarrow$ | $\downarrow$ | User_Cfg_Data_Not_Okay |
|          |   |   |   |   |   |   | 0            | 0            | User_Cfg_Finished      |
|          |   |   |   |   |   |   | 0            | 1            | Cfg_Conflict           |
|          |   |   |   |   |   |   | 1            | 1            | Not_Allowed            |

Figure 6.7: Coding of the User\_Cfg\_Data\_Not/\_Okay\_Cmd

### 6.2.4 Slave\_Diagnosis (SAP60)

### 6.2.4.1 Diagnostics Processing Sequence

Two buffers are available for diagnostics. The two buffers can have varying lengths. SPC3 always has one diagnostics buffer assigned to it, which is sent for a diagnostics call-up. The user can pre-process new diagnostics data in parallel in the other buffer. If the new diagnostics data are to be sent now, the user uses the 'New\_Diag\_Cmd' to make the request to exchange the diagnostics buffers. The user receives confirmation of the exchange of the buffers with the 'Diag\_Puffer\_Changed Interrupt.'

When the buffers are exchanged, the internal 'Diag\_Flag' is also set. For an activated 'Diag\_Flag,' SPC3 responds during the next Write\_Read\_Data with high-priority response data that signal the relevant master that new diagnostics data are present at the slave. Then this master fetches the new diagnostics data with a Slave\_Diagnosis telegram. Then the 'Diag\_Flag' is reset again. If the user signals 'Diag.Stat\_Diag = 1,' however (static diagnosis, see the structure of the diagnostics buffer), then 'Diag\_Flag' still remains activated after the relevant master has fetched the diagnosis. The user can poll the 'Diag\_Flag' in the status register to find out whether the master has already fetched the diagnostics data before the old data is exchanged for the new data.

Status coding for the diagnostics buffers is stored in the 'Diag\_bufferSM' processor parameter. The user can read this cell with the possible codings for both buffers: 'User,' 'SPC3,' or 'SPC3\_Send\_Mode.'

| Address  |   |   |   | Bit Po | sition |      |     |      | Designation           |
|----------|---|---|---|--------|--------|------|-----|------|-----------------------|
| Control  | 7 | 6 | 5 | 4      | 3      | 2    |     | 0    |                       |
| Register |   |   |   |        |        |      |     |      |                       |
| 0CH      | 0 | 0 | 0 | 0      | D_F    | Puf2 | D_F | Puf1 | Diag_Puffer_SM        |
|          |   |   |   |        | X1     | X2   | X1  | X2   | See below for coding. |

| X1 | X2 | Coding                        |
|----|----|-------------------------------|
| 0  | 0  | Each for the D_Buf2 or D_Buf1 |
| 0  | 1  | User                          |
| 1  | 0  | SPC3                          |
| 1  | 1  | SPC3_Send_Mode                |

Figure 6.8: Diag\_Buffer Assignment

The 'New\_Diag\_Cmd' is also a read access to a defined processor parameter with the signal as to which diagnostics buffer belongs to the user after the exchange, or whether both buffers are currently assigned to SPC3 ('no Puffer', 'Diag\_Puf1', 'Diag\_Puf2').

| Address             |   |   |   | Bit Po | sition |   |   |   | Designation  |
|---------------------|---|---|---|--------|--------|---|---|---|--------------|
| Control<br>Register | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |              |
| 0DH                 | 0 | 0 | 0 | 0      | 0      | 0 | ⇒ | ⇒ | New_Diag_Cmd |
|                     |   |   |   |        |        |   | 0 | 0 | no Puffer    |
|                     |   |   |   |        |        |   | 0 | 1 | Diag_Puf1    |
|                     |   |   |   |        |        |   | 1 | 0 | Diag_Puf2    |

Figure 6.9: Coding Diag\_Puffer\_SM, New\_Diag\_Cmd

### 6.2.4.2 Structure of the Diagnostics Buffer:

The user transfers the diagnostics buffer displayed in the figure below to SPC3. The first 6 bytes are space holders, except for the three least significant bit positions in the first byte. The user stores the diagnostics bits, 'Diag.Ext\_Diag' 'Diag.Stat\_Diag," and Diag.Ext.Diag\_Overflow' in these three bit positions. The remaining bits can be assigned in any order. When sending, SPC3 pre-processes the first six bytes corresponding to the standard.

| Byte |   |   |    | Bit Po   | sition  |                           |              |              | Designation                 |
|------|---|---|----|----------|---------|---------------------------|--------------|--------------|-----------------------------|
|      | 7 | 6 | 5  | 4        | 3       | 2                         | 1            | 0            |                             |
| 0    |   |   |    |          |         | Ext_<br>Diag<br>Over<br>f | Stat<br>Diag | Ext_<br>Diag | Spaceholder                 |
| 1    |   |   |    |          |         |                           |              |              | Spaceholder                 |
| 2    |   |   |    |          |         |                           |              |              | Spaceholder                 |
| 3    |   |   |    |          |         |                           |              |              | Spaceholder                 |
| 4    |   |   |    |          |         |                           |              |              | Spaceholder                 |
| 5    |   |   |    |          |         |                           |              |              | Spaceholder                 |
| 6-n  |   |   | Th | e user i | must in | put                       |              |              | Ext_Diag_Data (n = max 243) |

Figure 6.10: Structure of the Diagnostics Buffer for Transfer to the SPC3

The 'Ext-Diag\_Data' the user must enter into the buffers follow after the SPC3-internal diagnostics data. The three different formats are possible here (device-related, ID-related, and port-related). In addition to the 'Ext\_Diag\_Data,' the buffer length also includes the SPC3 diagnostics bytes (R\_Len\_Diag\_Puf1, R\_Len\_Diag\_Puf2).

### 6.2.5 Write\_Read\_Data / Data\_Exchange (Default\_SAP)

### 6.2.5.1 Writing Outputs

SPC3 reads the received output data in the D buffer. After error-free receipt, SPC3 shifts the newly filled buffer from 'D' to 'N.' In addition, the 'DX\_Out\_Interrupt' is generated. The user now fetches the current output data from 'N.' The buffer changes from 'N' to 'U' with the 'Next\_Dout\_Buffer\_Cmd,' so that the current data of the application can be sent back for the master's Read\_Outputs.

If the user's evaluation cycle time is shorter than the bus cycle time, the user does not find any new buffers with the next 'Next\_Dout\_Buffer\_Cmd' in 'N.' Therefore, the buffer exchange is omitted, At a 12 Mbd baud rate, it is more likely, however, that the user's evaluation cycle time is larger than the bus cycle time. This makes new output data available in 'N' several times before the user fetches the next buffer. It is guaranteed, however, that the user receives the data last received.

For 'Power\_On', 'Leave\_Master' and the Global\_Control-Telegram 'Clear,' SPC3 deletes the D buffer and then shifts it to 'N.' This also takes place during the power up (entering into 'Wait\_Prm'). If the user fetches this buffer, he receives the 'U\_buffer cleared' display during the 'Next\_Dout\_Buffer\_Cmd.' If the user is still supposed to enlarge the output data buffer after the Check\_Config telegram, the user must delete this delta in the N buffer himself (possible only during the power-up phase in the 'Wait\_Cfg' state).

If 'Diag.Sync\_Mode = 1', the D buffer is filled but not exchanged with the Write\_Read\_Data-Telegram, but rather exchanged at the next Sync or Unsync.

The user can read the buffer management state with the following codes for the four states: 'Nil', 'Dout\_Puf\_Ptr1-3'. The pointer for the current data is in the "N" state.

| Address  |    |    |    | Bit Po | sition |    |       | Designation |                       |
|----------|----|----|----|--------|--------|----|-------|-------------|-----------------------|
| Control  | 7  | 6  | 5  | 4      | 3      | 2  |       | 0           |                       |
| Register |    |    |    |        |        |    |       |             |                       |
| 0AH      | F  | -  | l  | J      | ١      | ١  | D     |             | Dout_Puffer_SM        |
|          | X1 | X2 | X1 | X2     | X1     | X2 | X1 X2 |             | See below for coding. |

| X1 | X2 | Coding        |
|----|----|---------------|
| 0  | 0  | Nil           |
| 0  | 1  | Dout_Puf_Ptr1 |
| 1  | 0  | Dout_Puf_Ptr2 |
| 1  | 1  | Dout_Puf_Ptr3 |

Figure 6.11: Dout\_Buffer Management

When reading the 'Next\_Dout\_Buffer\_Cmd' the user gets the information which buffer (U-buffer) belongs to the user after the change, or whether a change has taken place at all.

| Address  |   |   |   | Bit I | Position                |                        |                    |             | Designation            |
|----------|---|---|---|-------|-------------------------|------------------------|--------------------|-------------|------------------------|
| Control  | 7 | 6 | 5 | 4     | 3                       | 2                      | 1                  | 0           |                        |
| Register |   |   |   |       |                         |                        |                    |             |                        |
| 0BH      | 0 | 0 | 0 | 0     | U_<br>Buffer<br>Cleared | State_<br>U_<br>Buffer | Ind <u>.</u><br>Bu | _U_<br>ffer | Next_Dout_Buf_Cmd      |
|          |   |   |   |       |                         |                        | 0                  | 1           | Dout_Buf_Ptr1          |
|          |   |   |   |       |                         |                        | 1                  | 0           | Dout_Buf_Ptr2          |
|          |   |   |   |       |                         |                        | 1                  | 1           | Dout_Buf_Ptr3          |
|          |   |   |   |       |                         | 0                      |                    |             | No new U buffer        |
|          |   |   |   |       |                         | 1                      |                    |             | New U buffer           |
|          |   |   |   |       | 0                       |                        |                    |             | U buffer contains data |
|          |   |   |   |       | 1                       |                        |                    |             | U buffer was deleted   |

Figure 6.12: Next\_Dout\_Puffer\_Cmd

The user must delete the U buffer during initialization so that defined (deleted) data can be sent for a Read\_Output Telegram before the first data cycle.

### 6.2.5.2 Reading Inputs

SPC3 sends the input data from the D buffer. Prior to sending, SPC3 fetches the Din buffer from 'N' to 'D.' If no new buffer is present in 'N,' there is no change.

The user makes the new data available in 'U'. With the 'New\_Din\_buffer\_Cmd,' the buffer changes from 'U' to 'N'. If the user's preparation cycle time is shorter than the bus cycle time, not all new input data are sent, but just the most current. At a 12 Mbd baud rate, it is more probable, however, that the user's preparation cycle time. Then SPC3 sends the same data several times in succession.

During start-up, SPC3 first goes to 'DATA\_EX' after all parameter telegrams and configuration telegrams are acknowledged, and the user then makes the first valid Din buffer available in 'N' with the 'New\_Din\_Buffer\_Cmd.

If 'Diag.Freeze\_Mode = 1', there is no buffer change prior to sending.

The user can read the status of the state machine cell with the following codings for the four states: 'Nil', 'Dout\_Puf\_Ptr1-3.' (See Figure 3.13.) The pointer for the current data is in the "N" state.

| Address  |    |    |    | Bit Po | sition |    |    | Designation |                       |
|----------|----|----|----|--------|--------|----|----|-------------|-----------------------|
| Control  | 7  | 6  | 5  | 4      | 3      | 2  |    | 0           |                       |
| Register |    |    |    |        |        |    |    |             |                       |
| 08H      | F  | -  | ι  | J      | 1      | ١  | D  |             | Din_Buffer_SM         |
|          | X1 | X2 | X1 | X2     | X1     | X2 | X1 | X2          | See below for coding. |

| X1 | X2 | Coding       |
|----|----|--------------|
| 0  | 0  | Nil          |
| 0  | 1  | Din_Buf_Ptr1 |
| 1  | 0  | Din_Buf_Ptr2 |
| 1  | 1  | Din_Buf_Ptr3 |

Figure 6.13: Din\_Buffer Management

When reading the 'New\_Din\_Buffer\_Cmd' the user gets the information which buffer (U-buffer) belongs to the user after the change (Din\_Buf\_Ptr 1-3).

| Address             | Bit Position |   |   |   |   |   |              |              | Designation     |
|---------------------|--------------|---|---|---|---|---|--------------|--------------|-----------------|
| Control<br>Register | 7            | 6 | 5 | 4 | 3 | 2 | 1            | 0            |                 |
| Register            |              |   |   |   |   |   |              |              |                 |
| 09H                 | 0            | 0 | 0 | 0 | 0 | 0 | $\downarrow$ | $\Downarrow$ | New_Din_Buf_Cmd |
|                     |              |   |   |   |   |   | 0            | 1            | Din_Buf_Ptr1    |
|                     |              |   |   |   |   |   | 1            | 0            | Din_Buf_Ptr2    |
|                     |              |   |   |   |   |   | 1            | 1            | Din_Buf_Ptr3    |

Figure 6.14: Next\_Din\_Buffer\_Cmd

#### 6.2.5.3 User\_Watchdog\_Timer

After power-up ('DATA\_EX' state), it is possible that SPC3 continually answers Write\_Read\_Data-telegrams without the user fetching the received Din buffers or making new Dout buffers available. If the user processor 'hangs up,' the master would not receive this information. Therefore, a 'User\_Watchdog\_Timer' is implemented in SPC3.

This User\_Wd\_Timer is an internal 16-bit RAM cell that is started from a 'R\_User\_Wd\_Value15..0' value the user parameterizes and is decremented with each received Write\_Read\_Data telegram from SPC3. If the timer attains the '0000hex' value, SPC3 transitions to the 'Wait\_Prm' state, and the DP\_SM carries out a 'Leave\_Master.' The user must cyclically set this timer to its start value. Therefore, 'Res\_User\_Wd = 1' must be set in mode register 1. Upon receipt of the next Write\_Read\_Data telegram, SPC3 again loads the User\_Wd\_Timer to the parameterized value 'R\_User\_Wd\_Value15..0' and sets 'Res\_User\_Wd = 0' (Mode Register 1). During power-up, the user must also set 'Res\_User\_Wd = 1', so that the User\_Wd\_Timer is even set at its parameterized value.

### 6.2.6 Global\_Control (SAP58)

SPC3 itself processes the Global\_Control-Telegrams in the manner already described. In addition, this information is available to the user.

The first byte of a valid Global\_Control command is stored in the R\_GC\_Comand RAM cell. The second telegram byte (Group\_Select) is processed internally.

| Address     |     |     | Designation |            |        |              |                |     |              |
|-------------|-----|-----|-------------|------------|--------|--------------|----------------|-----|--------------|
| RAM<br>Cell | 7   | 6   | 5           | 4          | 3      | 2            | 1              | 0   |              |
| 3CH         | Res | Res | Sync        | Un<br>sync | Freeze | Un<br>freeze | Clear_<br>Data | Res | R_GC_Command |

| Bit | Designation | Significance                                                                                                                                                                         |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | Reserved    |                                                                                                                                                                                      |
| 1   | Clear_Data  | With this command, the output data is deleted in 'D' and is changed to 'N.'                                                                                                          |
| 2   | Unfreeze    | With "Unfreeze," freezing input data is cancelled.                                                                                                                                   |
| 3   | Freeze      | The input data is fetched from 'N' to 'D' and "frozen". New input data<br>is not fetched again until the master sends the next 'Freeze'<br>command.                                  |
| 4   | Unsync      | The "Unsync" command cancels the "Sync" command.                                                                                                                                     |
| 5   | Sync        | The output data transferred with a WRITE_READ_DATA telegram is changed from 'D' to 'N.' The following transferred output data is kept in 'D' until the next 'Sync' command is given. |
| 6,7 | Reserved    | The "Reserved" designation specifies that these bits are reserved for future function expansions.                                                                                    |

Figure 6.15: Data Format for the Global\_Control Telegram

If the Control\_Comand byte changed at the last received Global\_Control telegram, SPC3 additionally generates the 'New\_GC\_Command' interrupt. During initialization, SPC3 presets the 'R\_GC\_Command' RAM cell with 00H. The user can read and evaluate this cell.

So that Sync and Freeze can be carried out, these functions must be enabled in the mode register.

### 6.2.7 Read\_Inputs (SAP56)

SPC3 fetches the input data like it does for the Write\_Read\_Data Telegram. Prior to sending, 'N' is shifted to 'D,' if new input data are available in 'N.' For 'Diag.Freeze\_Mode = 1,' there is no buffer change.

### 6.2.8 Read\_Outputs (SAP57)

SPC3 fetches the output data from the Dout buffer in 'U'. The user must preset the output data with '0' during start-up so that no invalid data can be sent here. If there is a buffer change from 'N' to 'U' (through the Next\_Dout\_Buffer\_Cmd) between the first call-up and the repetition, the new output data is sent during the repetition.

### 6.2.9 Get\_Config (SAP59)

The user makes the configuration data available in the Read\_Cfg buffer. For a change in the configuration after the Check\_Config telegram, the user writes the changed data in the Cfg buffer, sets 'EN\_Change\_Cfg\_buffer = 1' (see Mode-Register1), and SPC3 then exchanges the Cfg buffer for the Read\_Cfg buffer. (See Section 3.2.3.) If there is a change in the configuration data (for example, for the modular DP systems) during operation, the user must return with 'Go Offline' (see Mode Register1) to 'Wait\_Prm' to SPC3.

## 7 <u>Hardware Interface</u>

## 7.1 Universal Processor Bus Interface

## 7.1.1 General Description

SPC3 has a parallel 8-bit interface with an 11-bit address bus. SPC3 supports all 8-bit processors and microcontrollers based on the 80C51/52 (80C32) from Intel, the Motorola HC11 family, as well as 8-/16-bit processors or microcontrollers from the Siemens 80C166 family, X86 from Intel, and the HC16 and HC916 family from Motorola. Because the data formats from Intel and Motorola are not compatible, SPC3 automatically carries out 'byte swapping' for accesses to the following 16-bit registers (interrupt register, status register, and mode register0) and the 16-bit RAM cell (R-User\_Wd\_Value). This makes it possible for a Motorola processor to read the 16-bit value correctly. Reading or writing takes place, as usual, through two accesses (8-bit data bus).

Due to the 11-bit address bus, SPC3 is no longer fully compatible to SPC2 (10-bit address bus). However, AB(10) is located on the XINTCI output of the SPC2 that was not used until now. For SPC3, the AB(10) input is provided with an internal pull-down resistor. If SPC3 is to be connected into existing SPC2 hardware, the user can use only 1 kByte of the internal RAM. Otherwise, the AB(10) cable on the modules must be moved to the same place.

The Bus Interface Unit (BIU) and the Dual Port RAM Controller (DPC) that controls accesses to the internal RAM belong to the processor interface of the SPC3.

In addition, a clock rate divider is integrated that the clock pulse of an external clock pulse generator divided by 2 (Pin: DIVIDER = High-Potential) or 4 (Pin: DIVIDER = Low-Potential) makes available on the pin CLKOUT2/4 as the system clock pulse so that a slower controller can be connected without additional expenditures in a low-cost application. SPC3 is supplied with a clock pulse rate of 48MHz.

#### 7.1.2 Bus Interface Unit (BIU)

The BIU forms the interface to the connected processor/microcontroller. This is a synchronous or asynchronous 8-bit interface with an 11-bit address bus. The interface is configurable via 2 pins (XINT/MOT, MODE). The connected processor family (bus control signals such as XWR, XRD, or R\_W, and the data format) is specified with the XINT/MOT pin. Synchronous (rigid) or asynchronous bus timing is specified with the MODE pin.

Various Intel system configurations are displayed in the figures in Section 7.1.3. The internal address latch and the integrated decoder must be used in the C32 mode. One figure displays the minimum configuration of a system with SPC3, whereby the block is connected to an EPROM version of the controller. Only a pulse generator is necessary as an additional block in this configuration. If a controller is to be used without an integrated program memory, the addresses must once again be latched off for the external memory. The connection schematic in the next figure is applicable for all Intel/Siemens processors that offer asynchronous bus timing and evaluate the ready signal.

#### Notes:

If the **SPC3 is connected to an 80286** processor, or others, it must be taken into consideration that the processor carries out word accesses. That is, either a "swapper" is necessary that switches the characters out of the SPC3 at the relevant byte position of the 16-bit data bus during reading, or the least significant address bit is not connected, and the 80286 must read word accesses and evaluate only the lower byte, as displayed in the figure.

| XINT/MO MODE  | The SPC3 interface supports the following processors/microcontrollers.                                                                                                         |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 1           | Motorola microcontroller with the following characteristics:                                                                                                                   |
| synchron-ous  | <ul> <li>Synchronous (rigid) bus timing without evaluation of the XREADY signal</li> </ul>                                                                                     |
| Motorola      | <ul> <li>8-bit non-multiplexed bus: DB70, AB100</li> </ul>                                                                                                                     |
|               | The following can be connected:                                                                                                                                                |
|               | • HC11 types: K, N, M, F1                                                                                                                                                      |
|               | <ul> <li>HC16- und HC916 types with programmable E clock timing</li> </ul>                                                                                                     |
|               | • All other HC11 types with a multiplexed bus must select addresses AB70 externally                                                                                            |
|               | from DB70 data.                                                                                                                                                                |
|               | The address decoder is switched off in the SPC3. The CS signal is fed to SPC3.                                                                                                 |
|               | • For microcontrollers with chip select logic (K, F1, HC16, and HC916), the chip select                                                                                        |
|               | signals are programmable as regards the address range, the priority, the polarity, and                                                                                         |
|               | the window width in the write cycle or read cycle.                                                                                                                             |
|               | • For microcontrollers without chip select logic (N and M), and others, an external chip                                                                                       |
|               | select logic is required. This means additional hardware and a fixed assignment.                                                                                               |
|               |                                                                                                                                                                                |
|               | • The SPC3 output clock (CLKOUT2/4) must be four times larger than the E_CLOCK.                                                                                                |
|               | The SPC3 input clock (CLK) must be at least 10 times larger than the desired system clock (E_Clock). The divider pin must be placed at "low" (divider 4), and it results in an |
|               | E_CLOCK of 3 MHz                                                                                                                                                               |
| 1 0           | Motorola microcontroller with the following characteristics:                                                                                                                   |
| asynchron-ous | <ul> <li>Asychronous bus timing with evaluation of the XREADY signal</li> </ul>                                                                                                |
| Motorola      | <ul> <li>8-bit non-multiplexed bus: DB70, AB100</li> </ul>                                                                                                                     |
|               | The following can be connected:                                                                                                                                                |
|               | HC16 and HC916 types                                                                                                                                                           |
|               | • All other HC11 types with a multiplexed bus must externally select addresses AB70                                                                                            |
|               | from data DB70.                                                                                                                                                                |
|               | The address decoder is switched off in SPC3. The CS signal is fed into SPC3.                                                                                                   |
|               | Chip select logic is available and programmable in all microcontrollers.                                                                                                       |
| 0 1           | Intel microcontroller CPU basis is 80C51/52/32, microcontrollers from various                                                                                                  |
| synchron-ous  | manufacturers:                                                                                                                                                                 |
| Intel         | <ul> <li>Sychronous (rigid) bus timing without evaluation of the XREADY signal</li> <li>8-bit multiplexed bus: ADB70</li> </ul>                                                |
| inter         | The following can be connected:                                                                                                                                                |
|               | <ul> <li>Microcontroller families from Intel, Siemens, and Philips, for example</li> </ul>                                                                                     |
|               | The address decoder is switched on in SPC3. The CS signal is generated for SPC3                                                                                                |
|               | internally.                                                                                                                                                                    |
|               | • The lower address bits AB70 are stored with the ALE signal in an internal address                                                                                            |
|               | latch. The internal CS decoder is activated in SPC3 that generates its own CS signal                                                                                           |
|               | from the AB100 addresses.                                                                                                                                                      |
|               | The internal address decoder is fixed wired, so that SPC3 must always be addressed                                                                                             |
|               | under the fixed addresses AB70 = $00000xxxb$ . SPC3 selects relevant address window                                                                                            |
|               | from the AB20 signals. In this mode, the CS-Pin (XCS) must be located at VDD (high                                                                                             |
| 0 1           | potential).<br>Intel- and Siemens 16-/8-bit microcontroller families                                                                                                           |
| asynchron.    | <ul> <li>Asychronous bus timing with evaluation of the XREADY signal</li> </ul>                                                                                                |
| Intel         | <ul> <li>8 bit non-multiplexed bus: DB70, AB100</li> </ul>                                                                                                                     |
|               | The following can be connected:                                                                                                                                                |
|               | <ul> <li>Microcontroller families from Intel x86 and Siemens 80C16x, for example</li> </ul>                                                                                    |
|               | Address decoder is switched off in SPC3. The CS signal is fed in to the SPC3.                                                                                                  |
|               | <ul> <li>External address decoding is always necessary.</li> </ul>                                                                                                             |
|               | <ul> <li>External chip select logic if the microcontroller is not present</li> </ul>                                                                                           |
|               |                                                                                                                                                                                |

Figure 7.1: Bus Interface

## SPC3

## 7.1.3 Switching Diagram Principles







## 7.1.4 Application with the 80 C 32



SPC3

The pull up / pull down resistances in the drawing above are only relevant for a in circuit tester. The internal chip select logic is activated when the address pins A 11 .. A 15 are set to  $_{0}^{\circ}$ . In the example above the starting address of the SPC3 is set to  $_{0}^{\circ}$ .



## 7.1.5 Application with th 80 C 165



The pull up / pull down resistances in the drawing above are only relevant for a in circuit tester.

## Dual Port RAM Controller

The internal 1.5k RAM of the SPC3 is a Single Port RAM. Due to an integrated Dual Port RAM controller, the controller, however, permits an almost simultaneous access of both ports (bus interface and microsequencer interface). When there is a simultaneous access of both ports, the bus interface has priority. This provides for the shortest possible access time. If SPC3 is connected to a microcontroller with an asynchronous interface, SPC3 can evaluate the Ready signal.

## 7.1.6 Interface Signals

The data bus outputs are high-resistance during the reset phase. All outputs are switched to high-resistance in the test mode. (See block test.)

| Name        | Input/<br>Output | Туре            | Comments                             |
|-------------|------------------|-----------------|--------------------------------------|
| DB(70)      | I/O              | Tristate        | High-resistance for RESET            |
| AB(100)     | 1                |                 | AB(10) has a pull down resistor.     |
| MODE        | 1                |                 | Setting: syn/async interface         |
| XWR/E_CLOCK | 1                |                 | Intel: Write /Motorola: E-Clk        |
| XRD/R_W     | 1                |                 | Intel: Read /Motorola: Read/Write    |
| XCS         |                  |                 | Chip Select                          |
| ALE/AS      | Ι                |                 | Intel/Motorola: Address Latch Enable |
| DIVIDER     | 1                |                 | Scaling factor 2/4 for CLKOUT 2/4    |
| X/INT       | 0                | Tristate        | Polarity programmable                |
| XRDY/XDTACK | 0                | Tristate        | Intel/Motorola: Ready-Signal         |
| CLK         |                  |                 | 48 MHz                               |
| XINT/MOT    | 1                |                 | Setting: Intel/Motorola              |
| CLKOUT2/4   | 0                | Tristate        | 24/12 MHz                            |
| RESET       |                  | Schmitt-Trigger | Minimum of 4 clock pulse cycles      |

Figure 7.2: Microprocessor Bus Signals

## 7.2 UART

The transmitter converts the parallel data structure into a serial data flow. Request-to-Send (RTS) is generated before the first character. The XCTS input is available for connecting a modem. After RTS active, the transmitter must hold back the first telegram character until the XCTS modem activates.

The receiver converts the serial data flow into the parallel data structure. The receiver scans the serial data flow with the four-fold transmission speed. Stop bit testing can be switched off for test purposes ("DIS\_STOP\_CONTROL = 1", in mode register 0 or 'Set\_Param-Telegram' for DP). One requirement of the PROFIBUS protocol is that no rest states are permitted between the telegram characters. The SPC3 transmitter ensures that this specification is maintained. This following start bit test is switched off with the parameter setting "DIS\_START\_CONTROL = 1" (in mode register 0 or 'Set\_Param telegram' for DP).

Specified by the four-fold scan, a maximum distortion of the serial input signal of X = -47% to y = +22% is permissible.

## 7.3 ASIC Test

All output pins and I/O pins can be switched in the high-resistance state via the XTESTO test pin. An additional XTEST1 input is provided (more information upon request) to test the block internally with test automatic devices (not in the target hardware environment!).

| Pin No. | Name   | Function  |                             |
|---------|--------|-----------|-----------------------------|
| 34      | XTEST0 | VSS (GND) | All outputs high-resistance |
|         |        | VDD (+5V) | Normal SPC3 function        |
| 35      | XTEST1 | VSS (GND) | Various test modes          |
|         |        | VDD (+5V) | Normal SPC3 function        |

Figure 7.3: Test Support

XTEST0 and XTEST1 must be placed on  $V_{DD}$  (+5V) via external pull-up resistors.

## 8 Technical Data

## 8.1 Maximum Limit Values

| Parameter                         | Designation      | М         | Min      |           | Max                  |    |  |
|-----------------------------------|------------------|-----------|----------|-----------|----------------------|----|--|
|                                   |                  | AMI-Vers. | ST-Vers. | AMI-Vers. | ST-Vers.             |    |  |
| Supply Voltage                    | V <sub>DD</sub>  | -0,3      | -0,5     | 6         | 7                    | V  |  |
| Input Voltage                     | Vi               | -0,3      | -0,5     | VDD+0,3   | V <sub>DD</sub> +0,5 | V  |  |
| Input Current                     | I,               | -10       | k.A.     | 10        | k.A.                 | mA |  |
| Storage Temperature               | T <sub>Stg</sub> | -55       | -40      | 150       | 125                  | °C |  |
| Ambient Temperature               | ТА               | -40       | -40      | 85        | 85                   | ٥C |  |
| Lead Temp.<br>(Soldering, 10 sec) | TL               | k.A       | k.A.     | 300       | k.A.                 | ℃  |  |

Tabel 8.1: Maximum Limit Values

## 8.2 Permitted Operating Values

| Parameter              | Designation                       | М                   | in                  | M                   | Unit                |   |
|------------------------|-----------------------------------|---------------------|---------------------|---------------------|---------------------|---|
|                        |                                   | AMI-Vers.           | ST-Vers.            | AMI-Vers.           | ST-Vers.            |   |
| Supply Voltage         | V <sub>DD</sub>                   | 4,5                 | 4,75                | 5,5                 | 5,25                | V |
| Input High Voltage     | V <sub>IHC</sub>                  | 0,7 V <sub>DD</sub> | 0,7 V <sub>DD</sub> | k.A.                | V <sub>DD</sub>     | V |
| Input Low Voltage      | V <sub>ILC</sub>                  | k.A.                | 0                   | 0,3 V <sub>DD</sub> | 0,3 V <sub>DD</sub> | V |
| Schmitt-Trigger (CMOS) |                                   |                     |                     |                     |                     |   |
| Input High Voltage     | V <sub>P</sub> / V <sub>IHC</sub> | k.A.                | k.A.                | 0,8 VDD             | 4                   | V |
| Input Low Voltage      | V <sub>n</sub> / V <sub>ILC</sub> | 0,2 V <sub>DD</sub> | 1                   | k.A.                | k.A.                | V |
| Hysteresis Voltage     | V <sub>h</sub>                    | 1                   | k.A.                | k.A.                | k.A.                | V |
| Schmitt-Trigger (TTL)  |                                   |                     |                     |                     |                     |   |
| Input High Voltage     | V <sub>P</sub> / V <sub>IHC</sub> | k.A.                | k.A.                | 2,1                 | 2,4                 | V |
| Input Low Voltage      | V <sub>n</sub> / V <sub>ILC</sub> | 0,7                 | 0,6                 | k.A.                | k.A.                | V |
| Hysteresis Voltage     | V <sub>h</sub>                    | 0,4                 | k.A.                | k.A.                | k.A.                | V |

Tabel 8. 2: -Permitted Operating Values

## 8.3 DC-Specifikation of the I/O- Drivers

| Parameter           | Design.         |                       | Condition |                        | Min                  |           | Max      |   |
|---------------------|-----------------|-----------------------|-----------|------------------------|----------------------|-----------|----------|---|
|                     |                 | AMI-Vers.             | ST-Vers.  | AMI-Vers.              | ST-Vers.             | AMI-Vers. | ST-Vers. |   |
| Output High Voltage | V <sub>он</sub> | V <sub>DD</sub> =4,5V | k.A.      | V <sub>DD</sub> -0.5 * | V <sub>DD</sub> -0,5 | k.A.      | k.A.     | V |
| Output High Voltage | V <sub>он</sub> | V <sub>DD</sub> =4,5V | k.A.      | 3.65 **                | V <sub>DD</sub> -0,5 | k.A.      | k.A.     | V |
| Output Low Voltage  | V <sub>oL</sub> | V <sub>DD</sub> =4,5V | k.A.      | k.A.                   | k.A.                 | 0,4*      | 0,4      | V |
| Output Low Voltage  | V <sub>oL</sub> | V <sub>DD</sub> =4,5V | k.A.      | k.A.                   | k.A.                 | 0,55**    | 0,4      | V |

\* at an output load of 4mA

\*\* at an output load of 8mA

Tabel 8.3: DC-Specifikation of the I/O- Drivers

| n.c. | 5 | 10 | n.c. | n.c. | pF |
|------|---|----|------|------|----|
| no   | E | 10 |      |      |    |
| n.c. | Э | 10 | n.c. | n.c. | pF |
| n.c. | 5 | 10 | n.c. | n.c. | pF |
|      |   |    |      |      |    |

#### Tabel 8.4: Capacity of the I/O drivers

| Parameter             |        | Des     | Min             |           | Max      |           | unit     |    |
|-----------------------|--------|---------|-----------------|-----------|----------|-----------|----------|----|
|                       |        |         |                 | AMI-Vers. | ST-Vers. | AMI-Vers. | ST-Vers. |    |
| Input leakage current |        |         | Ь               | -1        | -1       | 1         | 1        | μA |
| Tristate current      | output | leakage | I <sub>oz</sub> | -10       | -10      | 10        | 10       | μΑ |

Tabelle 8.5: Leakage current of the output drivers

## 8.4 AC-Specification for the Output Drivers

| Signal lineeitung | Driver type | Driver po | wer      | Unit | kap. Last |
|-------------------|-------------|-----------|----------|------|-----------|
|                   |             | AMI-Vers. | ST-Vers. |      |           |
| DB(7:0)           | Tristate    | 8         | 8        | mA   | 100pF     |
| TXD               | Tristate    | 8         | 8        | mA   | 50pF      |
| RTS               | Tristate    | 8         | 8        | mA   | 50pF      |
| X/INT             | Tristate    | 8         | 4        | mA   | 50pF      |
| XREADY/XDSACK     | Tristate    | 8         | 4        | mA   | 50pF      |
| XDATAEXCH         | Tristate    | 8         | 8        | mA   | 50pF      |
| CLKOUT2/4         | Tristate    | 8         | 8        | mA   | 100pF     |

Hint:

The output power of the AMI-drivers is entspricht 8mA under the circumstances described in Tabel 8.3

### Tabel 8.6: AC-Specifikation of the output drivers

## 8.5 Timing Characteristics

The following is generally applicable: All signals beginning with 'X' are 'low active'. All signal runtimes are based on the capacitive loads specified in the table above.

## 8.5.1 SYS Bus Interface

Clock Pulse:

| No. | Parameter            | MIN  | MAX  | Unit |
|-----|----------------------|------|------|------|
|     | Clock pulse 48 Mhz : |      |      |      |
| 1   | Clock High Time      | 6.25 | 14.6 | ns   |
| 2   | Clock Low Time       | 6.25 | 14.6 | ns   |
| 3   | Rise Time            |      | 4    | ns   |
| 4   | Fall Time            |      | 4    | ns   |

## **Clock Pulse Timing:**



Distortions in the clock pulse signal are permitted up to a ratio of 40:60. At a threshold of 1.5 or 3.5 V:

#### Interrupts:

| No. | Parameter                                      | MIN | MAX | Unit |
|-----|------------------------------------------------|-----|-----|------|
| 1   | Interrupt Inactive Time (for EOI_Timebase = 0) | 1   | 1   | μS   |
|     | Interrupt Inactive Time                        | 1   | 1   | ms   |

| X/INT | <del>10</del> |  |
|-------|---------------|--|
| EOI   |               |  |

After acknowledging an interrupt with EO1, a min. of 1 us or 1 ms is expected in SPC3 before a new interrupt is output.

Reset:

SPC3 requires a minimum of 400 clock pulse cycles during the reset phase so that it can be reset correctly.

Reset



## 8.5.2 Timing in the Synchronous C32-Mode:

If SPC3 is operated at 48MHz, an 80C32 with a maximum clock pulse rate of 20MHz can be connected.

In the C32 mode, SPC3 saves the least significant addresses with the negative edge of ALE. At the same time, SPC3 expects the more significant address bits on the address bus. SPC3 generates a chipselect signal from the more significant address bits. The request for an access to SPC3 is generated from the negative edge of the read signal and from the positive edge of the write signal.

|     | AN                                                                           |         | Vers.                               | ST-V    | 'ers.                       |      |
|-----|------------------------------------------------------------------------------|---------|-------------------------------------|---------|-----------------------------|------|
| No. | Parameter                                                                    | Min     | Max                                 | Min     | Max                         | Unit |
| 1   | Address to ALE ↓ Setuptime                                                   | 10      |                                     | 10      |                             | ns   |
| 2   | Address (AB <sub>815</sub> ) Holdtime after XRD $\uparrow$ or XWR $\uparrow$ | 5       |                                     | 5       |                             | ns   |
| 3   | XRD $\downarrow$ to Data Out (Zugriff auf RAM)                               |         | 4T + 5                              |         | 3T+42.5                     | ns   |
|     | XRD $\downarrow$ to Data Out (Zugriff auf die Register)                      |         | (88,3)<br><b>4T + 18</b><br>(101,3) |         | (105)<br>4T+20.2<br>(103,5) | ns   |
| 4   | ALE $\downarrow$ to XRD $\downarrow$                                         | 20      |                                     | 20      | ,                           | ns   |
| 5   | Data Holdtime after XRD $\uparrow$                                           | 2       | 6                                   | 3.1     | 10.2                        | ns   |
| 6   | Data Holdtime after XWR ↑                                                    | 10      |                                     | 10      |                             | ns   |
| 7   | Data Setuptime to XWR $\uparrow$                                             | 10      |                                     | 10      |                             | ns   |
| 8   | XRD $\uparrow$ to ALE $\uparrow$                                             | 10      |                                     | 10      |                             | ns   |
| 10  | XRD-Pulse-Width                                                              | 6T - 10 |                                     | 6T – 10 |                             | ns   |
| 11  | XWR-Pulse-Width                                                              | 4T      |                                     | 4T      |                             | ns   |
| 12  | Address-Holdtime after ALE $\downarrow$                                      | 10      |                                     | 10      |                             | ns   |
| 13  | ALE-Puls-Width                                                               | 10      |                                     | 10      |                             | ns   |
| 14  | XRD, XWR Cycletime                                                           | 6T + 30 |                                     | 6T + 30 |                             | ns   |
| 15  | ALE $\downarrow$ to XWR $\downarrow$                                         | 20      |                                     | 20      |                             | ns   |
| 16  | XWR $\uparrow$ to ALE $\uparrow$                                             | 10      |                                     | 10      |                             | ns   |

Explanations:

| Т   | = | Clock pulse cycle (48MHz)       |
|-----|---|---------------------------------|
| TBD | = | to be defined                   |
| (1  | = | Access to the RAM               |
| (2  | = | Access to the registers/latches |
| (0) |   |                                 |

(3) = for T = 48MHz

8 12 ALE ⓓ 2 AB(7..0) VALID VALID DB(7..0) dressen Data Out Adressen -(4) G 3 10 XRD 14 XWR = log.'1'

Synchronous Intel-Mode, Processor-Read-Timing

## Synchronous Intel-Mode, Processor-Write-Timing



## 8.5.3 Timing in the Asynchronous Intel Mode (X86 Mode) :

In 80X86 operation, SPC3 acts like memory with ready logic. The access times depend on the type of accesses.

The request for an access to SPC3 is generated from the negative edge of the read signal or the positive edge of the write signal.

SPC3 generates the Ready signal synchronously to the fed in pulse. The Ready signal is reset when the read signal or write signal is deactivated. The data bus is switched to the Tristate with XRD = 1.

|     |                                                                    | AMI-             | Vers.                             | ST-V             | ers.                        |      |
|-----|--------------------------------------------------------------------|------------------|-----------------------------------|------------------|-----------------------------|------|
| No. | Parameter                                                          | Min              | Max                               | Min              | Max                         | Unit |
| 20  | Address-Setuptime to RXD $\downarrow$ or XWR $\downarrow$          | 0                |                                   | 0                |                             | ns   |
| 21  | XRD $\downarrow$ to Data valid (Zugriff auf RAM)                   |                  | 4T+5                              |                  | 3T+42.5                     | ns   |
|     | XRD $\downarrow$ to Data valid (Zugriff auf die Register)          |                  | (88,3)<br><b>4T+18</b><br>(101,3) |                  | (105)<br>4T+20.2<br>(103,5) | ns   |
| 22  | Address (AB <sub>100</sub> ) Holdtime after XRD or XWR $\uparrow$  | 0                |                                   | 0                |                             | ns   |
| 23  | XCS $\downarrow$ Setuptime to XRD $\downarrow$ or XWR $\downarrow$ | - 5              |                                   | -5               |                             | ns   |
| 24  | XRD-Puls-Width                                                     | 6T – 10<br>(115) |                                   | 6T – 10<br>(115) |                             | ns   |
| 25  | Data Holdtime after XRD ↑                                          | 2                | 6                                 | 3.1              | 10.2                        | ns   |
| 26  | Read/Write-Inactive-Time                                           | 10               |                                   | 10               |                             | ns   |
| 27  | XCS Holdtime after XRD $\uparrow$ or XWR $\uparrow$                | 0                |                                   | 0                |                             | ns   |
| 28  | XRD/XWR $\downarrow$ to XRDY $\downarrow$ (Normal Ready)           | 4T + 5           | 5T+ 14                            |                  | 5T + 16                     | ns   |
| 29  | XRD/XWR $\downarrow$ to XRDY $\downarrow$ (Early Ready)            | 3T + 5           | 4T+ 14                            |                  | 4T + 12                     | ns   |
| 30  | XREADY-Holdtime after XRD or XWR                                   | 4.3              | 12.8                              | 6                | 22                          | ns   |
| 31  | Data Setuptime to XWR ↑                                            | 10               |                                   | 10               |                             | ns   |
| 32  | Data Holdtime after XWR ↑                                          | 10               |                                   | 10               |                             | ns   |
| 33  | XWR-Pulse-Width *                                                  | 4T               |                                   | 4T               |                             | ns   |
| 34  | XRD, XWR Cycletime                                                 | 6Т               |                                   | 67               |                             | ns   |
| 35  | last XRD $\psi$ to XCS $\psi$                                      | 4T + 10          |                                   | 4T + 10          |                             | ns   |
| 36  | XCS ↑ to next XWR ↑                                                | 2T + 10          |                                   | 2T + 10          |                             | ns   |
| 37  | XWR $\uparrow$ to next XWR $\uparrow$ (XCS don't care)             | 6Т               |                                   | 6T               |                             | ns   |

#### Explanations:

T = Clock pulse cycle (48MHz) TBD = to be defined  $^{(1)}$  = Access to the RAM  $^{(2)}$  = Access to the registers/latches  $^{(3)}$  = For T = 48 MHz



Asynchronous Intel-Mode, Processor-Read-Timing

#### Asynchronous Intel-Mode, Processor-Write-Timing



## 8.5.4 Timing in the Synchronous Motorola Mode (E\_Clock-Mode, for example, 68HC11) :

For a CPU clockline through the SPC3, the output clock pulse (CLKOUT2/4) must be 4 times larger than the E\_CLOCK. That is, a clock pulse signal must be present at the CLK input that is **at least 10 times** larger than the desired system clock pulse (E\_CLOCK). The Divider-Pin must be placed on <log. 0> (divider 4). This results in an E\_CLOCK of 3MHz.

The request for a read access to SPC3 is derived from the positive edge of the E clock (in addition: XCS = 0, R W = 1). The request for a write access is derived from the negative edge of the E clock (in addition: XCS = 0, RW = 0.

|     | AMI-Vers.                                                         |                         | Vers.                               | ST-Vers.  |                      |      |
|-----|-------------------------------------------------------------------|-------------------------|-------------------------------------|-----------|----------------------|------|
| No. | Parameter                                                         | Min                     | Max                                 | Min       | Max                  | Unit |
| 40  | E_Clock-Pulse-Width                                               | 8.5.4.1.<br>T +<br>74.2 |                                     | 3T + 74.2 |                      | ns   |
| 41  | Address (AB <sub>10.0</sub> ) Setuptime to E_Clock $\uparrow$     | 10                      |                                     | 10        |                      | ns   |
| 42  | Address (AB <sub>10.0</sub> ) Holdtime after E_Clock $\downarrow$ | 5                       |                                     | 5         |                      | ns   |
| 43  | E_Clock ↑ to Data Active Delay                                    | 5.7                     | 17                                  | 5         |                      | ns   |
| 44  | E_Clock ↑ to Data valid (Zugriff auf RAM)                         |                         | 4T + 5                              |           | 3T + 44.2<br>(107)   | ns   |
|     | E_Clock $\uparrow$ to Data valid (Zugriff auf die Register)       |                         | (88,3)<br><b>4T + 18</b><br>(101,3) |           | 4T + 21.9<br>(105,2) | ns   |
| 45  | Data Holdtime after E_Clock $\downarrow$                          | 2                       | 6.3                                 | 4         | 12                   | ns   |
| 46  | R_W Setuptime to E_Clock ↑                                        | 10                      |                                     | 10        |                      | ns   |
| 47  | R_W Holdtime after E_Clock $\downarrow$                           | 5                       |                                     | 5         |                      | ns   |
| 48  | XCS Setuptime to E_Clock ↑                                        | 0                       |                                     | 0         |                      | ns   |
| 49  | XCS Holdtime after E_Clock $\downarrow$                           | 0                       |                                     | 0         |                      | ns   |
| 50  | Data Setuptime to E_Clock $\downarrow$                            | 10                      |                                     | 10        |                      | ns   |
| 51  | Data Holdtime after E_Clock $\downarrow$                          | 10                      |                                     | 10        |                      | ns   |

Explanations:

| Т   | = | Clock pulse cycle (48MHz)       |
|-----|---|---------------------------------|
| TBD | = | to be defined                   |
| (1  | = | Access to the RAM               |
| (2  | = | Access to the registers/latches |
| (3  | = | For $T = 48 \text{ MHz}$        |

## Synchronous Motorola-Mode, Processor-Read-Timing





Synchronous Motorola-Mode, Processor-Write-Timing

#### 8.5.5 Timing in the Asynchronous Motorola-Mode (for example, 68HC16) :

In the asynchronous Motorola mode, the SPC3 acts like memory with Ready logic, whereby the access times depend on the type of accesses.

The request for an access of SPC3 is generated from the positive edge of the AS signal (in addition: XCS='0',  $R_W='1'$ ). The request for a write access is generated from the positive edge of the AS signal (in addition: XCS='0',  $R_W='1'$ ).

|     |                                                             | AMI-Vers. |                                     | ST-V    | ers.                          |      |
|-----|-------------------------------------------------------------|-----------|-------------------------------------|---------|-------------------------------|------|
| No. | Parameter                                                   | Min       | Max                                 | Min     | Max                           | Unit |
| 60  | Address-Setuptime to AS $\downarrow$                        | 0         |                                     | 0       |                               | ns   |
| 61  | AS $\downarrow$ to Data valid (Zugriff auf RAM)             |           | 4T + 5                              |         | 3T + 45.2                     | ns   |
|     | AS $\downarrow$ to Data valid (Zugriff auf die Register)    |           | (88,3)<br><b>4T + 18</b><br>(101,3) |         | (108)<br>4T + 22.9<br>(106,2) | ns   |
| 62  | Address (AB <sub>100</sub> ) Holdtime after AS $\uparrow$   | 10        | ( - )-)                             | 10      |                               | ns   |
| 63  | R_W $\downarrow$ Setuptime to AS $\downarrow$               | 10        |                                     | 10      |                               | ns   |
| 64  | AS-Puls-Width (Read)                                        | 6T - 10   |                                     | 6T – 10 |                               | ns   |
| 65  | Data Holdtime after AS $\uparrow$                           | 2         | 6.3                                 | 4       | 12                            | ns   |
| 66  | AS-Inactive-Time                                            | 10        |                                     | 10      |                               | ns   |
| 67  | R_W Holdtime after AS ↑                                     | 10        |                                     | 10      |                               | ns   |
| 68  | XCS $\downarrow$ Setuptime to AS $\downarrow$               | -5        |                                     | -5      |                               | ns   |
| 69  | XCS Holdtime after AS ↑                                     | 0         |                                     | 0       |                               | ns   |
| 70  | AS $\downarrow$ to XDSACK $\downarrow$ (Read, Normal Ready) | 4T + 5    | 5T + 14                             |         | 5T + 16                       | ns   |
| 71  | AS $\downarrow$ to XDSACK $\downarrow$ (Read, Early Ready)  | 3T + 5    | 4T + 14                             |         | 4T + 16                       | ns   |
| 72  | XDSACK-Holdtime after AS ↑                                  | 4.3       | 12.7                                | 6       | 22                            | ns   |
| 73  | AS Cycletime                                                | 6Т        |                                     | 6T      |                               | ns   |
| 74  | Data Setuptime to AS $\uparrow$                             | 10        |                                     | 10      |                               | ns   |
| 75  | Data Holdtime after AS ↑                                    | 10        |                                     | 10      |                               | ns   |
| 76  | AS-Pulse-Width (Write) *                                    | 4T        |                                     | 4T      |                               | ns   |
| 77  | last AS $\psi$ (Read) to XCS $\psi$                         | 4T + 10   |                                     | 4T + 10 |                               | ns   |
| 78  | XCS ↑ to next AS ↑ (Write)                                  | 2T + 10   |                                     | 2T + 10 |                               | ns   |
| 79  | AS $\uparrow$ to next AS $\uparrow$ (Write, XCS don't care) | 6Т        |                                     | 67      |                               | ns   |

Explanations:

## SPC3

| T = | Pulse cycle | (48MHz) |
|-----|-------------|---------|
|-----|-------------|---------|

TBD = To Be Defined

(1 = Access to the RAM

- <sup>(2</sup> = Access to the register/latches
- $^{(3)}$  = For T = 48MHz

#### Asynchronous Motorola-Mode, Processor-Read-Timing



#### Asynchronous Motorola-Mode, Processor-Write-Timing



#### **SPC3 Hardware Description**

#### 8.5.6 Serial Bus Interface

| No. | Parameter                          | MIN | MAX | Unit |
|-----|------------------------------------|-----|-----|------|
|     | Pulse 48 MHz:                      |     |     |      |
| 1   | RTS ↑ to TxD Setup Time            | 4T  |     |      |
| 2   | RTS $\downarrow$ to TxD Hold Token | 4T  |     |      |

T = Clock pulse cycle (48MHz)



## **PROFIBUS Interface Center**

## 8.5.7 Housing

PQFP-44 Housing



SPC3





| Symbol         | M         | in       | T         | /p       | Max       |          |
|----------------|-----------|----------|-----------|----------|-----------|----------|
|                | AMI-Vers. | ST-Vers. | AMI-Vers. | ST-Vers. | AMI-Vers. | ST-Vers. |
| Α              | -         | -        | 2.13      | -        | 2.35      | 2.45     |
| A1             | 0.10      | 0.25     | 0.15      | -        | 0.25      | -        |
| A2             | 1.95      | 1.90     | 2.00      | 2.00     | 2.10      | 2.10     |
| D              | 13.65     | 13.65    | 13.90     | 13.90    | 14.15     | 14.15    |
| D1             | 9.90      | 9.90     | 10.00     | 10.00    | 10.10     | 10.10    |
| E              | 13.65     | 13.65    | 13.90     | 13.90    | 14.15     | 14.15    |
| E1             | 9.90      | 9.90     | 10.00     | 10.00    | 10.10     | 10.10    |
| L              | 0.65      | 0.78     | 0.80      | 0.88     | 0.95      | 1.03     |
| e BASIC        | -         | -        | 0.80      | 0.80     | -         | -        |
| В              | 0.30      | 0.30     | -         | 0.35     | 0.45      | 0.40     |
| C              | 0.13      | -        | -         | -        | 0.23      | 0.17     |
| α°             | 12        | -        | -         | 10       | 16        | -        |
| β°             | 0         | 0        | -         | -        | 7         | 7        |
| γ°             | 0         | 1        | -         | 5        | -         | 9        |
| G              | 0.13      | -        | -         | 0.20     | -         | -        |
| Н              | -         | -        | 1.95      | -        | -         | -        |
| J              | -         | -        | 0.30      | 0.30     | -         | -        |
| K              | 0.40      | -        | -         | -        | -         | -        |
| 2H (Footprint) | -         | -        | 3.90      | 3.90     | -         | -        |

## 8.5.8 Processing Instructions

**ESD protective measures** must be maintained for all electronic components.

SPC3 is a **cracking-endangered component** that must be handled as such.

A drying process must be carried out before SPC3 is processed. The component must be dried at **125<sup>o</sup> C** for **24 hours** and then be processed within **48 hours**. This drying process may be carried out once only because the component is soldered.

It must also be ensured that the SPC3's connections are not bent. Flawless processing can be guaranteed only if a planity of less than 0.1 mm is ensured. **SPC3** is released for infrared soldering with a soldering profile according to CECC00802.

## 9 PROFIBUS Interface

## 9.1 Pin Assignment

The data transmission is performed in RS 485 operating mode (i.e., physical RS 485). The SPC3 is connected via the following signals to the galvanically isolated interface drivers.

| Signal Name | Input/<br>Output | Function        |
|-------------|------------------|-----------------|
| RTS         | Output           | Request to send |
| TXD         | Output           | Sending data    |
| RXD         | Input            | Receiving data  |

The PROFIBUS interface is a 9-way, sub D, plug 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 (floating P5) Pin 7 - Free Pin 8 - A line Pin 9 - Free

The cable shield must be connected to the plug connector housing.

The free pins are described as optional in EN 50170 Vol. 2. If used, they should conform to the specifications in DIN192453.

## CAUTION:

The designations A and B of the lines on the plug connector refer to the designations in the RS 485 standard, and not the pin designation of driver ICs.

Keep the cable from driver to connector as short as possible.

Use of higher baud rates )i.e., 3 to 12 Mbaud) requires the use of new plug connectors. These connectors compensate for line interferences on all possible combinations of cables. 6ES7 972-0BB10-0XA0 with PG socket 6ES7 972-0BA10-0XA0 without PG socket

## 9.2 Example for the RS 485 Interface



Explanations of the circuitry:

The bus driver input EN2 has to be connected to low potential to ensure that after transmission of a telegram the ASIC is able to listen to the transmitted data.

To minimize the capacity of the bus lines the user should avoid additional capacities. The typical capacity of a bus station should be 15 ... 25 pF.

## 10 Appendix

## 10.1 Addresses

## **PROFIBUS User Organisation**

PNO Office Mr. Dr. Wenzel Haid- und Neu- Straße 7 76131 Karlsruhe Tel.: (0721) 9658-590

## Technical contact person at ComDeC in Germany

Siemens AG A&D SE RD73 Mr. Putschky

Address: Postfach 2355 90713 Fürth

Tel.: (0911) 750 - 2078 Fax: (0911) 750 - 2100 email: Gerd.Putschky@siemens.com

## Technical contact person at the PROFIBUS Interface Center in the United States

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

Fax : (423) - 262 - 2103

Your Partner: Ron Mitchell Tel.: (423) - 262 - 2687 email: Ron.Mitchell@sea.siemens.com

## **10.2 General Definition of Terms**

| ASPC2 | Advanced Siemens PROFIBUS Controller, 2 <sup>nd</sup> generation |
|-------|------------------------------------------------------------------|
| SPC2  | Siemens PROFIBUS Controller, 2 <sup>nd</sup> generation          |
| SPC3  | Siemens PROFIBUS Controller, 3 <sup>rd</sup> generation          |
| SPM2  | Siemens PROFIBUS Multiplexer, 2 <sup>nd</sup> generation         |
| LSPM2 | Lean Siemens PROFIBUS Multiplexer, 2 <sup>nd</sup> generation    |
| DP    | Distributed I/Os                                                 |
| FMS   | Fieldbus Message Specification                                   |
| MS    | MicroSequenzer                                                   |
| SM    | State Machine                                                    |
| SM    | State Machine                                                    |

## 10.3 Ordering of ASICs

For Ordering SPC3 ASICs please refer to your contact person in the Siemens local branch office and use one of the ordering numbers depending on the amount you want to order.

## 10.3.1 SPC3 (AMI)

| ASIC SPC 3 | 6ES7 195-0BD02-0XA0 | Small amount | 5    |
|------------|---------------------|--------------|------|
| (STEP C)   | 6ES7 195-0BD12-0XA0 | Single-Tray  | 96   |
|            | 6ES7 195-0BD22-0XA0 | Tray-Box     | 576  |
|            | 6ES7 195-0BD32-0XA0 | 8 Tray-Box   | 4608 |
|            | 6ES7 195-0BD42-0XA0 | 17 Tray-Box  | 9792 |

#### 10.3.2 SPC3 (ST)

| 6ES7 195-0BD01-0XA0 | Kleinverpack.                                                     | 5                                                                                                                                                                                                                           |
|---------------------|-------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6ES7 195-0BD11-0XA0 | Einzel-Tray                                                       | 96                                                                                                                                                                                                                          |
| 6ES7 195-0BD21-0XA0 | Tray-Box                                                          | 576                                                                                                                                                                                                                         |
| 6ES7 195-0BD31-0XA0 | 8 Tray-Box                                                        | 4608                                                                                                                                                                                                                        |
| 6ES7 195-0BD41-0XA0 | 17 Tray-Box                                                       | 9792                                                                                                                                                                                                                        |
|                     | 6ES7 195-0BD11-0XA0<br>6ES7 195-0BD21-0XA0<br>6ES7 195-0BD31-0XA0 | 6ES7 195-0BD01-0XA0       Kleinverpack.         6ES7 195-0BD11-0XA0       Einzel-Tray         6ES7 195-0BD21-0XA0       Tray-Box         6ES7 195-0BD31-0XA0       8 Tray-Box         6ES7 195-0BD41-0XA0       17 Tray-Box |

Order numbers for the lead free version

| 6ES7 195-0BD04-0XA0 | Evaluation pack; 6pcslead free- |
|---------------------|---------------------------------|
| 6ES7 195-0BD14-0XA0 | Single tray; 96pcslead free-    |
| 6ES7 195-0BD24-0XA0 | Try box; 960pcslead free-       |
| 6ES7 195-0BD34-0XA0 | 10 tray box; 4800pcslead free-  |

## 11 Appendix A: Diagnostics Processing in PROFIBUS DP

## 11.1 Introduction

PROFIBUS DP offers a convenient and multi-layer possibility for processing diagnostics messages on the basis of error states.

As soon as a diagnostics request is required, the slave will respond in the current data exchange with a high priority reply message. In the next bus cycle, the master then requests a diagnostics from this slave, instead of executing normal data exchange.

Likewise, any master (not only the assigned master!) can request a diagnostics from the slave. The diagnostics information of the DP slave consists of standard diagnostics information (6 bytes), and can be supplemented by user-specific diagnostics information.

In the case of the ASICs, SPM2, and LSPM2, extensive diagnostics is possible through corresponding wiring. In the case of the intelligent SPCx solution, adapted and convenient diagnostics processing can be carried out through programming.

## **11.2 Diagnostics Bits and Expanded Diagnostics**

Parts of the standard diagnostics information are permanently specified in the firmware and in the microprogram of the ASICs through the state machine.

Request diagnostics only once ("update\_diag(..)") if an error is present or changes. By no means should diagnostics be requested cyclically in the data exchange state; otherwise, the system will be burdened by redundant data.

Three information bits can be influenced by the application:

#### 11.2.1 STAT\_DIAG

Because of a state in the application, the slave can't make valid data available. Consequently, the master only requests diagnostics information until this bit is removed again. The PROFIBUS DP state is, however, Data\_Exchange, so that immediately after the cancellation of the static diagnostics, data exchange can start.

Example: failure of supply voltage for the output drivers

#### 11.2.2 EXT\_DIAG

If this bit is set, a diagnostics entry **must** be present in the user-specific diagnostics area. If this bit is not set, a status message can be present in the user-specific diagnostics area.

User-Specific Diagnostics

The user-specific diagnostics can be filed in three different formats:

Device-Specific Diagnostics:

The diagnostics information can be coded as required.

|                                                             | Bit 7 Bit 6 Bit 5-0                      |  |  |  |  |
|-------------------------------------------------------------|------------------------------------------|--|--|--|--|
| Header Byte <b>0 0</b> Block length in bytes, including hea |                                          |  |  |  |  |
| Diagnostics Field                                           | Coding of diagnostics is device-specific |  |  |  |  |
|                                                             | Can be specified as required             |  |  |  |  |

etc.

Identifier-Related Diagnostics:

For each identifier byte assigned during configuration (for example, 0 x 10 for 1 byte input), a bit is reserved.

In the case of a modular system with an identifier byte each per module, module-specific diagnostics can be indicated. One bit respectively will then indicate diagnostics per module.

| Header Byte <b>0 1</b> Block length in bytes including header |               | Bit 7 | Bit 6 | Bit 5-0                             |     |
|---------------------------------------------------------------|---------------|-------|-------|-------------------------------------|-----|
|                                                               | Header Byte   | 0     | 1     | Block length in bytes including hea | der |
| Bit Structure 1 1                                             | Bit Structure | 1     |       |                                     | 1   |

Identifier Byte 7 has

diagnostics

diagnostics

↑ Identifier Byte 0 has

Channel-Related Diagnostics:

In this block, the diagnosed channels and the diagnostics cause are entered in sequence. Three bits are required per entry.

|                     | Bit 7             | Bit 6 | Bit 5     | Bit 4 - 0            |
|---------------------|-------------------|-------|-----------|----------------------|
| Header Byte         | 1                 | 0     | Identifie | cation Number        |
| Channel Number      | Coding<br>Input/C |       | Channe    | el Number            |
| Type of Diagnostics | Coding<br>Channe  |       |           | Coding<br>Error Type |

Coding of the error type is in part manufacturer-specific; other codings are specified in the Standard.

Example:

|     | 1                    |     |     |                        |   |   | 1 |                                                               |
|-----|----------------------|-----|-----|------------------------|---|---|---|---------------------------------------------------------------|
| 0   | 0                    | 0   | 0   | 0                      | 1 | 0 | 0 | Device-related diagnostics.                                   |
| De  | evic                 | e-s | pec | cific                  | ; |   |   | Meaning of the bits                                           |
| dia | diagnostics field of |     |     | is specified           |   |   |   |                                                               |
| ler | length 3             |     |     | manufacturer-specific. |   |   |   |                                                               |
| 0   | 1                    | 0   | 0   | 0                      | 1 | 0 | 1 | Identifier-related diagnostics.                               |
|     |                      |     |     |                        |   |   | 1 | Identification number 0 has diagnostics.                      |
|     |                      |     | 1   |                        |   |   |   |                                                               |
|     |                      |     |     |                        |   | 1 |   | Identification number 18 has diagnostics.                     |
|     |                      |     |     |                        |   |   |   |                                                               |
|     |                      |     |     |                        |   |   |   |                                                               |
| 1   | 0                    | 0   | 0   | 0                      | 0 | 0 | 0 | <b>Channel-</b> related diagnostics, identification number 0. |
| 0   | 0                    | 0   | 0   | 0                      | 0 | 1 | 0 | Channel 2.                                                    |
| 0   | 0                    | 0   | 1   | 0                      | 1 | 0 | 0 | Overload, channel organized bit by bit.                       |
| 1   | 0                    | 0   | 0   | 1                      | 1 | 0 | 0 | Channel-related diagnostics identification number 12.         |
| 0   | 0                    | 0   | 0   | 0                      | 1 | 1 | 0 | Channel 6.                                                    |
| 1   | 0                    | 1   | 0   | 0                      | 1 | 1 | 1 | Upper limit evalue xceeded, channel organized word by word.   |
|     |                      |     |     |                        |   |   |   |                                                               |

#### Status

If the Bit EXT\_DIAG is set to 0, data is viewed as status info from the system view. f.e. cancellation of the error triggering the diagnostics.

### 11.2.3 EXT\_DIAG\_OVERFLOW

This bit is set if more diagnostics data is present than will fit in the available diagnostics data area. For example, more channel diagnostics could be present than the send buffer or the receive buffer makes possible.

## **11.3 Diagnostics Processing from the System View**

Inasmuch as it is bus-specific, the diagnostics information of the slaves is managed solely by the master interface (for example, IM308B).

All diagnostics from the application are made available to the S6 program via corresponding data bytes. If the **External Diagnostics bit** is set, the slaves to be diagnosed can already be evaluated in the diagnostics overview. Then, a special error routine can be called up, whereby the standard diagnostics information and the user-specific information can be evaluated.

After eliminating the current diagnostics situation, this can be signalled as a status message from the slave **without setting the external diagnostics bit**.

With the COM ET200, a comfortable diagnostics tool is available on-line. At the present time, identificationrelated diagnostics information can be displayed with it in plain text. In later phases, channel-related diagnostics will also be supported. User-specific diagnostics are only displayed if the EXT\_DIAG bit is set.

Set Program File C:PNO4..ET.200 SIMATIC S5 / COM ET 200 SINGLE DIAGNOSTICS Station Number: 30 Station Type: ET 200U-COMBI Station Designation: Station4 Station Status: Slave not ready for data exchange External diagnostics Configuration error **Device-Related Diagnostics** KH = 01 Identification-Related Diagnostics Slot 3 Active F1 F2 F3 F4 F5 F6 F7 F8 EXIT

The figure below shows a screen during data processing, for example:

In the type file for the COM ET200 and in the GSD [device master data] file, fields are already provided for referencing device-specific bits and pertinent plain text messages (for example, Bit 7: "I have had it; good night!").

# 12 Appendix B: Useful Information

## 12.1 Data format in the Siemens PLC SIMATIC

The SPC3 always sends data from the beginning of the buffer till the end. 16Bit values are shown in the Motorola format. For example:

Buffer pointer

Buffer pointer +1

high byte

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

SIEMENS Aktiengesellschaft

© Siemens AG Subject to change without prior notice Printed in the Fed. Rep. of Germany