

## 256 x 256 DIGITAL SWITCHING MATRIX

 256 INPUT AND 256 OUTPUT CHANNEL DIGI-TAL SWITCHING MATRIX

SGS-THOMSON MICROELECTRONICS

- BUILDING BLOCK DESIGNED FOR LARGE CAPACITY ELECTRONIC EXCHANGES, SUB-SYSTEMS AND PABX
- NO EXTRA PIN NEEDED FOR NOT-BLOCK-ING SINGLE STAGE AND HIGHER CAPACITY SYNTHESIS BLOCKS (512 or 1024 channels)
- EUROPEAN TELEPHONE STANDARD COM-PATIBLE (32 serial channels per frame)
- PCM INPUTS AND OUTPUTS MUTUALLY COMPATIBLE
- INPUT-OUTPUT CHANNEL CONNECTIONS STORED AND MODIFIED VIA ON CHIP 8-BIT PARALLEL MICROPROCESSOR INTERFACE
- 6 MAIN "FUNCTIONS" OR "INSTRUCTIONS" AVAILABLE
- TYPICAL BIT RATE : 2Mbit/s
- TYPICAL SYNCHRONIZATION RATE : 8KHz (time frame is 125µs)
- 5V POWER SUPPLY WITH INTERNALLY GENERATED BIAS VOLTAGE
- MOS & TTL INPUT/OUTPUT LEVELS COM-PATIBLE
- SGS-THOMSON N-CHANNEL SILICON GATE HIGH DENSITY MOS PROCESS

#### Main instructions controlled by the microprocessor interface

- CHANNEL CONNECTION/DISCONNECTION
- CHANNEL DISCONNECTION
- INSERTION OF A BYTE ON A PCM OUTPUT CHANNEL

- TRANSFER TO THE MICROPROCESSOR OF A SINGLE PCM OUTPUT CHANNEL SAMPLE
- TRANSFER TO THE MICROPROCESSOR OF A SINGLE OUTPUT CHANNEL CONTROL WORD
- TRANSFER TO THE MICROPROCESSOR OF A SELECTED 0 CHANNEL PCM INPUT DATA



| Symbol | Parameter                       | Value       | Unit |
|--------|---------------------------------|-------------|------|
| Vcc    | Supply Voltage                  | - 0.3 to 7  | V    |
| Vi     | Input Voltage                   | - 0.3 to 7  | V    |
| Vo     | Off State Output Voltage        | 7           | V    |
| Ptot   | Total Package Power Dissipation | 1.5         | W    |
| Tstg   | Storage Temperature Range       | - 65 to 150 | °C   |
| Tap    | Operating Temperature Range     | 0 to 70     | °C   |

Stresses above those listed under " Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress ratings only and functional operation of the device at these or any other conditions above those indicated in the operating conditions of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

#### March 1989

#### ABSOLUTE MAXIMUM RATINGS

#### **PIN CONNECTIONS**

| OUT PCM3    |      | 40 1 1 | DUT PCM4  |
|-------------|------|--------|-----------|
| OUT PCM2    | 2    | 39 1 0 | OUT PCM5  |
| OUT PCM1    | 2    | 381    | DUT PC M6 |
| OUT PCMD    | 4    | 37 1 0 | OUT PCM7  |
| BIAS        | 5    | .361   | <b>GR</b> |
| CLOCK       | 6    | 35     | WR        |
| SYNC        | 7    | 34     | CSI       |
| IN P PCM7 [ | 8    | 330    | C52       |
| INP PCM6    | 9    | 32     | RESET     |
| INPPCMS     | M088 | 31 11  | Vss       |
| INPPCM4     |      | 30     | c/D       |
| INPPCM3     | 2    | 291    | A1        |
| INPPCM2     | 3    | 2801   | 51        |
| INPPCMI II  | 4    | 271    | A 2       |
| INPPCM0 1   | 5    | :6)    | 52        |
| Vcc [1      | 6    | 25     | DR        |
| D7 [11      | 7    | 24     | D0        |
| D6 11       |      | 23     | D1        |
| D5 []       | 9    | 22     | D2        |
| D4 12       | 0    | 21 L   | D3        |

#### **EXCHANGE NETWORKS APPLICATIONS**

256 PCM links network (160 or 192 DSM) : the 32 x 32 link module shown on the next page.

2048 PCM links network (1792 or 2048 DSM) : the 256 x 256 link network is shown above.





#### EXCHANGE NETWORKS APPLICATIONS (continued)

Single Stage/Sixteen Devices Configuration (32 by 32 links or 1024 channels).





#### **BLOCK DIAGRAM**



#### **RECOMMENDED OPERATING CONDITIONS**

| Symbol          | Parameter                       | Value        | Unit |
|-----------------|---------------------------------|--------------|------|
| Vcc             | Supply Voltage                  | 4.75 to 5.25 | V    |
| Vi              | Input Voltage                   | 0 to 5.25    | V    |
| Vo              | Off State Input Voltage         | 0 to 5.25    | V    |
| CLOCK Freq.     | Input Clock Frequency           | 4.096        | MHz  |
| SYNC Freq.      | Input Synchronization Frequency | 8            | KHz  |
| T <sub>op</sub> | Operating Temperature           | 0 to 70      | °C   |

#### CAPACITANCES (measurement freq. = 1MHz ; Top = 0 to 70°C ; unused pins tied to VSS)

| Symbol           | Parameter          | Pins                              | Min. | Тур. | Max. | Unit |
|------------------|--------------------|-----------------------------------|------|------|------|------|
| Ci               | Input Capacitance  | 6 to 15 ; 26 to 30 ; 32 to 36     |      |      | 5    | pf   |
| C <sub>I/O</sub> | I/O Capacitance    | 20 to 24                          |      |      | 15   | pf   |
| Co               | Output Capacitance | 1 to 4 ; 17 to 19 ; 25 ; 37 to 40 |      |      | 10   | pf   |

# D.C. ELECTRICAL CHARACTERISTICS (T<sub>amb</sub> = 0 to 70°C, V<sub>CC</sub> = 5V $\pm$ 5%) All D.C. characteristics are valid 250µs after V<sub>CC</sub> and clock have been applied.

| Symbol          | Parameter                | Pins                                        | Test Conditions                                                                                                                                                                                         | Min.  | Тур. | Max. | Unit |
|-----------------|--------------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|------|------|
| VILC            | Clock Input Low Level    | 6                                           |                                                                                                                                                                                                         | - 0.3 |      | 0.8  | V    |
| VIHC            | Clock Input High Level   | 6                                           |                                                                                                                                                                                                         | 2.4   |      | Vcc  | V    |
| VIL             | Input Low Level          | 7 to 15<br>20 to 24<br>26 to 30<br>32 to 36 |                                                                                                                                                                                                         | - 0.3 |      | 0.8  | V    |
| VIH             | Input High Level         | 7 to 15<br>20 to 24<br>26 to 30<br>32 to 36 |                                                                                                                                                                                                         | 2.0   |      | Vcc  | v    |
| VOL             | Output Low Level         | 17 to 25                                    | I <sub>OL</sub> = 1.8mA                                                                                                                                                                                 |       |      | 0.4  | V    |
| Vон             | Output High Level        | 17 to 25                                    | I <sub>OH</sub> = 250µА                                                                                                                                                                                 | 2.4   |      |      | V    |
| VOL             | PCM Output Low Level     | 1 to 4<br>37 to 40                          | I <sub>OL</sub> = 2.0mA                                                                                                                                                                                 |       |      | 0.4  | V    |
| l <sub>iL</sub> | Input Leakage Current    | 6 to 15<br>26 to 30<br>32 to 36             | $V_{IN} = 0$ to $V_{CC}$                                                                                                                                                                                |       |      | 10   | μA   |
| I <sub>DL</sub> | Data Bus Leakage Current | 17 to 24                                    | $\label{eq:VIN} \begin{array}{l} V_{IN} = 0 \text{ to } V_{CC} \\ V_{CC} \text{ applied } : \text{Pins 35} \\ \text{and 36 tied to } V_{CC}, \text{ after} \\ \text{Device Initialization} \end{array}$ |       |      | ± 10 | μA   |
| lcc             | Supply Current           | 16                                          | Clock Freq. = 4.096MHz                                                                                                                                                                                  |       |      | 180  | mA   |



A.C. ELECTRICAL CHARACTERISTICS ( $T_{amb} = 0$  to 70°C,  $V_{CC} = 5V \pm 5\%$ ) All A.C. characteristics are valid 250µs after  $V_{CC}$  and clock have been applied.  $C_L$  is the max. capacitive load and  $R_L$  the test pull up resistor.

| Signal                  | Symbol                                           | Parameter                                                                                                                                                                                             | Test Conditions                                                                                          | Min.                                                | Typ. | Max.     | Unit                       |
|-------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-----------------------------------------------------|------|----------|----------------------------|
| CK<br>(clock)           | tск<br>twL<br>twн<br>tя<br>tF                    | Clock Period<br>Clock Low Level Width<br>Clock High Level Width<br>Rise Time<br>Fall Time                                                                                                             |                                                                                                          | 230<br>100<br>100                                   |      | 25<br>25 | ns<br>ns<br>ns<br>ns       |
| SYNC                    | ts∟<br>t <sub>HL</sub><br>tsн<br>t <sub>WH</sub> | Low Level Setup Time<br>Low Level Hold Time<br>High Level Setup Time<br>High Level Width                                                                                                              |                                                                                                          | 80<br>40<br>80<br>t <sub>ск</sub>                   |      |          | ns<br>ns<br>ns<br>ns       |
| PCM Input<br>Busses     | ts<br>t <sub>H</sub>                             | Setup Time<br>Hold Time                                                                                                                                                                               |                                                                                                          | - 5<br>45                                           |      |          | ns<br>ns                   |
| PCM<br>Output<br>Busses | ted min                                          | Propagation time<br>referred to CK low level<br>Propagation time<br>referred to CK high level                                                                                                         | $C_{L} = 50 \text{pf.} \text{ R}_{L} = 2 \text{K}$<br>$C_{L} = 50 \text{pf.} \text{ R}_{L} = 2 \text{K}$ | 45                                                  |      | 200      | ns<br>ns                   |
| RESET                   | t <sub>SL</sub><br>t <sub>HL</sub><br>tsн<br>twн | Low Level Setup Time<br>Low Level Hold Time<br>High Level Setup Time<br>High Level Width                                                                                                              |                                                                                                          | 100<br>50<br>90<br>t <sub>ск</sub>                  |      |          | ns<br>ns<br>ns<br>ns       |
| WR                      | twL<br>twн<br>trep<br>tsн<br>tнн<br>tr           | Low Level Width<br>High Level Width<br>Repetition Interval<br>between Active Pulses<br>High Level Setup Time<br>to Active Read Strobe<br>High Level Hold Time<br>from Active Read Strobe<br>Rise Time | t <sub>REP</sub> = 40 + 2 t <sub>CK +</sub><br>+ t <sub>WL(CK) +</sub><br>+ t <sub>R(CK)</sub>           | 150<br>t <sub>СК</sub><br>see<br>formula<br>0<br>20 |      | 60       | ns<br>ns<br>ns<br>ns<br>ns |
|                         | t <sub>F</sub>                                   | Fall Time                                                                                                                                                                                             |                                                                                                          |                                                     |      | 60       |                            |
| RD                      | twl<br>twh<br>trep<br>tsh                        | Low Level Width<br>High Level Width<br>Repetition Interval<br>between Active Pulses<br>High Level Setup Time<br>to Active Read Strobe                                                                 | $t_{REP} = 40 + 2 t_{CK} + t_{WL(CK)} + t_{R(CK)}$                                                       | 180<br>tск<br>see<br>formula<br>0                   |      |          | ns<br>ns<br>ns             |
|                         | tнн<br>te<br>te                                  | High Level Hold Time<br>from Active Write Strobe<br>Rise Time<br>Fall Time                                                                                                                            |                                                                                                          | 20                                                  |      | 60<br>60 | ns<br>ns                   |



#### A.C. ELECTRICAL CHARACTERISTICS (continued)

| Signal                 | Symbol                    | Parameter                                                        | Test Conditions              | Min.                      | Тур. | Max.               | Uni |
|------------------------|---------------------------|------------------------------------------------------------------|------------------------------|---------------------------|------|--------------------|-----|
| CS1,<br>CS2            | ISL(CS-WR)                | Low level setup time<br>to WR falling edge                       | Active Case                  | 0                         |      |                    | ns  |
|                        | tHL(CS-WR)                | Low level hold time<br>from WR rising edge                       | Active Case                  | 0                         |      |                    | ns  |
|                        | ISH(CS-WR)                | High level setup time to WR falling edge                         | Inactive Case                | 0                         |      |                    | ns  |
|                        | THH(CS-WR)                | High level hold time<br>from WR rising edge                      | Inactive Case                | 0                         |      |                    | ns  |
|                        | ISL(CS-RD)                | Low level setup time<br>to RD falling edge                       | Active Case                  | 0                         |      |                    | ns  |
|                        | tHL (CS-RD)               | Low level hold time<br>from RD rising edge                       | Active Case                  | 0                         |      |                    | ns  |
|                        | tSH(CS-RD)                | High level setup time<br>RD falling edge                         | Inactive Case                | 0                         |      |                    | ns  |
|                        | tHH(CS-RD)                | High level hold time<br>from RD rising edge                      | Inactive Case                | 0                         |      |                    | ns  |
| C/D                    | ts(C/D-WR)                | Setup time to write strobe end                                   |                              | 130                       |      |                    | ns  |
|                        | tH(C/D-WR)                | Hold time from<br>write strobe end                               |                              | 25                        |      |                    | ns  |
|                        | ts(C/D-RD)                | Setup time to read<br>strobe start                               |                              | 20                        |      |                    | ns  |
|                        | tH(C/D-RD)                | Hold time from read<br>strobe end                                |                              | 25                        |      |                    | ns  |
| A1, S1,<br>A2, S2      | ts(match-WR)              | Setup time to write<br>strobe end                                |                              | 130                       |      |                    | ns  |
| (match<br>inputs)      | t <sub>H</sub> (match-WR) | Hold time from<br>strobe end                                     |                              | 25                        |      |                    | ns  |
| inputo)                | ts(match-RD)              | Setup time to read<br>strobe start                               |                              | 20                        |      |                    | ns  |
|                        | t <sub>H</sub> (match-RD) | Hold time from read<br>strobe end                                |                              | 25                        |      |                    | ns  |
| DR<br>(data            | t <sub>W</sub>            | Low state width<br>DR output delay                               | Instructions 5 and 6         |                           |      | 2.t <sub>СК</sub>  | ns  |
| ready)                 |                           | from write strobe end<br>(active command)                        | Instruction 5, $C_L = 50 pf$ | <b>5</b> .t <sub>СК</sub> |      | 14.t <sub>СК</sub> | ns  |
| D0 to D7<br>(interface | ts(BUS-WR)                | Input setup time to write strobe end                             |                              | 130                       |      |                    | ns  |
| bus)                   | t <sub>H(BUS-WR)</sub>    | Input hold time<br>from write strobe end                         |                              | 25                        |      |                    | ns  |
|                        | tpd(bus)                  | Propagation time<br>from (active) falling<br>Edge of read strobe | C <sub>L</sub> = 200pF       |                           |      | 120                | ns  |
|                        | t <sub>HZ(BUS)</sub>      | Propagation time<br>from (active) rising                         |                              |                           |      |                    |     |
|                        |                           | Edge of read strobe<br>to high impedance state                   |                              |                           |      | 80                 | ns  |



#### PCM TIMING, RESET



#### WRITE OPERATION TIMING





#### **READ OPERATION TIMING**



#### **GENERAL DESCRIPTION**

The M088 is intended for large telephone switching systems, mainly central exchanges, digital line concentrators and private branch exchanges where a distributed microcomputer control approach is extensively used. It consists of a speech memory (SM), a control memory (CM), a serial/parallel and a parallel/serial converter, an internal parallel bus. an interface (8 data lines, 11 control signals) and dedicated control logic. By means of repeated clock division two timebases are generated. These are preset from an external synchronization signal to two specific count numbers so that sequential scanning of the bases give synchronous addresses to the memories and I/O channel controls. Different preset count numbers are needed because of processing delays and data path direction. The timebase for the input channels is delayed and the timebase for output channels is advanced with respect to the actual time. Each serial PCM input channel is converted to parallel data and stored in the speech memory at the beginning of any new time slot (according to first timebase) in the location determined by input pin number and time slot number. The control memory CM maintains the correspondences between input and output channels. More exactly, for any output pin/output channel combination the control memory gives either the full address of the speech memory location involved in the PCM transfer or an 8-bit word to be supplied to the parallel/serial output converter. A 9<sup>th</sup> bit at each CM location defines the data source for output links, low for SM, high for CM.

The late timebase is used to scan the output channels and to determine the pins to be serviced within each channel ; enough idle cycles are left to the microprocessor for asynchronous instruction processing. Two 8-bit registers OR1 and OR2 supply feedback data for control or diagnostic purposes ; OR1 comes from internal bus i.e. from memories, OR2 gives an opcode copy and additional data to the microcomputer. A four byte-five bit stack register and an instruction register, under microcomputer control, store input data available at the interface.

Dedicated logic, under control of the microprocessor interface, extracts the 0 channel content of any selected PCM input bus, using spare cycles of SM.



#### PIN DESCRIPTION

#### D7 to D0 (pins 17 to 24)

Data bus pins. The bidirectional bus is used to transfer data and instructions to/from the microprocessor. D0 is the least significant digit. The output bus is 8 bits wide ; input is only 5 bits wide.

The bus is tristate and cannot be used while RESET is held low.

The meaning of input data. such as bus or channel numbers, and of expected output data is specified in detail by the instruction description.

#### C/D (pin 30)

Input control pin, select pin. In a write operation C/D = 0 qualifies any bus content as data, while C/D = 1 qualifies it as an opcode. In a read\_operation OR1 is selected by C/D = 0, OR2 by C/D = 1.

#### A1, S1, A2, S2 (pins 26 to 29)

Address select or match pins. In a multi-chip configuration (e.g. a single stage matrix expansion), using the same CS pins, the match condition (A1 = S1 and A2 = S2) leaves the command instruction as defined ; on the contrary the mismatch condition modifies the execution as follows : instructions 1 and 3 are reversed to channel disconnection, instruction 5 is unaffected, instructions 2-4-6 are cancelled (not executed).

Bus reading takes place only on match condition, instruction flow is in any case affected.

Each pins couple is commutative : in a multichip configuration pins S1 and S2 give a hard-wired address selection for individual matrixes, while in single configuration S1 and A1 or S2 and A2 are normally tied together.

#### CS1, CS2 (pins 33, 34)

Commutative chip select pins. They enable the device to perform valid read/write operations (active low). Two pins allow row/column selection with different types of microprocessors ; normally one is tied to ground.

#### WR (pin 35)

Pin WR, when CS1 and CS2 are low, enables data transfer from microprocessor to the device. Data or opcode and controls are latched on WR rising edge. Because of internal clock resynchronization one single additional requirement is recommended in order to produce a simultaneous instruction execution in a multichip configuration : WR rising edge has to be 20 to 20 +  $t_{WL(CK)}$  nsec late relative to clock falling edge.

#### RD (pin 36)

When CS1 and CS2 are low and match condition exists. a low level on RD enables a register OR1 or OR2 read operation, through the bidirectional bus.

In addition, the rising edge of RD latches C/D and the match condition pins in order to direct the internal flow of operations. Because of internal clock resynchronization, one single additional requirement is recommended in order to produce a simultaneous instruction flow in a multichip configuration : the RD rising edge has to be 20 to 20 +  $t_{WL(CK)}$  nsec late relative to clock falling edge.

#### **DR** (pin 25)

Data ready. Normally high, DR output pin goes low to tell the microprocessor that :

a) the instruction code was found to be invalid ;

b) executing instruction 5 an active output channel was found in the whole matrix array, that is a CM word not all "ones" was found in a configuration of devices sharing the same CS pins :

c) executing instruction 6 "0 channel extraction" took place and OR2 was loaded with total number of messages inserted on 0 time slot.

DR is active about two clock cycles in case **b** and **c**; in case a it is left low until a valid instruction code is supplied.

#### RESET (pin 32)

RESET control pin is normally used at the very beginning to initialize the device or the network. Any logical status is reset and CM is set to all "ones" after RESET going low.

The internal initialization routine takes one time frame whatever the RESET width on low level (minimum one cycle roughly), but it is repeated an integer number of time frames as long as RESET is found low during 0 time slot.

Initialization pulls the interface bus immediately to a high impedance state. After the CM has been set to all "ones" the PCM output channels are also set to high impedance state (that is pulled to "ones").

#### CLOCK (pin 6)

Input master clock. Typical frequency is 4.096MHz. First division gives an internal clock controlling the input and output channels bit rate.

#### SYNC (pin 7)

SGS-THOMSON

Input synchronization signal is active low. Typical frequency is 8kHz.



Internal time bases are forced by synchronism to an assigned count number in order to restore channels and bit sequential addressing to a known state. Count difference between the bases is 32, corresponding to two time slots, that is the minimum PCM propagation time, or latency time.

#### INP PCM 7 to INP PCM 0 (pins 8 to 15)

PCM input busses or pins ; they accept a standard 2Mbit/s rate. Bit 1 (sign bit) is the first of the serial sequence ; in a parallel conversion it is left adjusted as the most significant digit.

OUT PCM 7 to OUT PCM 0 (pins 37 to 40 and 1 to 4)

PCM output busses or pins ; bit rate and organization are the same as input pins.

Output buffers are open drain type in order to simplify wired-or connections and minimize current spike problems in multichip configuration systems.

The device drives the output channels theoretically one bit time before input channels are needed by specifications : this feature allows inputs and outputs to be tied together cancelling any analog delay of digital outputs up to

tDEL max = tbit - tPD(PCM)max + tPD(PCM)min

#### BIAS (pin 5)

Internally generated bias voltage (- 2.5 to - 3.0V for V<sub>CC</sub> in the operating range). A max. 220pf capacitor connected to pin 5 provides improved filtering.

#### MIXED RD & WR OPERATIONS

In principle RD and WR operations are allowed in any order within specification constraints.

In practive, only one control pin is low at any given time when CS1 and CS2 are enabled.

If by mistake or hardware failure both  $\overline{RD}$  and  $\overline{WR}$  pins are low, the interface bus is internally pushed to tristate condition as long as WR is held low and input registers are protected.

Registers OR1 and OR2 can be read in any order with a single RD strobe using C/D as multiplexing control; never the less this procedure is not recommended because the device is directed for instruction flow only according to data latched by RD rising edge.

Multiple RD operations of the same kind are allowed without affecting the instruction flow : only "new" OR1 or OR2 read operations step the flow.

Input and output registers are held for sure in the previous state for the first 3 cycles following an opcode or an OR2 read.

#### FUNCTIONAL DESCRIPTION OF SPECIFIC MICROPROCESSOR OPERATIONS

The device, under microprocessor control, performs the following instructions :

1 CHANNEL CONNECTION/DISCONNECTION

2 CHANNEL DISCONNECTION

3 INSERTION OF A BYTE ON A PCM OUTPUT CHANNEL/CHANNEL DISCONNECTION)

4 TRANSFER OF A SINGLE PCM OUTPUT CHAN-NEL SAMPLE

5 TRANSFER OF A SINGLE OUTPUT CHANNEL CONTROL WORD

6 TRANSFER OF A SELECTED 0 CHANNEL PCM INPUT DATA ACCORDING TO AN 8-BIT MASK PREVIOUSLY STORED IN THE "EXPECTED MESSAGES" REGISTER

The instruction flow is as follows.

Any input protocol is started by the microprocessor interface loading the internal stack register with 2 bytes (4 bytes for instructions 1 and 3) qualified as data bytes by C/D = 0 and a specific opcode qualified by C/D = 1 (match condition is normally needed).

After the code is loaded in the instruction register it is immediately checked to see whether it is acceptable and if not it is rejected. If accepted the instruction is also processed as regards match condition and is appended for execution during the memories' space cycles.

Four cases are possible :

a) the code is not valid; execution cannot take place, the DR output pin is reset to indicate the error; all registers are saved:

b) the code is valid for types 2, 4 and 6 but it is unmatched; execution cannot take place. DR is not affected.

c) the code is valid for types 1 and 3 and it is unmatched : the instruction is interpreted as a channel disconnection.

d) the code is valid and is either matched or of type 5; the instruction is processed as received.

Validation control takes only two cycles out of a total execution time of 5 to 13 cycles; the last operation is updating of the content of registers OR1 and OR2.



During a very long internal operation (device initialization after RESET going high or execution of instruction 6) a new set of data bytes with a valid opcode is accepted while a wrong code is rejected. At the end of the current routine execution takes place in the same way as described before.

At the end of an instruction it is normally recommended to read one or both registers. To enable instruction 6, however, it is necessary to read register OR2. This is because instruction 6, used between other short instructions of type 1 to 5, must have a lower priority and can be enabled only after the short instructions have been completed. Instruction 6 normally has a long process and a special flow which is described below.

First a not-all-zero mask is stored in the "expected messages" register and in another "background" register. This operation starts the second phase of instruction 6 which is called "channel 0 extraction" and is repeated at the beginning of any new time frame. At the beginning of the time frame a new copy of activated channels to be extracted is made from the "background register" and put in the "expected messages" register. In addition the latter register is modified to indicate the exact number of messages that have arrived. The term messages covers any input 0 channel data with starting sequence different from the label 01. So using this label the num-

ber of expected messages can be reduced to correspond to the number of effective messages. If and only if the residual number is different from zero will the device start the extraction protocol at the end of the current routine.

The procedure is as follows: the DR output is pulsed low as a two cycle interrupt request and OR2 is loaded with the total number of active channels to be extracted.

The transfer of OR2 content to the microprocessor continues the extraction which consists of repeated steps of OR1 and OR2 loading, indicating respectively the message and the incoming bus number. Reading the registers in the order OR1, OR2 must be continued until completion or until the time frame runs out.

With a new time frame a new extraction process begins, resuming the copy operation from the background register.

During extraction the active channels are scanned from the highest to the lowest number (from 7 to 0). While extraction is being carried out the time interval requirements between active rising edges of RD are minimum 5 to 13 t<sub>CK</sub> for sequence OR2 - OR1 and minimum 3 times t<sub>CK</sub> for sequence OR1 - OR2. More details are given in the following tables.

#### INSTRUCTION TABLES

The most significant digits of OR2 A7. A6, A5 are a copy of the PCM selected output bus ; the least sig-

nificant digits of OR2 are the opcode. C8 is the control bit. In any case parentheses () define actual register content.

#### INSTRUCTION 1 : CHANNEL CONNECTION/DISCONNECTION

| С      | ontro | ol Sig | nals |    |                    |                |                  | Data           | Bus            |                |                |                  | Notes                                                                            |
|--------|-------|--------|------|----|--------------------|----------------|------------------|----------------|----------------|----------------|----------------|------------------|----------------------------------------------------------------------------------|
| Match  | C/D   | CS     | WR   | RD | D7                 | D6             | D 5              | D4             | D 3            | D2             | D 1            | D 0              | Notes                                                                            |
| Х      | 0     | 0      | 0    | 1  | Х                  | Х              | Х                | Х              | Х              | Bi2            | Bi1            | Bi0              | 1 st Data Byte : selected input bus.                                             |
| Х      | 0     | 0      | 0    | 1  | Х                  | Х              | Х                | Ci4            | Ci3            | Ci2            | Ci1            | Ci0              | 2 <sup>nd</sup> Data Byte : selected input channel.                              |
| Х      | 0     | 0      | 0    | 1  | Х                  | Х              | Х                | Х              | Х              | Bo2            | Bo1            | Bo0              | 3 rd Data Byte : selected output bus.                                            |
| X      | 0     | 0      | 0    | 1  | Х                  | Х              | Х                | Co4            | Co3            | Co2            | Co1            | Co0              | 4 <sup>th</sup> Data Byte : selected output channel.                             |
| Yes/no | 1     | 0      | 0    | 1  | Х                  | Х              | Х                | Х              | 0              | 0              | 0              | 1                | Instruction Opcode                                                               |
| Yes    | 0     | 0      | 1    | 0  | C7<br>(1<br>(Bi2   | C6<br>1<br>Bi1 | C5<br>1<br>Bi0   | C4<br>1<br>Ci4 | C3<br>1<br>Ci3 | C2<br>1<br>Ci2 | C1<br>1<br>Ci1 | C0<br>1)<br>Ci0) | OR1 : CM content copy, that is for<br>mismatch condition for match<br>condition. |
| Yes    | 1     | 0      | 1    | 0  | A7<br>(Bo2<br>(Bo2 |                | A5<br>Bo0<br>Bo0 | C8<br>1<br>0   | 0<br>0<br>0    | 0<br>0<br>0    | 0<br>0<br>0    | 1<br>1)<br>1)    | OR2 : that is for mismatch condition, for match condition.                       |



#### INSTRUCTION 2 : OUTPUT CHANNEL DISCONNECTION

| C     | Contro | ol Sig | gnals |    |      |     |     | Data       | Bus |     |     |     | Notes                                                |
|-------|--------|--------|-------|----|------|-----|-----|------------|-----|-----|-----|-----|------------------------------------------------------|
| Natch | C/D    | CS     | WR    | RD | D7   | D 6 | D 5 | <b>D</b> 4 | D 3 | D 2 | D 1 | DO  | Notes                                                |
| Х     | 0      | 0      | 0     | 1  | Х    | Х   | Х   | Х          | Х   | Bo2 | Bo1 | Bo0 | 1 st Data Byte : selected output bus.                |
| Х     | 0      | 0      | 0     | 1  | X    | Х   | Х   | Co4        | Co3 | Co2 | Co1 | Co0 | 2 <sup>nd</sup> Data Byte : selected output channel. |
| Yes   | 1      | 0      | 0     | 1  | Х    | Х   | Х   | Х          | 0   | 0   | 1   | 0   | Instruction Opcode                                   |
| Yes   | 0      | 0      | 1     | 0  | 1    | 1   | 1   | 1          | 1   | 1   | 1   | 1   | OR1 : CM Content Copy (output channel is inactive)   |
| Yes   | 1      | 0      | 1     | 0  | A7   | A6  | A5  | 1          | 0   | 0   | 1   | 0   | OR2 : that is                                        |
|       |        |        |       |    | (Bo2 | Bo1 | Bo0 | 1          | 0   | 0   | 1   | 0)  |                                                      |

#### INSTRUCTION 3 : LOADING A MICROPROCESSOR BYTE

| C<br>Match | c/D | CS | w R | RD | D7               | D6             | D 5            | Data<br>D4     | Bus<br>D 3     | D2             | D 1            | D0               | Notes                                                                          |
|------------|-----|----|-----|----|------------------|----------------|----------------|----------------|----------------|----------------|----------------|------------------|--------------------------------------------------------------------------------|
| Х          | 0   | 0  | 0   | 1  | X                | Х              | Х              | Х              | Х              | Ci7            | Ci6            | Ci5              | 1 <sup>st</sup> Data Byte : most significant digits to be inserted.            |
| Х          | 0   | 0  | 0   | 1  | X                | Х              | Х              | Ci4            | Ci3            | Ci2            | Ci1            | Ci0              | 2 <sup>nd</sup> Data Byte : least significant digits to be inserted.           |
| Х          | 0   | 0  | 0   | 1  | Х                | Х              | Х              | Х              | Х              | Bo2            | Bo0            | Bo1              | 3 rd Data Byte : selected output bus.                                          |
| Х          | 0   | 0  | 0   | 1  | Х                | Х              | Х              | Co4            | Co3            | Co2            | Co1            | Co0              | 4 <sup>th</sup> Data Byte : selected output channel.                           |
| Yes/no     | 1   | 0  | 0   | 1  | Х                | Х              | Х              | Х              | 0              | 1              | 0              | 0                | Instruction Opcode                                                             |
| Yes        | 0   | 0  | 1   | 0  | C7<br>(1<br>(Ci7 | C6<br>1<br>Ci6 | C5<br>1<br>Ci5 | C4<br>1<br>Ci4 | C3<br>1<br>Ci3 | C2<br>1<br>Ci2 | C1<br>1<br>Ci1 | C0<br>1)<br>Ci0) | OR1 : CM content copy, that is for mis<br>match condition for match condition. |
| Yes        | 1   | 0  | 1   | 0  | A7<br>(Bo2       | A6<br>Bo1      | A5<br>Bo0      | 1<br>1         | 0<br>0         | 1              | 0<br>0         | 0<br>0)          | OR2 : that is.                                                                 |

### INSTRUCTION 4 : TRANSFER OF A SINGLE PCM SAMPLE

| C     | ontro | ol Sig | nals | -  | Data Bus   |           |           |          |          |          |          | Notes    |                                                                        |
|-------|-------|--------|------|----|------------|-----------|-----------|----------|----------|----------|----------|----------|------------------------------------------------------------------------|
| Match | C/D   | CS     | WR   | RD | D7         | D6        | D 5       | D 4      | D 3      | D 2      | D 1      | D 0      | Notes                                                                  |
| Х     | 0     | 0      | 0    | 1  | X          | Х         | Х         | Х        | Х        | Bo2      | Bo1      | Bo0      | 1 st Data Byte : selected output bus.                                  |
| х     | 0     | 0      | 0    | 1  | X          | Х         | Х         | Co4      | Co3      | Co2      | Co1      | Co0      | 2 <sup>nd</sup> Data Byte : selected output channel.                   |
| Yes   | 1     | 0      | 0    | 1  | Х          | Х         | Х         | Х        | 1        | 0        | 1        | 1        | Instruction Opcode                                                     |
| Yes   | 0     | 0      | 1    | 0  | C7<br>S7   | C6<br>S6  | C5<br>S5  | C4<br>S4 | C3<br>S3 | C2<br>S2 | C1<br>S1 | C0<br>S0 | OR1 : CM Content Copy if C8 = 1 ;<br>or<br>SM Content Sample if C8 = 0 |
| Yes   | 1     | 0      | 1    | 0  | A7<br>(Bo2 | A6<br>Bo1 | A5<br>Bo0 | C8<br>C8 | 1<br>1   | 0<br>0   | 1<br>1   | 1<br>1)  | OR2 : that is.                                                         |

Notes: S7...S0 is a parrallel copy of a PCM data, S7 is the most significant digit and the first of the sequence.



#### INSTRUCTION 5 : TRANSFER OF AN OUTPUT CHANNEL CONTROL WORD

| C     | ontro | ol Sig | nals |    |            |           |           | Data     | Bus    |        | Notes  |         |                                                      |
|-------|-------|--------|------|----|------------|-----------|-----------|----------|--------|--------|--------|---------|------------------------------------------------------|
| Match | C/D   | CS     | WR   | RD | D7         | D6        | D 5       | D 4      | D 3    | D 2    | D 1    | D 0     | Notes                                                |
| Х     | 0     | 0      | 0    | 1  | Х          | Х         | Х         | Х        | Х      | Bo2    | Bo1    | Bo0     | 1 st Data Byte : selected output bus.                |
| Х     | 0     | 0      | 0    | 1  | Х          | X         | Х         | Co4      | Co3    | Co2    | Co1    | Co0     | 2 <sup>nd</sup> Data Byte : selected output channel. |
| Х     | 1     | 0      | 0    | 1  | Х          | Х         | Х         | Х        | 1      | 0      | 0      | 0       | Instruction Opcode                                   |
| Yes   | 0     | 0      | 1    | 0  | C7         | C6        | C5        | C4       | C3     | C2     | C1     | CO      | OR1 : CM selected CM word copy.                      |
| Yes   | 1     | 0      | 1    | 0  | A7<br>(Bo2 | A6<br>Bo1 | A5<br>Bo0 | C8<br>C8 | 1<br>1 | 0<br>0 | 0<br>0 | 0<br>0) | OR2 : that is.                                       |

#### INSTRUCTION 6 : CHANNEL 0 SELECTION MASK STORE/DATA TRANSFER

| C<br>Match |       |       |        | RD    | D7                 | D6      | D5    | Data<br>D4 | Bus<br>D3 | D2  | D1  | DO                              | Notes                                                            |
|------------|-------|-------|--------|-------|--------------------|---------|-------|------------|-----------|-----|-----|---------------------------------|------------------------------------------------------------------|
| X          | 0     |       | 0      | 1     | X                  | X       | X     | X          | X         | Mi7 | Mi6 | Mi5                             | 1 st Data Byte : most sign. digits of selection mask.            |
| ×          | 0     | 0     | 0      | 1     | Х                  | Х       | Х     | Mi4        | Mi3       | Mi2 | Mi1 | Mi0                             | 2 <sup>nd</sup> Data Byte : most sign. digits of selection mask. |
| Yes        | 1     | 0     | 0      | 1     | Х                  | Х       | Х     | Х          | 1         | 1   | 1   | 0                               | Instruction Opcode                                               |
| Mask       | store | e con | trol   |       |                    |         |       |            |           |     |     |                                 |                                                                  |
| Yes        | 0     | 0     | 1      | 0     | (previous content) |         |       |            |           |     |     | OR1 : register is not affected. |                                                                  |
| Yes        | 1     | 0     | 1      | 0     | N2                 | N1      | NO    | Tn         | 1         | 1   | 1   | 0                               | OR2 : see below.                                                 |
| First      | Data  | Tran  | sfer ( | after | DR go              | oing lo | ow)   |            |           |     |     |                                 |                                                                  |
| Yes        | 0     | 0     | 1      | 0     | (previous content) |         |       |            |           |     |     | OR1 : register is not affected. |                                                                  |
| Yes        | 1     | 0     | 1      | 0     | N2                 | N1      | NO    | Tn         | 1         | 1   | 1   | 0                               | OR2 : see below.                                                 |
| Repe       | ated  | Data  | Tran   | sfer  | (after             | first C | R2 tr | ansfe      | r)        |     |     |                                 |                                                                  |
| Yes        | 0     | 0     | 1      | 0     | S7                 | S6      | S5    | S4         | S3        | S2  | S1  | S 0                             | OR1 : expected message stored in SM                              |
| Yes        | 1     | 0     | 1      | 0     | P2                 | P1      | PO    | Fn         | 1         | 1   | 1   | 0                               | OR2 : see below.                                                 |

Notes: 1. About mask bits Mi0 to Mi7 a logic "0" level means disabling condition, a logic "1" level means enabling condition

A null mask or a RESET pulse clear the mask and the deep background mask registers and disable channel 0 extraction function.
Reading of OR2 is optional after mask store or redefinition, because function is activated only by not-null mask writing.

4. After mask store (N2 N1 N0) is the sum of activated channels, after DR is the sum of active channels : Tn = 1/0 means activation/suppression of the function after store while after DR only Tn = 1 can appear to tell a not-null configuration to be extracted

5 Reading of OR2 is imperative after DR in order to step the data transfer : reading of OR1 is also needed to scan in descending order the priority register. Relevant messages only are considered, that means only messages with a MSD label different from 0.1

 (P2 P1 P0) is the PCM bus on which the message copied in OR1 was found ; Fn is a continuation bit telling respectively on level 1/0 for any more/no more extraction to be performed.

