

# Extended ISDN HDLC FIFO controller with Universal ISDN Port





Cologne Chip AG Eintrachtstrasse 113 D - 50668 Köln

Germany Tel.: +49 (0) 221 / 91 24-0 Fax: +49 (0) 221 / 91 24-100

http://www.CologneChip.com http://www.CologneChip.de support@CologneChip.com

#### Copyright 1994 - 2012 Cologne Chip AG All Rights Reserved

The information presented can not be considered as assured characteristics. Data can change without notice. Parts of the information presented may be protected by patent or other rights. Cologne Chip products are not designed, intended, or authorized for use in any application intended to support or sustain life, or for any other application in which the failure of the Cologne Chip product could create a situation where personal injury or death may occur.



### **Revision History of XHFC-1SU Data Sheet**

| Date         | Remarks                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| June 2012    | Bitmap width of A_SL_CFG.V_CH_SNUM reduced to 4 bit.                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | Description of bitmaps V_B1_TX_EN, V_B2_TX_EN (both in register R_SU_CTRL0), R_STATUS.V_MISC_IRQSTA and R_IRQ_OVIEW.V_MISC_IRQ slightly changed.                                                                                                                                                                                                                                                                                                      |
|              | Paragraph concerning HFC-channel processing limitation added to section 3.2.3 on page 78.                                                                                                                                                                                                                                                                                                                                                             |
|              | Figure 6.5 (PCM clock synchronization) on page 221 modified concerning C2IO signal path to PCM data controller.                                                                                                                                                                                                                                                                                                                                       |
|              | Section 9.2.4 (Supply noise requirements for PLL locking) on page 286 added.                                                                                                                                                                                                                                                                                                                                                                          |
| May 2010     | No changes with regard to contents, only a few typographical corrections have been made.                                                                                                                                                                                                                                                                                                                                                              |
| April 2010   | Sections 6.5.6, 6.5.7, 9.1.3.5, 10.3 and 13 added. Figures 9.3 and 10.3 added. Tables 2.3, 10.3, 13.1 and 13.2 added. Register R_SU_LED_CTRL added. Bit V_WD_EN in register R_BERT_WD_MD added.                                                                                                                                                                                                                                                       |
|              | Reset groups and I/O characteristic of the pin list completely reworked. Section "Reset" also reworked.                                                                                                                                                                                                                                                                                                                                               |
|              | Register descriptions improved for e.g. R_B1_RX, R_B2_RX, R_D_RX, R_E_RX, A_FIFO_CTRL, A_SL_CFG, R_CHIP_ID, R_CIRM, R_CLK_CFG, R_FIFO_BL0_IRQR_FIFO_BL3_IRQ, R_IRQ_CTRL, R_IRQ_OVIEW, R_PCM_MD1 and R_RAM_CTRL.                                                                                                                                                                                                                                       |
|              | Register descriptions clarified and corrected for A_CON_HDLC, A_F1, A_F2, R_SU_CTRL0, R_IRQ_OVIEW, R_PCM_MD1, R_STATUS.                                                                                                                                                                                                                                                                                                                               |
|              | Schematics slightly changed for processor interface (recommended capacitor added), component values of the quarz circuitry improved (see also calculation procedure in section 9.1.3).                                                                                                                                                                                                                                                                |
|              | /WAIT signal added to parallel processor interface timing diagrams.<br>Signals /SPICLK, SPICLK_IDLE and /SPICLK_IDLE added to timing diagram 2.20.                                                                                                                                                                                                                                                                                                    |
|              | Internal signal FSC renamed to FSC_RX (and as a consequence of this FSC_0 and FSC_1 renamed to FSC_TX_0 and FSC_TX_1). Internal signal FSC_TX added to figures 5.1, 5.5 and 5.13 and to the corresponding sections.                                                                                                                                                                                                                                   |
|              | Note *1 changed in NT state matrices for S/T (Table 5.4) and $U_p$ (Table 5.9) line interfaces.<br>Remarks added for bit scrambler configuration in sections 5.3.4 and 5.3.7.<br>Remark added for monitoring applications in section 5.3.6.<br>Remark concerning internal PCM loop added to section 6.2.<br>Register bit V_FIFO_IRQMSK added to Figure 9.7.<br>Chapter 11 reworked and supplemented.                                                  |
| October 2007 | Minor changes were made in this data sheet revision: Information added to Section 5.2.6 concerning state machine behaviour.                                                                                                                                                                                                                                                                                                                           |
| July 2007    | C1 and C2 in external S/T receive circuitry moved from L_A /L_B pins to R_A /R_B pins, $t_{AHD}$ added for bus interface write access in mode 2 (Motorola) and mode 3 (Intel), name V_ST_TX_LI changed to V_ST_PU_CTRL in register R_SU_CTRL0 and has new description, name V_CH_IRQ changed to V_STUP_IRQ in register R_IRQ_OVIEW, name V_FR_IRQSTA changed to V_FIFO_IRQSTA in register R_STATUS, description of many interrupt registers improved. |
| March 2007   | I/O type and input/output characteristics revised in pin list, pins 6 and 7 changed from NC to GND in SPI operating mode (refer to pin list and SPI connection circuitry), SPI timing diagrams added, section "PCM clock synchronization" restructured and supplemented, application hints for expanding an existing system with ISDN ports added.                                                                                                    |



# Contents

| A | About this data sheet and Cologne Chip technical support |          |                                                                    |    |
|---|----------------------------------------------------------|----------|--------------------------------------------------------------------|----|
| 1 | Gen                                                      | eral des | scription                                                          | 31 |
|   | 1.1                                                      | System   | n overview                                                         | 32 |
|   | 1.2                                                      | Featur   | es                                                                 | 33 |
|   | 1.3                                                      | Pin de   | scription                                                          | 34 |
|   |                                                          | 1.3.1    | Pinout diagram                                                     | 34 |
|   |                                                          | 1.3.2    | Pin list                                                           | 36 |
| 2 | Mic                                                      | roproce  | ssor bus interface                                                 | 41 |
|   | 2.1                                                      | Mode     | selection                                                          | 42 |
|   | 2.2                                                      | Paralle  | el processor interface                                             | 43 |
|   |                                                          | 2.2.1    | Overview                                                           | 43 |
|   |                                                          | 2.2.2    | Interface signals                                                  | 43 |
|   |                                                          | 2.2.3    | Register access                                                    | 44 |
|   |                                                          |          | 2.2.3.1 Non-multiplexed / multiplexed access                       | 44 |
|   |                                                          |          | 2.2.3.2 Read* access                                               | 45 |
|   |                                                          |          | 2.2.3.3 Register address read-back capability                      | 45 |
|   |                                                          |          | 2.2.3.4 Problems with interrupts between address and data accesses | 45 |
|   |                                                          | 2.2.4    | Signal and timing characteristics                                  | 45 |
|   |                                                          |          | 2.2.4.1 Bus interface in mode 2 and mode 3 (non-multiplexed)       | 45 |
|   |                                                          |          | 2.2.4.2 Bus interface in mode 2m and mode 3m (multiplexed)         | 51 |
|   |                                                          | 2.2.5    | Microprocessor connection circuitries                              | 55 |
|   | 2.3                                                      | Serial   | processor interface (SPI)                                          | 57 |
|   |                                                          | 2.3.1    | SPI control byte                                                   | 57 |
|   |                                                          | 2.3.2    | SPI transactions                                                   | 58 |
|   |                                                          | 2.3.3    | Transaction duration                                               | 59 |
|   |                                                          | 2.3.4    | Register write access                                              | 61 |
|   |                                                          | 2.3.5    | Register read access                                               | 63 |
|   |                                                          | 2.3.6    | Register access duration                                           | 64 |
|   |                                                          | 2.3.7    | Register address read-back capability                              | 64 |



|   |     | 2.3.8   | Problems with interrupts during transaction sequences |
|---|-----|---------|-------------------------------------------------------|
|   |     | 2.3.9   | SPI timing diagrams                                   |
|   |     | 2.3.10  | SPI connection circuitry                              |
|   | 2.4 | Auto-E  | EPROM mode 69                                         |
|   | 2.5 | Registe | er description                                        |
|   |     | 2.5.1   | Write only registers                                  |
|   |     | 2.5.2   | Read only registers                                   |
|   |     | 2.5.3   | Read / write register                                 |
| 3 | XHI | FC-1SU  | data flow 75                                          |
|   | 3.1 | Data fl | ow concept                                            |
|   |     | 3.1.1   | Overview                                              |
|   |     | 3.1.2   | Term definitions                                      |
|   | 3.2 | Flow c  | ontroller                                             |
|   |     | 3.2.1   | Overview                                              |
|   |     | 3.2.2   | Switching buffers                                     |
|   |     | 3.2.3   | Timed sequence                                        |
|   |     | 3.2.4   | Transmit operation (FIFO in transmit data direction)  |
|   |     | 3.2.5   | Receive operation (FIFO in receive data direction)    |
|   |     | 3.2.6   | Connection summary                                    |
|   | 3.3 | Assign  | ers                                                   |
|   |     | 3.3.1   | HFC-channel assigner                                  |
|   |     | 3.3.2   | PCM slot assigner                                     |
|   |     | 3.3.3   | Line interface assigner                               |
|   |     | 3.3.4   | Assigner summary                                      |
|   | 3.4 | Data fl | ow modes                                              |
|   |     | 3.4.1   | Simple Mode (SM)                                      |
|   |     |         | 3.4.1.1 Mode description                              |
|   |     |         | 3.4.1.2 Subchannel processing                         |
|   |     |         | 3.4.1.3 Example for SM                                |
|   |     | 3.4.2   | Channel Select Mode (CSM)                             |
|   |     |         | 3.4.2.1 Mode description                              |
|   |     |         | 3.4.2.2 HFC-channel assigner                          |
|   |     |         | 3.4.2.3 Subchannel Processing                         |
|   |     |         | 3.4.2.4 Example for CSM                               |
|   |     | 3.4.3   | FIFO Sequence Mode (FSM)                              |
|   |     |         | 3.4.3.1 Mode description                              |
|   |     |         | 3.4.3.2 FIFO sequence                                 |
|   |     |         | 3.4.3.3 FSM programming                               |



|   |      |           | 3.4.3.4 Example for FSM                                                                                                                                                          | 02 |
|---|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|   | 3.5  | Subcha    | nnel Processing                                                                                                                                                                  | 08 |
|   |      | 3.5.1     | Overview                                                                                                                                                                         | 08 |
|   |      | 3.5.2     | Subchannel registers                                                                                                                                                             | 09 |
|   |      | 3.5.3     | Details of the FIFO oriented part of the subchannel processor (part A) 10                                                                                                        | 09 |
|   |      |           | 3.5.3.1 FIFO transmit operation in transparent mode                                                                                                                              | 09 |
|   |      |           | 3.5.3.2 FIFO transmit operation in HDLC mode                                                                                                                                     | 11 |
|   |      |           | 3.5.3.3 FIFO receive operation in transparent mode                                                                                                                               | 11 |
|   |      |           | 3.5.3.4 FIFO receive operation in HDLC mode                                                                                                                                      | 11 |
|   |      | 3.5.4     | Details of the HFC-channel oriented part of the subchannel processor (part B) 1                                                                                                  | 11 |
|   |      |           | 3.5.4.1 FIFO transmit operation in SM                                                                                                                                            | 11 |
|   |      |           | 3.5.4.2 FIFO transmit operation in CSM and FSM                                                                                                                                   | 12 |
|   |      |           | 3.5.4.3 FIFO receive operation in SM                                                                                                                                             | 12 |
|   |      |           | 3.5.4.4 FIFO receive operation in CSM and FSM                                                                                                                                    | 12 |
|   |      | 3.5.5     | Subchannel example for SM                                                                                                                                                        | 13 |
|   |      | 3.5.6     | Subchannel example for CSM                                                                                                                                                       | 18 |
| 4 | FIFO | ) handl   | ing and HDLC controller 12                                                                                                                                                       | 25 |
|   | 4.1  | Overvi    | ew                                                                                                                                                                               | 26 |
|   | 4.2  | FIFO c    | ounters                                                                                                                                                                          | 26 |
|   | 4.3  | FIFO s    | ize setup                                                                                                                                                                        | 28 |
|   | 4.4  | FIFO o    | pperation                                                                                                                                                                        | 28 |
|   |      | 4.4.1     | HDLC transmit FIFOs                                                                                                                                                              | 28 |
|   |      | 4.4.2     | Automatic D-channel frame repetition (for S/T in TE mode only) 12                                                                                                                | 29 |
|   |      | 4.4.3     | HDLC receive FIFOs                                                                                                                                                               | 30 |
|   |      | 4.4.4     | Transparent mode of XHFC-1SU 12                                                                                                                                                  | 31 |
|   | 4.5  | Registe   | er description                                                                                                                                                                   | 33 |
|   |      | 4.5.1     | Write only registers                                                                                                                                                             | 33 |
|   |      | 4.5.2     | Read only registers                                                                                                                                                              | 38 |
|   |      | 4.5.3     | Read / write registers                                                                                                                                                           | 45 |
| 5 | Univ | versal IS | SDN Port 1                                                                                                                                                                       | 55 |
|   | 5.1  | Genera    | l overview of the S/T and $U_p$ interface $\ldots \ldots \ldots$ | 56 |
|   |      | 5.1.1     | Multiregisters                                                                                                                                                                   | 56 |
|   |      | 5.1.2     | Block diagram of the Universal ISDN Port module                                                                                                                                  | 56 |
|   | 5.2  | S/T int   | erface description                                                                                                                                                               | 58 |
|   |      | 5.2.1     | Overview                                                                                                                                                                         | 58 |
|   |      | 5.2.2     | Frame Structure                                                                                                                                                                  | 58 |
|   |      | 5.2.3     | Multiframe structure                                                                                                                                                             | 59 |



|   |     | 5.2.4               | Data transmission                                                                                                                                                              |
|---|-----|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     | 5.2.5               | INFO signals                                                                                                                                                                   |
|   |     | 5.2.6               | State machine                                                                                                                                                                  |
|   |     | 5.2.7               | Clock synchronization                                                                                                                                                          |
|   |     | 5.2.8               | External circuitries                                                                                                                                                           |
|   |     |                     | 5.2.8.1 External receive circuitry                                                                                                                                             |
|   |     |                     | 5.2.8.2 External transmit circuitry                                                                                                                                            |
|   |     |                     | 5.2.8.3 Transformer and ISDN jack connection                                                                                                                                   |
|   |     | 5.2.9               | S/T transformers                                                                                                                                                               |
|   | 5.3 | U <sub>p</sub> inte | erface description                                                                                                                                                             |
|   |     | 5.3.1               | Overview                                                                                                                                                                       |
|   |     | 5.3.2               | Frame Structure                                                                                                                                                                |
|   |     | 5.3.3               | Superframe structure                                                                                                                                                           |
|   |     | 5.3.4               | Data transmission                                                                                                                                                              |
|   |     | 5.3.5               | INFO signals                                                                                                                                                                   |
|   |     | 5.3.6               | State machine                                                                                                                                                                  |
|   |     | 5.3.7               | Clock synchronization                                                                                                                                                          |
|   |     | 5.3.8               | External circuitry                                                                                                                                                             |
|   |     | 5.3.9               | U <sub>p</sub> transformers                                                                                                                                                    |
|   | 5.4 | Comm                | on features of the S/T and $U_p$ interface $\ldots \ldots 186$ |
|   |     | 5.4.1               | Direct data access for test purposes                                                                                                                                           |
|   |     | 5.4.2               | Combined S/T and $U_p$ circuitry                                                                                                                                               |
|   | 5.5 | Registe             | er description                                                                                                                                                                 |
|   |     | 5.5.1               | Write only registers                                                                                                                                                           |
|   |     | 5.5.2               | Read only registers                                                                                                                                                            |
|   | DO  |                     |                                                                                                                                                                                |
| 6 | PCN | 1 interfa           | ace 211                                                                                                                                                                        |
|   | 0.1 | PCM II              |                                                                                                                                                                                |
|   | 6.2 | PCM d               |                                                                                                                                                                                |
|   | 0.3 | PCM II              |                                                                                                                                                                                |
|   | 6.4 | PCM ti              | iming                                                                                                                                                                          |
|   |     | 6.4.1               | Mode selection                                                                                                                                                                 |
|   |     | 6.4.2               | Master mode                                                                                                                                                                    |
|   | 65  | 6.4.3               | Slave mode                                                                                                                                                                     |
|   | 6.5 | PCM c               | 220 200 200 200 200 200 200 200 200 200                                                                                                                                        |
|   |     | 6.5.1               | Overview                                                                                                                                                                       |
|   |     | 6.5.2               | Manual or automatic synchronization source selection                                                                                                                           |
|   |     | 6.5.3               | PLL programming for F0IO generation                                                                                                                                            |
|   |     | 6.5.4               | Manual PLL adjustment                                                                                                                                                          |



|   |            | 6.5.5    | C2IO signal                                                           | 2  |
|---|------------|----------|-----------------------------------------------------------------------|----|
|   |            | 6.5.6    | SYNC_O and FSC_RX synchronization signals                             | 2  |
|   |            | 6.5.7    | Synchronous 512 kHz output signal                                     | 2  |
|   |            | 6.5.8    | Application examples for XHFC-1SU synchronization schemes             | 2  |
|   |            |          | 6.5.8.1 System with internal PCM bus expanded by an ISDN interface 22 | 3  |
|   |            |          | 6.5.8.2 Application with multiple XHFC-1SU                            | .4 |
|   | 6.6        | Multifr  | rame / superframe synchronization to the PCM interface                | 27 |
|   |            | 6.6.1    | Overview                                                              | 27 |
|   |            | 6.6.2    | Frame counter                                                         | 27 |
|   |            | 6.6.3    | Synchronization input signal                                          | 27 |
|   |            | 6.6.4    | Synchronization output signal (FOIO pulse modification)               | 0  |
|   |            | 6.6.5    | Line interface synchronization                                        | 1  |
|   | 6.7        | Externa  | al CODECs                                                             | 2  |
|   | 6.8        | GCI / I  | OM-2 mode                                                             | 4  |
|   |            | 6.8.1    | Overview                                                              | 4  |
|   |            | 6.8.2    | GCI frame structure                                                   | 4  |
|   |            | 6.8.3    | GCI register programming                                              | 5  |
|   |            |          | 6.8.3.1 Enable CGI functionality                                      | 5  |
|   |            |          | 6.8.3.2 Monitor channel                                               | 6  |
|   |            |          | 6.8.3.3 Command / indication bits (C/I-channel)                       | 6  |
|   |            |          | 6.8.3.4 Examples for GCI frame embedding in the PCM data structure 23 | 6  |
|   |            | 6.8.4    | GCI protocol                                                          | -1 |
|   |            |          | 6.8.4.1 XHFC-1SUtransmit procedure                                    | -1 |
|   |            |          | 6.8.4.2 XHFC-1SUreceive procedure                                     | -2 |
|   |            |          | 6.8.4.3 Receiver abort                                                | 4  |
|   | 6.9        | Registe  | er description                                                        | -5 |
|   |            | 6.9.1    | Write only registers                                                  | -5 |
|   |            | 6.9.2    | Read only registers                                                   | 3  |
|   |            | 6.9.3    | Read / write register                                                 | 6  |
| 7 | Dula       | o width  | modulation (BWM) outputs 26                                           | 7  |
| / | 7 1        | Overvi   |                                                                       | 0  |
|   | 7.1        | Standar  | rd PWM usage 26                                                       | 20 |
|   | 7.2        | Alterne  | $\frac{1}{20}$                                                        | 20 |
|   | 7.3<br>7.4 | Pogisto  | $\frac{1}{20}$                                                        | 0  |
|   | /.4        | Registe  | a desemption                                                          | フ  |
| 8 | Bit E      | Error Ra | ate Test (BERT) 27                                                    | 1  |
|   | 8.1        | BERT     | functionality                                                         | 2  |
|   | 0 7        | BERT     | transmitter 27                                                        | 2  |



|   | 8.3  | BERT    | receiver                                                    |  |
|---|------|---------|-------------------------------------------------------------|--|
|   | 8.4  | Registe | er description                                              |  |
|   |      | 8.4.1   | Write only registers                                        |  |
|   |      | 8.4.2   | Read only registers                                         |  |
| 9 | Cloc | k, PLL  | , reset, interrupt, timer and watchdog 279                  |  |
|   | 9.1  | Clock   |                                                             |  |
|   |      | 9.1.1   | Clock output                                                |  |
|   |      | 9.1.2   | Clock distribution                                          |  |
|   |      | 9.1.3   | Clock oscillator circuitry                                  |  |
|   |      |         | 9.1.3.1 Frequency accuracy                                  |  |
|   |      |         | 9.1.3.2 Pierce oscillator                                   |  |
|   |      |         | 9.1.3.3 3rd overtone oscillator                             |  |
|   |      |         | 9.1.3.4 Crystal oscillator circuitry                        |  |
|   |      |         | 9.1.3.5 Several XHFC-1SU with a single oscillator circuitry |  |
|   | 9.2  | Phase   | locked loop (PLL)                                           |  |
|   |      | 9.2.1   | Overview                                                    |  |
|   |      | 9.2.2   | PLL structure                                               |  |
|   |      | 9.2.3   | PLL operation                                               |  |
|   |      | 9.2.4   | Supply noise requirements for PLL locking                   |  |
|   |      | 9.2.5   | PLL configuration                                           |  |
|   | 9.3  | Reset   |                                                             |  |
|   | 9.4  | Interru | pt                                                          |  |
|   |      | 9.4.1   | Common features                                             |  |
|   |      | 9.4.2   | $ST/U_p$ interface interrupt                                |  |
|   |      | 9.4.3   | FIFO interrupt                                              |  |
|   |      | 9.4.4   | Miscelleanous interrupts                                    |  |
|   |      |         | 9.4.4.1 Line interface frequency slip interrupt             |  |
|   |      |         | 9.4.4.2 Timer interrupt                                     |  |
|   |      |         | 9.4.4.3 Processing / non-processing interrupt               |  |
|   |      |         | 9.4.4.4 Command / indication interrupt (GCI interface)      |  |
|   |      |         | 9.4.4.5 Wakeup interrupt                                    |  |
|   |      |         | 9.4.4.6 Interrupt for GCI monitor byte transmission         |  |
|   |      |         | 9.4.4.7 Interrupt after GCI monitor byte received           |  |
|   | 9.5  | Watche  | log reset                                                   |  |
|   | 9.6  | Registe | er description                                              |  |
|   |      | 9.6.1   | Write only registers                                        |  |
|   |      | 9.6.2   | Read only registers                                         |  |
|   |      | 9.6.3   | Read / write registers                                      |  |

| Cologno |
|---------|
| Cologne |
| Chip    |

| 10  | General purpose I/O pins (GPIO)          | 315 |
|-----|------------------------------------------|-----|
|     | 10.1 GPIO functionality                  | 316 |
|     | 10.2 GPIO output voltage                 | 316 |
|     | 10.3 Activation state F7 / G3 signalling | 320 |
|     | 10.4 Register description                | 321 |
|     | 10.4.1 Write only registers              | 321 |
|     | 10.4.2 Read only registers               | 328 |
| 11  | Electrical characteristics               | 331 |
| 12  | XHFC-1SU package dimensions              | 335 |
| 13  | XHFC-1SU address decoding erratum        | 337 |
|     | 13.1 Fault description                   | 338 |
|     | 13.2 Work-Around                         | 338 |
| Re  | eferences                                | 343 |
| Lis | st of register and bitmap abbreviations  | 345 |



# **List of Figures**

| 1.1  | XHFC-1SU block diagram                                                                                       | 31 |
|------|--------------------------------------------------------------------------------------------------------------|----|
| 1.2  | XHFC-1SU pinout in parallel processor interface mode                                                         | 34 |
| 1.3  | XHFC-1SU pinout in serial processor interface mode                                                           | 35 |
| 2.1  | Bus interface read access in mode 2 (Motorola) and mode 3 (Intel)                                            | 46 |
| 2.2  | Bus interface write access in mode 2 (Motorola) and mode 3 (Intel)                                           | 49 |
| 2.3  | Bus interface read access in modes 2m and 3m (multiplexed)                                                   | 52 |
| 2.4  | Bus interface write access in mode 2m and 3m (multiplexed)                                                   | 54 |
| 2.5  | 8 bit Motorola processor circuitry example (mode 2)                                                          | 55 |
| 2.6  | 8 bit Motorola processor circuitry example (mode 2m)                                                         | 55 |
| 2.7  | 8 bit Intel processor circuitry example (mode 3)                                                             | 56 |
| 2.8  | 8 bit Intel processor circuitry example (mode 3m)                                                            | 56 |
| 2.9  | 16 bit SPI write transaction ( $R = '0'$ , one data byte) $\ldots \ldots \ldots \ldots \ldots \ldots \ldots$ | 59 |
| 2.10 | 16 bit SPI read transaction ( $R = '1'$ , one data byte)                                                     | 59 |
| 2.11 | 40 bit SPI write transaction ( $R = '0'$ , four data bytes)                                                  | 60 |
| 2.12 | 40 bit SPI read transaction ( $R = '1'$ , four data bytes)                                                   | 60 |
| 2.13 | Split 40 bit SPI read transaction $(R = '1')$                                                                | 60 |
| 2.14 | Register write access (transaction sequence)                                                                 | 62 |
| 2.15 | Multiple write accesses to the same register                                                                 | 62 |
| 2.16 | Register write access with a 40 bit transaction                                                              | 62 |
| 2.17 | Register read access (transaction sequence)                                                                  | 63 |
| 2.18 | Multiple read accesses to the same register                                                                  | 64 |
| 2.19 | Register read access with a 40 bit transaction                                                               | 64 |
| 2.20 | SPI timing diagram for data write transactions                                                               | 65 |
| 2.21 | SPI timing diagram for data read transactions                                                                | 66 |
| 2.22 | SPI connection circuitry                                                                                     | 68 |
| 3.1  | Data flow block diagram                                                                                      | 75 |
| 3.2  | Areas of FIFO oriented, HFC-channel oriented and PCM time slot oriented numbering                            | 77 |
| 3.3  | The flow controller in transmit operation                                                                    | 79 |



| 3.4  | The flow controller in receive FIFO operation                                                    |
|------|--------------------------------------------------------------------------------------------------|
| 3.5  | Overview of the assigner programming                                                             |
| 3.6  | SM example                                                                                       |
| 3.7  | HFC-channel assigner in CSM                                                                      |
| 3.8  | CSM example                                                                                      |
| 3.9  | HFC-channel assigner in FSM                                                                      |
| 3.10 | FSM list processing                                                                              |
| 3.11 | FSM list programming 101                                                                         |
| 3.12 | FSM example                                                                                      |
| 3.13 | General structure of the subchannel processor                                                    |
| 3.14 | Location of the subchannel parts A and B in the data flow diagram 108                            |
| 3.15 | Part A of the subchannel processor                                                               |
| 3.16 | Part B of the subchannel processor                                                               |
| 3.17 | SM example with subchannel processor                                                             |
| 3.18 | CSM example with subchannel processor                                                            |
| 4 1  |                                                                                                  |
| 4.1  | FIFO organization in UDL C mode                                                                  |
| 4.2  | FIFO data organization in HDLC mode                                                              |
| 5.1  | Overview of the Universal ISDN Port module                                                       |
| 5.2  | Frame structure at reference point S and T                                                       |
| 5.3  | S/T frame composition for B1-, B2-, D-channel and multiframe bits                                |
| 5.4  | S/T frame decomposition for B1-, B2-, D-, E-channel and multiframe bits 162                      |
| 5.5  | S/T clock synchronization                                                                        |
| 5.6  | External S/T receive circuitry for TE and NT mode                                                |
| 5.7  | External S/T transmit circuitry for TE and NT mode                                               |
| 5.8  | Transformer and connector circuitry in TE mode                                                   |
| 5.9  | Transformer and connector circuitry in NT mode                                                   |
| 5.10 | U <sub>p</sub> interface frame structure                                                         |
| 5.11 | U <sub>p</sub> frame composition for B1-, B2-, D-channel and superframe bits                     |
| 5.12 | $U_p$ frame decomposition for B1-, B2-, D-channel and superframe bits $\ldots \ldots \ldots 178$ |
| 5.13 | U <sub>p</sub> clock synchronization                                                             |
| 5.14 | External U <sub>p</sub> circuitry for TE and LT mode                                             |
| 6.1  | PCM data flow for transmit and receive time slots                                                |
| 6.2  | Global setting for all PCM time slots (detail of Figure 6.1)                                     |
| 6.3  | PCM timing for master mode                                                                       |
| 6.4  | PCM timing for slave mode                                                                        |



| 6.5  | PCM clock synchronization                                                                   |
|------|---------------------------------------------------------------------------------------------|
| 6.6  | Expanding an existing system with an ISDN port (XHFC-1SU as PCM slave) 223                  |
| 6.7  | Expanding an existing system with an ISDN port (XHFC-1SU as PCM master) 224                 |
| 6.8  | Multiple XHFC-1SU synchronized with an open loop of SYNC_O/SYNC_I 225                       |
| 6.9  | Multiple XHFC-1SU synchronized with an closed loop of SYNC_O/SYNC_I $\ldots 226$            |
| 6.10 | Multiframe/superframe synchronization to the PCM interface                                  |
| 6.11 | Timing specification of the SYNC_IN change detection                                        |
| 6.12 | F0IO pulse modification                                                                     |
| 6.13 | Example for two CODEC enable signal shapes                                                  |
| 6.14 | Single channel GCI format 235                                                               |
| 6.15 | GCI application example 1 (XHFC-1SU is PCM master and GCI master) 237                       |
| 6.16 | GCI application example 2 (XHFC-1SU is PCM slave and GCI master) 239                        |
| 6.17 | GCI application example 3 (XHFC-1SU is PCM slave and GCI slave)                             |
| 6.18 | GCI protocol for monitor bytes transmission                                                 |
| 6.19 | GCI protocol for monitor bytes receiving                                                    |
| 81   | BERT transmitter block diagram 273                                                          |
| 8.2  | BERT receiver block diagram                                                                 |
| 0.2  |                                                                                             |
| 9.1  | CLK_OUT generation and clock distribution                                                   |
| 9.2  | Standard XHFC-1SU quartz circuitry                                                          |
| 9.3  | Clock distribution with only one quartz circuitry                                           |
| 9.4  | PLL block diagram                                                                           |
| 9.5  | Interrupt output                                                                            |
| 9.6  | $ST/U_p$ interface interrupt                                                                |
| 9.7  | Enable FIFO interrupt condition with V_FIFO_IRQ_EN $\ldots \ldots \ldots \ldots \ldots 292$ |
| 9.8  | FIFO interrupt                                                                              |
| 9.9  | Miscelleanous interrupts                                                                    |
| 9.10 | Wakeup interrupt                                                                            |
| 10.1 | Block diagram of GPIO pins shared with the $ST/U_{\rm c}$ interface 317                     |
| 10.2 | Block diagram of the additional GPIO block                                                  |
| 10.2 | Activation state signalling exemplarily shown with GPIO0 320                                |
| 10.0 |                                                                                             |
| 12.1 | XHFC-1SU package dimensions                                                                 |



# **List of Tables**

| 2.1  | Overview of the XHFC-1SU bus interface registers                                            | 41  |
|------|---------------------------------------------------------------------------------------------|-----|
| 2.2  | Microprocessor access types                                                                 | 42  |
| 2.3  | Overview of the parallel processor interface pins                                           | 43  |
| 2.4  | Parallel processor interface mode selection                                                 | 44  |
| 2.5  | Pins and signal names of the parallel processor interface modes                             | 44  |
| 2.6  | Overview of accesses in parallel microprocessor interface mode                              | 47  |
| 2.7  | Timing diagrams of the parallel microprocessor interface                                    | 47  |
| 2.8  | Symbols of read accesses in Figure 2.1                                                      | 48  |
| 2.9  | Symbols of write accesses in Figure 2.2                                                     | 50  |
| 2.10 | Symbols of read accesses in Figure 2.3                                                      | 51  |
| 2.11 | Symbols of write accesses in Figures 2.4                                                    | 53  |
| 2.12 | Overview of the SPI interface pins                                                          | 57  |
| 2.13 | SPI control byte with $A = '0'$                                                             | 58  |
| 2.14 | SPI control byte with $A = '1'$                                                             | 58  |
| 2.15 | SPI control commands for register read and write operations                                 | 58  |
| 2.16 | SPI data rates                                                                              | 64  |
| 2.17 | Symbols of write access in Figure 2.20                                                      | 66  |
| 2.18 | Symbols of read access in Figure 2.21                                                       | 67  |
| 3.1  | Flow controller connectivity                                                                | 81  |
| 3.2  | V_DATA_FLOW programming values for bidirectional connections                                | 81  |
| 3.3  | Line interface assigner                                                                     | 83  |
| 3.4  | Index registers of the FIFO array registers (sorted by address)                             | 86  |
| 3.5  | List specification of the example in Figure 3.12                                            | 103 |
| 3.6  | Subchannel processing according to Figure 3.17 (SM $\bullet$ TX, transparent mode)          | 115 |
| 3.7  | Subchannel processing according to Figure 3.17 (SM $\bullet$ RX, transparent mode)          | 115 |
| 3.8  | Subchannel processing according to Figure 3.17 (SM <b>2</b> TX, HDLC mode)                  | 117 |
| 3.9  | Subchannel processing according to Figure 3.17 (SM <b>2</b> RX, HDLC mode)                  | 117 |
| 3.10 | Subchannel processing according to Figure 3.18 (CSM <b>1</b> TX, transparent mode)          | 120 |
| 3.11 | Subchannel processing according to Figure 3.18 (CSM $\textcircled{O}$ RX, transparent mode) | 121 |
| 3.12 | Subchannel processing according to Figure 3.18 (CSM <b>2</b> TX, HDLC mode)                 | 124 |



| 3.13 | Subchannel processing according to Figure 3.18 (CSM <b>2</b> RX, HDLC mode)                                | 124 |
|------|------------------------------------------------------------------------------------------------------------|-----|
| 4.1  | Overview of the XHFC-1SU FIFO registers                                                                    | 125 |
| 4.2  | FIFO size setup                                                                                            | 128 |
| 5.1  | Overview of the $ST/U_p$ interface registers                                                               | 155 |
| 5.2  | Legend for Figure 5.2                                                                                      | 159 |
| 5.3  | Multiframe structure of the Q- and S-bits                                                                  | 160 |
| 5.4  | S/T interface activation / deactivation layer 1 matrix for NT mode                                         | 164 |
| 5.5  | S/T interface activation / deactivation layer 1 matrix for TE mode                                         | 165 |
| 5.6  | S/T transformer part numbers and manufacturers                                                             | 171 |
| 5.7  | Legend for Figure 5.10                                                                                     | 176 |
| 5.8  | Superframe construction                                                                                    | 176 |
| 5.9  | $U_p$ interface activation / deactivation layer 1 matrix for LT mode $\hfill \ldots \ldots \ldots \ldots$  | 180 |
| 5.10 | $U_p$ interface activation / deactivation layer 1 matrix for TE mode $\ \ldots \ \ldots \ \ldots \ \ldots$ | 181 |
| 5.11 | Up transformer part numbers and manufacturers                                                              | 185 |
| 6.1  | Overview of the XHFC-1SU PCM interface registers                                                           | 211 |
| 6.2  | PCM master mode                                                                                            | 212 |
| 6.3  | PCM data flow programming                                                                                  | 214 |
| 6.4  | Symbols of PCM timing for master mode in Figure 6.3                                                        | 217 |
| 6.5  | Symbols of PCM timing for slave mode in Figure 6.4                                                         | 219 |
| 6.6  | Symbols of the SYNC_IN change detection timing specification in Figure 6.11                                | 230 |
| 6.7  | Selection of the F0IO pulse characteristic (see also Figure 6.12)                                          | 231 |
| 6.8  | Legend of figure 6.14                                                                                      | 235 |
| 6.9  | Programming procedure for application example 1 according to Figure 6.15                                   | 238 |
| 6.10 | Programming procedure for application example 3 according to Figure 6.17                                   | 240 |
| 6.11 | Rules for the handshake signals $MX_{TX}$ and $MR_{TX}$                                                    | 242 |
| 6.12 | Rules for the handshake signals $MX_{RX}$ and $MR_{RX}$                                                    | 244 |
| 7.1  | Overview of the XHFC-1SU PWM registers                                                                     | 267 |
| 8.1  | Overview of the XHFC-1SU BERT registers                                                                    | 271 |
| 9.1  | Overview of clock, PLL, reset, timer and watchdog registers                                                | 279 |
| 9.2  | PLL setup examples $(P,M,N,S)$ with ISDN related frequencies for $\mathbf{f}_{\text{out}}$                 | 288 |
| 9.3  | PLL setup examples $(P,M,N,S)$ with ISDN related frequencies for $\mathbf{f}_{in}$                         | 289 |
| 9.4  | XHFC-1SU reset groups                                                                                      | 290 |
| 10.1 | Overview of the XHFC-1SU general purpose I/O registers                                                     | 315 |
| 10.2 | GPIO pins                                                                                                  | 319 |

## Cologne Chip

| 10.3 | State F7/G3 reporting                              | 320 |
|------|----------------------------------------------------|-----|
| 13.1 | Involved registers of the address decoding fault   | 338 |
| 13.2 | Detailed register list and work-around description | 339 |



# **List of Registers**

## Please note !

Register addresses are assigned independently for write and read access; i.e. in many cases there are different registers for write and read access with the same address. Only registers with the same meaning and bitmap structure in both write and read directions are declared to be read/write.

It is important to distinguish between *registers*, *array registers* and *multi-registers*.

Array registers have multiple instances and are indexed by a number. This index is either the FIFO number (R\_FIFO with 15 indexed registers) or the PCM time slot number (R\_SLOT with 1 indexed register). <u>Array registers have equal name, bitmap structure and meaning for every instance.</u>

Multi-registers have multiple instances, too, but they are selected by a bitmap value. With this value, different registers can be selected with the same address. Multi-register addresses are 0x15 (11 instances selected by R\_PCM\_MD0), 0x0F (2 instances selected by R\_FIFO\_MD) and 0x35 (2 instances selected by R\_ST\_CTRL3/R\_UP\_CTRL3) for XHFC-1SU. Multi-registers have different names, bitmap structure and meaning for each instance.

The first letter of array register names is 'A\_ ...' whereas all other registers begin with 'R\_ ...'. The index of array registers and multi-registers has to be specified in the appropriate register.



Reset group

Η, 0

Η, 0

Η, 0

H, 0, 2

H, 0, 3

H, 0 H, 0, 3

H, 0, 3

Η, Ο

H, 0, 3

Page

270

71

71

256

256

257

256

247

248

248

245

195

199

189

191

192

300 327

258

188

302

196

## **Registers sorted by name**

| Reset group: | Η | = | Hardware reset        |
|--------------|---|---|-----------------------|
|              | 0 | = | Global software reset |
|              | 1 | = | HFC reset             |
|              | 2 | = | PCM reset             |
|              | 3 | = | Line interface reset  |

See Table 9.4 on page 290 for a detailed reset group explanation.

#### Write only registers:

|         |               | <b>D</b> (     |      | 0x39 | R_PWM1        |
|---------|---------------|----------------|------|------|---------------|
| Address | Name          | Reset<br>group | Page | 0x08 | R_RAM_ADDR    |
|         |               | H 0 1 2 3      | 136  | 0x09 | R_RAM_CTRL    |
| 0x3C    | R B1 TX       |                | 200  | 0x15 | R_SH0H        |
| 0x3D    | R B2 TX       | _              | 200  | 0x15 | R_SH0L        |
| 0x3E    | R BAC S TX    | _              | 200  | 0x15 | R_SH1H        |
| 0x1B    | R BERT WD MD  | НО             | 202  | 0x15 | R_SH1L        |
| 0x28    | R CL TX       | H 0 2          | 259  | 0x15 | R_SL_SEL0     |
| 0x00    | R_CIBM        | Н, 0, 2        | 297  | 0x15 | R_SL_SEL1     |
| 0x02    | B CLK CFG     | Н              | 299  | 0x15 | R_SL_SEL7     |
| 0x01    | R CTRL        | Н              | 70   | 0x10 | R_SLOT        |
| 0x3E    | R D TX        | _              | 201  | 0x35 | R_ST_CTRL3    |
| 0x0D    | R_FIFO_MD     | Н              | 135  | 0x37 | R_SU_CLK_DLY  |
| 0x0C    | R_FIFO_THRES  | H. 0. 1. 2. 3  | 134  | 0x31 | R_SU_CTRL0    |
| 0x0F    | R_FIFO        | H, 0, 1        | 137  | 0x32 | R_SU_CTRL1    |
| 0x0B    | R_FIRST_FIFO  | H, 0, 1        | 133  | 0x33 | R_SU_CTRL2    |
| 0x0F    | R_FSM_IDX     | H, 0, 1        | 137  | 0x12 | R_SU_IRQMSK   |
| 0x29    | R_GCI_CFG0    | H, 0, 2        | 260  | 0x4D | R_SU_LED_CTRL |
| 0x2A    | R_GCI_CFG1    | H, 0, 2        | 262  | 0x17 | R_SU_SYNC     |
| 0x4A    | R_GPIO_EN0    | Η, 0           | 325  | 0x30 | R_SU_WR_SIA   |
| 0x42    | R_GPIO_EN1    | Η, 0           | 322  | 0x1A | R_II_WD       |
| 0x47    | R_GPIO_EN2    | Η, 0           | 324  | 0x35 | R_UP_CIRL3    |
| 0x48    | R_GPIO_OUT0   | Η, 0           | 324  |      |               |
| 0x40    | R_GPIO_OUT1   | Н, 0           | 321  |      |               |
| 0x45    | R_GPIO_OUT2   | Н, 0           | 323  |      |               |
| 0x44    | R_GPIO_SEL_BL | Η, 0           | 323  |      |               |
| 0x4C    | R_GPIO_SEL    | Η, 0           | 326  |      |               |
| 0x13    | R_IRQ_CTRL    | Η, 0           | 301  |      |               |
| 0x11    | R_MISC_IRQMSK | Н              | 300  |      |               |
| 0x2B    | R_MON_TX      | H, 0, 2        | 262  |      |               |
| 0x36    | R_MS_DF       | H, 0, 3        | 198  |      |               |
| 0x34    | R_MS_TX       | H, 0, 3        | 194  |      |               |
| 0x15    | R_MSS0        | H, 0, 2        | 249  |      |               |
| 0x15    | R_MSS1        | H, 0, 2        | 255  |      |               |
| 0x14    | R_PCM_MD0     | H, 0, 2        | 246  |      |               |
| 0x15    | R_PCM_MD1     | H, 0, 2        | 251  |      |               |
| 0x15    | R_PCM_MD2     | H, 0, 2        | 253  |      |               |
| 0x50    | R_PLL_CTRL    | Н              | 303  |      |               |
| 0x1E    | R_PWM_CFG     | Η, 0           | 269  |      |               |
| 0x46    | R_PWM_MD      | Η, 0           | 270  |      |               |
| 0x38    | R_PWM0        | Η, 0           | 269  |      |               |

## Please note !

Name

Address

See explanation of register types on page 21.



### Read only registers:

### Read/Write registers:

| Address | Name             | Reset<br>group | Page |
|---------|------------------|----------------|------|
| 0x0C    | A_F1[FIFO]       | H, 0, 1        | 138  |
| 0x0D    | A_F2[FIFO]       | H, 0, 1        | 139  |
| 0x0E    | A_FIFO_STA[FIFO] | H, 0, 1        | 140  |
| 0x14    | A_USAGE[FIFO]    | H, 0, 1        | 141  |
| 0x04    | A_Z1[FIFO]       | H, 0, 1        | 138  |
| 0x06    | A_Z2[FIFO]       | H, 0, 1        | 138  |
| 0x3C    | R_B1_RX          | _              | 208  |
| 0x3D    | R_B2_RX          | _              | 208  |
| 0x1B    | R_BERT_ECH       | H, 0, 1        | 278  |
| 0x1A    | R_BERT_ECL       | H, 0, 1        | 277  |
| 0x17    | R_BERT_STA       | H, 0, 1        | 277  |
| 0x16    | R_CHIP_ID        | Н              | 72   |
| 0x1F    | R_CHIP_RV        | Η              | 72   |
| 0x28    | R_CI_RX          | _              | 264  |
| 0x3E    | R_D_RX           | _              | 209  |
| 0x3F    | R_E_RX           | _              | 210  |
| 0x19    | R_F0_CNTH        | H, 0, 1        | 263  |
| 0x18    | R_F0_CNTL        | H, 0, 1        | 263  |
| 0x20    | R_FIFO_BL0_IRQ   | H, 0, 1        | 309  |
| 0x21    | R_FIFO_BL1_IRQ   | H, 0, 1        | 310  |
| 0x22    | R_FIFO_BL2_IRQ   | H, 0, 1        | 311  |
| 0x23    | R_FIFO_BL3_IRQ   | H, 0, 1        | 312  |
| 0x24    | R_FILL_BL0       | H, 0, 1        | 141  |
| 0x25    | R_FILL_BL1       | H, 0, 1        | 142  |
| 0x26    | R_FILL_BL2       | H, 0, 1        | 143  |
| 0x27    | R_FILL_BL3       | H, 0, 1        | 144  |
| 0x29    | R_GCI_STA        | H, 0, 2        | 265  |
| 0x48    | R_GPIO_IN0       | _              | 329  |
| 0x40    | R_GPIO_IN1       | _              | 328  |
| 0x45    | R_GPIO_IN2       | _              | 328  |
| 0x88    | R_INT_DATA       | _              | 73   |
| 0x10    | R_IRQ_OVIEW      | H, 0, 1        | 304  |
| 0x11    | R_MISC_IRQ       | H, 0, 1        | 306  |
| 0x2A    | R_MON_RX         | _              | 265  |
| 0x34    | R_MS_RX          | Н, 0, 3        | 206  |
| 0x50    | R_PLL_STA        | Н              | 312  |
| 0x15    | R_RAM_USE        | _              | 72   |
| 0x1D    | R_SL_MAX         | _              | 263  |
| 0x1C    | R_STATUS         | H, 0, 3        | 308  |
| 0x32    | R_SU_DLYH        | _              | 205  |
| 0x31    | R_SU_DLYL        | _              | 204  |
| 0x12    | R_SU_IRQ         | Η, 0           | 307  |
| 0x30    | R_SU_RD_STA      | Н, 0, 3        | 203  |
| 0x35    | R_SU_STA         | -              | 207  |

| Address | Name                | Reset<br>group | Page |
|---------|---------------------|----------------|------|
| 0xF4    | A_CH_MSK[FIFO]      | H, 0, 1        | 146  |
| 0xFC    | A_CHANNEL[FIFO]     | H, 0, 1        | 150  |
| 0xFA    | A_CON_HDLC[FIFO]    | H, 0, 1        | 147  |
| 0xFF    | A_FIFO_CTRL[FIFO]   | H, 0, 1        | 152  |
| 0x84    | A_FIFO_DATA_NOINC[F | IFO]–          | 145  |
| 0x80    | A_FIFO_DATA[FIFO]   | _              | 145  |
| 0xFD    | A_FIFO_SEQ[FIFO]    | H, 0, 1        | 151  |
| 0xD0    | A_SL_CFG[SLOT]      | H, 0, 2        | 266  |
| 0xFB    | A_SUBCH_CFG[FIFO]   | H, 0, 1        | 149  |
| 0x52    | R_PLL_N             | Н              | 313  |
| 0x51    | R_PLL_P             | Н              | 313  |
| 0x53    | R_PLL_S             | Н              | 313  |
| 0xC0    | R_RAM_DATA          | -              | 74   |



Reset group

H, 0, 3

Η, 0

H, 0

\_

\_

\_

– H, 0

Η, 0

Η, 0

H, 0

H, 0 H, 0

Η, 0

H, 0

H, 0

Η, 0

Η

Page

194

195

196

198

199

269

270 200

200

201

202

321

322

323

323 270

324

324

325

326

327 303

## **Registers sorted by address**

| Reset group: | Η | = | Hardware reset        |
|--------------|---|---|-----------------------|
|              | 0 | = | Global software reset |
|              | 1 | = | HFC reset             |
|              | 2 | = | PCM reset             |
|              | 3 | = | Line interface reset  |

See Table 9.4 on page 290 for a detailed reset group explanation.

#### Write only registers:

| Address     | Name                 | Reset<br>group | Page      |
|-------------|----------------------|----------------|-----------|
| ~00         |                      | ц              | 207       |
| 00          |                      | н<br>Н         | 297<br>70 |
| (02)        | R CIK CEG            | н<br>Н         | 200       |
| x02<br>v09  |                      | но             | 299<br>71 |
| (UO<br>(OO  |                      | п, 0           | 71        |
| (09<br>(09  | R_RAM_CIRL           | П, О           | 122       |
| XUD         |                      | П, 0, 1        | 133       |
|             | R_FIFU_IHRES         | H, U, 1, 2, 3  | 134       |
|             |                      | н              | 135       |
|             | A_INU_RES_FIFU[FIFU] | H, U, 1, 2, 3  | 130       |
|             |                      | H, 0, 1        | 137       |
|             |                      | H, U, I        | 15/       |
| (10<br>     | K_SLUI               | H, 0, 2        | 245       |
| (11<br>(10) | K_MISU_IKQMSK        | Н              | 300       |
| x12         | R_SU_IRQMSK          | H, 0, 3        | 300       |
| (13         | R_IRQ_CTRL           | H, 0           | 301       |
| (14         | R_PCM_MD0            | H, 0, 2        | 246       |
| x15         | R_MSS0               | H, 0, 2        | 249       |
| x15         | R_MSS1               | H, 0, 2        | 255       |
| x15         | R_PCM_MD1            | Н, 0, 2        | 251       |
| x15         | R_PCM_MD2            | H, 0, 2        | 253       |
| x15         | R_SH0H               | H, 0, 2        | 256       |
| x15         | R_SH1H               | H, 0, 2        | 257       |
| x15         | R_SH0L               | H, 0, 2        | 256       |
| )x15        | R_SH1L               | H, 0, 2        | 256       |
| )x15        | R_SL_SEL0            | H, 0, 2        | 247       |
| )x15        | R_SL_SEL1            | H, 0, 2        | 248       |
| )x15        | R_SL_SEL7            | H, 0, 2        | 248       |
| )x17        | R_SU_SYNC            | Н, 0, 3        | 258       |
| x1A         | R_TI_WD              | Η, 0           | 302       |
| )x1B        | R_BERT_WD_MD         | Η, 0           | 276       |
| Dx1E        | R_PWM_CFG            | Η, 0           | 269       |
| 0x28        | R_CI_TX              | H, 0, 2        | 259       |
| )x29        | R_GCI_CFG0           | H, 0, 2        | 260       |
| )x2A        | R_GCI_CFG1           | H, 0, 2        | 262       |
| )x2B        | R_MON_TX             | H, 0, 2        | 262       |
| )x30        | R_SU_WR_STA          | H, 0, 3        | 188       |
| 0x31        | R_SU_CTRL0           | H, 0, 3        | 189       |
| 0x32        | R_SU_CTRL1           | Н, 0, 3        | 191       |
| 0x33        | R_SU_CTRL2           | Н, 0, 3        | 192       |

## Please note !

Name

Address

See explanation of register types on page 21.



### Read only registers:

# Read/Write registers:

| Address | Name             | Reset<br>group | Page |
|---------|------------------|----------------|------|
| 0x04    | A_Z1[FIFO]       | H, 0, 1        | 138  |
| 0x06    | A_Z2[FIFO]       | H, 0, 1        | 138  |
| 0x0C    | A_F1[FIFO]       | H, 0, 1        | 138  |
| 0x0D    | A_F2[FIFO]       | H, 0, 1        | 139  |
| 0x0E    | A_FIFO_STA[FIFO] | H, 0, 1        | 140  |
| 0x10    | R_IRQ_OVIEW      | H, 0, 1        | 304  |
| 0x11    | R_MISC_IRQ       | H, 0, 1        | 306  |
| 0x12    | R_SU_IRQ         | Η, 0           | 307  |
| 0x14    | A_USAGE[FIFO]    | H, 0, 1        | 141  |
| 0x15    | R_RAM_USE        | _              | 72   |
| 0x16    | R_CHIP_ID        | Н              | 72   |
| 0x17    | R_BERT_STA       | H, 0, 1        | 277  |
| 0x18    | R_F0_CNTL        | H, 0, 1        | 263  |
| 0x19    | R_F0_CNTH        | H, 0, 1        | 263  |
| 0x1A    | R_BERT_ECL       | H, 0, 1        | 277  |
| 0x1B    | R_BERT_ECH       | H, 0, 1        | 278  |
| 0x1C    | R_STATUS         | H, 0, 3        | 308  |
| 0x1D    | R_SL_MAX         | _              | 263  |
| 0x1F    | R_CHIP_RV        | Н              | 72   |
| 0x20    | R_FIFO_BL0_IRQ   | H, 0, 1        | 309  |
| 0x21    | R_FIFO_BL1_IRQ   | H, 0, 1        | 310  |
| 0x22    | R_FIFO_BL2_IRQ   | H, 0, 1        | 311  |
| 0x23    | R_FIFO_BL3_IRQ   | H, 0, 1        | 312  |
| 0x24    | R_FILL_BL0       | H, 0, 1        | 141  |
| 0x25    | R_FILL_BL1       | H, 0, 1        | 142  |
| 0x26    | R_FILL_BL2       | H, 0, 1        | 143  |
| 0x27    | R_FILL_BL3       | H, 0, 1        | 144  |
| 0x28    | R_CI_RX          | _              | 264  |
| 0x29    | R_GCI_STA        | H, 0, 2        | 265  |
| 0x2A    | R_MON_RX         | _              | 265  |
| 0x30    | R_SU_RD_STA      | H, 0, 3        | 203  |
| 0x31    | R_SU_DLYL        | _              | 204  |
| 0x32    | R_SU_DLYH        | _              | 205  |
| 0x34    | R_MS_RX          | H, 0, 3        | 206  |
| 0x35    | R_SU_STA         | _              | 207  |
| 0x3C    | R_B1_RX          | _              | 208  |
| 0x3D    | R_B2_RX          | _              | 208  |
| 0x3E    | R_D_RX           | -              | 209  |
| 0x3F    | R_E_RX           | -              | 210  |
| 0x40    | R_GPIO_IN1       | -              | 328  |
| 0x45    | R_GPIO_IN2       | _              | 328  |
| 0x48    | R_GPIO_IN0       | -              | 329  |
| 0x50    | R_PLL_STA        | Н              | 312  |
| 0x88    | R_INT_DATA       | -              | 73   |

| Address | Name                | Reset<br>group | Page |
|---------|---------------------|----------------|------|
| 0x51    | R_PLL_P             | Н              | 313  |
| 0x52    | R_PLL_N             | Н              | 313  |
| 0x53    | R_PLL_S             | Н              | 313  |
| 0x80    | A_FIFO_DATA[FIFO]   | _              | 145  |
| 0x84    | A_FIFO_DATA_NOINC[F | IFO]–          | 145  |
| 0xC0    | R_RAM_DATA          | -              | 74   |
| 0xD0    | A_SL_CFG[SLOT]      | H, 0, 2        | 266  |
| 0xF4    | A_CH_MSK[FIFO]      | H, 0, 1        | 146  |
| 0xFA    | A_CON_HDLC[FIFO]    | H, 0, 1        | 147  |
| 0xFB    | A_SUBCH_CFG[FIFO]   | H, 0, 1        | 149  |
| 0xFC    | A_CHANNEL[FIFO]     | H, 0, 1        | 150  |
| 0xFD    | A_FIFO_SEQ[FIFO]    | H, 0, 1        | 151  |
| 0xFF    | A_FIFO_CTRL[FIFO]   | H, 0, 1        | 152  |



# About this data sheet and Cologne Chip technical support

This data sheet covers all the features of XHFC-1SU. The reader who absorbs the information in this data sheet will gain a deep and broad understanding of XHFC-1SU microchip.

However, the hurried reader needs not to read the complete data sheet. Every chapter comprises just one topic. What's not needed in the focus of a target application can be skipped over while reading this data sheet.

### Organization of this data sheet

Chapters start with a short overview. They typically contain both the electrical description and the programming features of the corresponding subject. Finally, chapters end with a register description.

Links between chapters are mentioned in the text.

### **Development tools**

Driver software plays an important role in all ISDN projects. For this reason we offer more than the hardware:

- An evaluation board of XHFC-1SU is available. This can be connected to the target microprocessor system via a flat ribbon cable. It is planned to make the evaluation board accessible via a PCI bridge board to a standard PC environment.
- A demo layer 1 driver as source code as well as open-source (GPL) Linux drivers are available.
- There are also header files with all registers and their bitmaps available for programming language C. Please ask the Cologne Chip support team for more information and file delivery.

### Visit our web site

Our web site (http://www.colognechip.com) contains a download area for all Cologne Chip data sheets. Additional information is given concerning transformers, drivers etc. on the website, too.

By having broad knowledge about ISDN applications, Cologne Chip supports any project individually. Please contact our support team.



### **Chapter overview**

- **Chapter "General description"** (1) begins with an overview to XHFC-1SU, especially general block diagrams and a feature list. Pinout diagrams for the different microprocessor bus interfaces and a detailed list of all pins complete this chapter.
- **Chapter "Microprocessor bus interface":** (2) XHFC-1SU supports several processor interfaces which are explained in this chapter. This includes signal and timing characteristics as well as register access explanation and typical connection circuitries. (Separated inferface modes, read only the section which deals with the interface mode of your interest, prerequisite knowledge of the chosen interface mode is strongly recommended.)
- **Chapter "XHFC-1SU data flow"** (3) starts with the data processing explanation. This chapter deals with the data flow concept which connects all the data interfaces that are explained in the following chapters. (It is recommended to have at least a basic comprehension to this topic, as it connects several important parts of XHFC-1SU.)
- **Chapter "FIFO handling and HDLC controller"** (4) covers the host side of the data flow. This includes both the HDLC controller and the FIFOs. (Should be read because FIFOs and the HDLC controller is typically used in every application.)
- **Chapter "Universal ISDN Port":** (5) XHFC-1SU has a line interface which can be configured either in S/T or U<sub>p</sub> mode. This chapter explains the data structures, clock synchronization and external circuitries. (The most important interface, should be read, prerequisite knowledge of ISDN protocol is strongly recommended.)
- **Chapter "PCM interface":** (6) The last interface which deals with the data flow described in chapter 3 is the PCM interface. Beneath other, an important topic of this chapter are synchronization features of XHFC-1SU. (Read only when used, but don't skip the overview in this chapter even if the PCM interface is not used!)
- **Chapter "Pulse width modulation (PWM) outputs":** (7) This chapter can be skipped if the PWM interface is not used.
- Chapter "Bit Error Rate Test (BERT)": (8) This chapter can be skipped if the BERT functionality is not used.
- **Chapter "Clock, PLL, reset, interrupt, timer and watchdog"** (9) explains clock generation and distribution, PLL programming, reset functions and interrupt capabilities. (Must be read.)
- **Chapter "Electrical characteristics":** (11) Some information about the electrical characteristics of XHFC-1SU are given in this chapter. (Information for hardware design.)
- **Chapter "XHFC-1SU package dimensions"** (12) shows the XHFC-1SU package dimensions. (Information for hardware design.)



### General remarks to notations

- 1. The decimal point is written as a point (e.g. 1.23). Thousands separators are written with thin space.
- 2. Numerical values have different notations for various number systems; e.g. the hexadecimal value 0xC9 is '1100 1001' in binary and 201 in decimal notation.
- 3. The prefix 'kilo' is written k for the meaning of 1000 and it is written K for the meaning of 1024.
- 4. The first letter of register names indicates the type: 'R\_ ...' is a register or multi-register, while 'A\_ ...' is an array register.





# Chapter 1

# **General description**



Figure 1.1: XHFC-1SU block diagram



### **1.1** System overview

XHFC-1SU is a ISDN transceiver chip for one ISDN S/T or  $U_{pN}/U_{p0}^{-1}$  Basic Rate Interface with integrated HDLC controllers for all kinds of BRI equipment, such as

- VoIP gateways / VoIP routers
- Integrated Access Devices (IAD)
- ISDN SOHO PABX
- ISDN phones / system phones
- POTS TAs
- ISDN least cost routers
- ISDN LAN routers
- ISDN test equipment

The integrated microprocessor bus interface of XHFC-1SU can be configured to 8 bit parallel microprocessor interface or serial processor interface (SPI). A PCM128 / PCM64 / PCM30 interface for CODEC or inter-chip connection is also integrated. The deep FIFOs of XHFC-1SU are realized with an internal SRAM.

 $<sup>{}^{1}</sup>U_{pN}$  /  $U_{p0}$  in the following referred to as  $U_{p}$ .



## **1.2 Features**

### Line interface

- 1 ISDN interface selectable as S/T or  $U_{pN}/U_{p0}$  interface (Universal ISDN Port)
- S/T ISDN interface in TE and NT mode conform to ITU-T I.430 and TBR 3 [9, 4]
- $U_p$  signal range exceeding  $U_{pN}/U_{p0}$  specification [3]
- Simple external line interface circuitry

### HDLC-controller and FIFO controller

- Universal HDLC controller for both B-, D- and E-channel, can also be used for PCM time slots
- Transparent mode and data rate independently selectable for all FIFOs
- Up to 16 FIFOs for transmit and receive data each, FIFO size configurable from 64 up to 256 bytes per FIFO, maximum 7 HDLC frames per FIFO
- B- and D-channels can be combined for higher data rate to 128 kBit/s (2B) or 144 kBit/s (2B+D)
- Bit Error Rate Test (BERT) with transmitter and receiver
- Programmable data flow to connect FIFOs,  $ST/U_p$  interface and PCM time slotswith each other

#### **PCM interface**

- PCM128 / PCM64 / PCM30 interface configurable to MST (MVIP)<sup>2</sup> or Siemens IOM<sup>TM</sup>-2 and Motorola GCI (monitor and C/I-channel support) for interchip connection or external CODECs
- Programmable PCM time slot assigner for 16 channels in transmit and receive direction each (switch matrix for PCM)
- H.100 data rate supported on PCM bus
- Flexible PCM synchronization options implemented, synchronization input and output signals available

#### Microprocessor bus interface

- Improved 8 bit parallel microprocessor interface compatible to Motorola bus and Siemens / Intel bus, multiplexed and non-multiplexed modes supported
- High performance serial processor interface (SPI), up to 16 XHFC devices addressable with one /SPISEL signal
- Auto-configure mode for repeater applications without microcontroller (only external EEPROM needed)

#### **Miscelleanous features**

- Flexible interrupt controller, timer and watchdog with interrupt capability
- Programmable PLL with big range of clock frequencies for general purpose usage (can also be used to generate the internal system clock)
- 6 dedicated GPIO pins available, 6 additional pins can be used for GPIO when the line interface is not used, further 8 GPIOs can be enabled separately as second pin function
- 2 general purpose pulse width modulators (PWM) with dedicated output pins

### **Technology features**

- Single 3.3 V power supply, CMOS technology 3.3 V, 5 V tolerant on nearly all inputs
- LQFP 64 package, 0.5 mm pin pitch
- RoHS compliant

<sup>&</sup>lt;sup>2</sup>Mitel Serial Telecom bus



### 1.3 Pin description

### 1.3.1 Pinout diagram



NC pins must not be connected

Figure 1.2: XHFC-1SU pinout in parallel processor interface mode





NC pins must not be connected

Figure 1.3: XHFC-1SU pinout in serial processor interface mode



### 1.3.2 Pin list

| Pin | Function                     | Name            | I/O (type)           | Description                                              | $\mathbf{U}_{in} / \mathbf{V}$ | $\mathbf{I}_{\mathrm{out}}/\mathbf{mA}$ |  |  |  |
|-----|------------------------------|-----------------|----------------------|----------------------------------------------------------|--------------------------------|-----------------------------------------|--|--|--|
|     | Microprocessor bus interface |                 |                      |                                                          |                                |                                         |  |  |  |
| 1   | Processor<br>SPI             | /CS<br>/SPISEL  | I (2 #)<br>I (2 #)   | Chip select, active low<br>SPI device select, active low | TTL<br>TTL                     |                                         |  |  |  |
| 2   | Processor<br>SPI             | A0<br>GND       | I (2 #)              | Address<br>Ground                                        | TTL                            |                                         |  |  |  |
| 3   |                              | GND             |                      | Ground                                                   |                                |                                         |  |  |  |
| 4   | Processor<br>SPI             | D7<br>SPI_TX    | IO (1 #)<br>O (1)    | Data bit 7<br>SPI transmit data output                   | TTL                            | 8 mA<br>8 mA                            |  |  |  |
| 5   | Processor<br>SPI             | D6<br>SPI_RX    | IO (1 #)<br>I (1 #)  | Data bit 6<br>SPI receive data input                     | TTL<br>TTL                     | 8 mA                                    |  |  |  |
| 6   | Processor<br>SPI             | D5<br>GND       | IO (1 #)             | Data bit 5<br>Ground                                     | TTL                            | 8 mA                                    |  |  |  |
| 7   | Processor<br>SPI             | D4<br>GND       | IO (1 #)             | Data bit 4<br>Ground                                     | TTL                            | 8 mA                                    |  |  |  |
| 8   | Processor<br>SPI             | D3<br>DN3       | IO (1 #)<br>I (1 #)  | Data bit 3<br>SPI device number, bit 3                   | TTL<br>TTL                     | 8 mA                                    |  |  |  |
| 9   | Processor<br>SPI             | D2<br>DN2       | IO (1 #)<br>I (1 #)  | Data bit 2<br>SPI device number, bit 2                   | TTL<br>TTL                     | 8 mA                                    |  |  |  |
| 10  | Processor<br>SPI             | D1<br>DN1       | IO (1 #)<br>I (1 #)  | Data bit 1<br>SPI device number, bit 1                   | TTL<br>TTL                     | 8 mA                                    |  |  |  |
| 11  | Processor<br>SPI             | D0<br>DN0       | IO (1 #)<br>I (1 #)  | Data bit 0<br>SPI device number, bit 0                   | TTL<br>TTL                     | 8 mA                                    |  |  |  |
|     |                              |                 | Μ                    | iscellaneous                                             |                                |                                         |  |  |  |
| 12  |                              | GND             |                      | Ground                                                   |                                |                                         |  |  |  |
| 13  |                              | VDD             |                      | +3.3 V power supply                                      |                                |                                         |  |  |  |
| 14  |                              | /INT            | Ood #                | Interrupt request pin, active<br>low / high programmable |                                | 8 mA                                    |  |  |  |
| 15  |                              | /RES            | Isch #               | Reset input pin, active low                              | TTL                            |                                         |  |  |  |
|     |                              |                 | PO                   | CM interface                                             |                                |                                         |  |  |  |
| 16  | 1st function<br>2nd function | SYNC_O<br>GPIO6 | IO (1 #)<br>IO (1 #) | Synchronization output<br>General purpose I/O pin 6      | TTL<br>TTL                     | 8 mA<br>8 mA                            |  |  |  |
| 17  |                              | SYNC_I          | I (2 #)              | Synchronization input                                    | TTL                            |                                         |  |  |  |
|     |                              |                 |                      |                                                          |                                |                                         |  |  |  |

(continued on next page)


(continued from previous page)

| Pin           | Function                     | Name          | I/O (type)        | Description                                                 | $\mathbf{U}_{\mathrm{in}} / \mathbf{V}$ | $I_{out}/mA$ |
|---------------|------------------------------|---------------|-------------------|-------------------------------------------------------------|-----------------------------------------|--------------|
| 18            |                              | C2IO          | IOpu #            | PCM bit clock                                               | TTL                                     | 8 mA         |
| 19            |                              | C4IO          | IOpu #            | PCM double bit clock                                        | TTL                                     | 8 mA         |
| 20            |                              | F0IO          | IOpu #            | PCM frame clock (8 kHz)                                     | TTL                                     | 8 mA         |
| 21            | 1st function                 | STIO1         | IOpu #            | PCM data line 1, I or O per time slot                       | TTL                                     | 8 mA         |
|               | 2nd function                 | GPIO4         | IOpu #            | General purpose I/O pin 4                                   | TTL                                     | 8 mA         |
| 22            | 1st function                 | STIO2         | IOpu #            | PCM data line 2, I or O per time slot                       | TTL                                     | 8 mA         |
|               | 2nd function                 | GPIO5         | IOpu #            | General purpose I/O pin 5                                   | TTL                                     | 8 mA         |
| 23            |                              | GND           |                   | Ground                                                      |                                         |              |
| 24            |                              | VDD           |                   | +3.3 V power supply                                         |                                         |              |
| 25            |                              | MODE0         | I (2 #)           | Interface mode pin 0                                        | TTL                                     |              |
| 26            |                              | MODE1         | I (2 #)           | Interface mode pin 1                                        | TTL                                     |              |
| 27            | 1st function                 | F1_1          | 0(1)              | Enable signal for external CODEC 1                          |                                         | 8 mA         |
|               | 2nd function                 | GPIO3         | IO (1 #)          | General purpose I/O pin 3                                   | TTL                                     | 8 mA         |
| 28            | 1st function                 | F1_0          | 0(1)              | Enable signal for external CODEC 0                          |                                         | 8 mA         |
|               | 2nd function                 | GPIO2         | IO (1 #)          | General purpose I/O pin 2                                   | TTL                                     | 8 mA         |
|               |                              |               |                   | Clock                                                       |                                         |              |
| 29            |                              | VDD           |                   | +3.3 V power supply                                         |                                         |              |
| 30            |                              | OSC_IN        | I (4)             | Oscillator input signal                                     | Oscillator                              |              |
| 31            |                              | OSC_OUT       | O (3)             | Oscillator output signal                                    |                                         | Oscillator   |
| 32            |                              | GND           |                   | Ground                                                      |                                         |              |
| 33            | 1st function                 | CLK_OUT       | 0(1)              | Clock output signal                                         |                                         | 8 mA         |
|               | 2nd function                 | GPIO7         | IO (1 #)          | General purpose I/O pin 7                                   | TTL                                     | 8 mA         |
| Miscellaneous |                              |               |                   |                                                             |                                         |              |
| 34            | 1st function                 | WAKEUP        | I (1 #)           | Wakeup input pin for external awake circuitry               | TTL                                     |              |
|               | 2nd function                 | /WD           | Ood #             | Watchdog output signal                                      | TTL                                     |              |
| 35            | 1st function<br>2nd function | PWM1<br>GPIO1 | O (1)<br>IO (1 #) | Pulse width modulator output 1<br>General purpose I/O pin 1 | TTL                                     | 8 mA<br>8 mA |
| 36            | 1st function                 | PWM0          | 0(1)              | Pulse width modulator output 0                              |                                         | 8 m 4        |
|               | 2nd function                 | GPIO0         | IO (1 #)          | General purpose I/O pin 0                                   | TTL                                     | 8 mA         |

(continued on next page)



(continued from previous page)

| Pin | Function     | Name   | I/O (type) | Description                                     | $\mathbf{U}_{\mathrm{in}}/\mathbf{V}$ | $I_{out}/mA$ |
|-----|--------------|--------|------------|-------------------------------------------------|---------------------------------------|--------------|
| 37  |              | VDD    |            | +3.3 V power supply                             |                                       |              |
| 38  |              | GND    |            | Ground                                          |                                       |              |
|     |              |        | Gene       | ral purpose I/O                                 |                                       |              |
| 39  |              | GPIO15 | IO (3)     | General purpose I/O pin 15                      | TTL                                   | 3 mA         |
| 40  |              | GPIO14 | IO (3)     | General purpose I/O pin 14                      | TTL                                   | 3 mA         |
| 41  |              | GPIO13 | IO (3)     | General purpose I/O pin 13                      | TTL                                   | 3 mA         |
| 42  |              | GPIO12 | IO (3)     | General purpose I/O pin 12                      | TTL                                   | 3 mA         |
| 43  |              | NC     |            | Must not be connected                           |                                       |              |
| 44  |              | VDD    |            | +3.3 V power supply                             |                                       |              |
| 45  |              | GND    |            | Ground                                          |                                       |              |
| 46  |              | GPIO19 | IO (3)     | General purpose I/O pin 19                      | TTL                                   | 16 mA        |
| 47  |              | GPIO18 | IO (3)     | General purpose I/O pin 18                      | TTL                                   | 16 mA        |
| 48  |              | VDD    |            | +3.3 V power supply                             |                                       |              |
|     |              |        | Unive      | ersal ISDN Port                                 |                                       |              |
| 49  |              | VDD_SU |            | Power supply for the ST/Up interface            |                                       |              |
| 50  | 1st function | T_B    | O (2)      | Combined ST/Up interface                        |                                       | S/T / Up     |
|     | 2nd function | GPIO17 | IO (3)     | General purpose I/O pin 17                      | TTL                                   | 16 mA        |
| 51  | 1st function | T_A    | O (2)      | Combined ST / Up interface<br>transmit output A |                                       | S/T / Up     |
|     | 2nd function | GPIO16 | IO (3)     | General purpose I/O pin 16                      | TTL                                   | 16 mA        |
| 52  |              | GND    |            | Ground                                          |                                       |              |
| 53  |              | VDD    |            | +3.3 V power supply                             |                                       |              |
| 54  |              | ADJ    | Ood #      | Combined ST/Up interface level generator        |                                       | 2 mA         |
| 55  | 1st function | R_B    | I (3)      | Combined ST/Up receive input B                  | S/T / Up                              |              |
|     | 2nd function | GPIO11 | IO (3)     | General purpose I/O pin 11                      | TTL                                   | 3 mA         |
| 56  | 1st function | L_B    | I (3)      | Combined ST/Up interface level detect B         | S/T / Up                              |              |
|     | 2nd function | GPIO10 | IO (3)     | General purpose I/O pin 10                      | TTL                                   | 3 mA         |
|     |              |        |            |                                                 | (continued or                         | n next page) |



(continued from previous page)

| Pin | Function         | Name        | I/O (type) | Description                                      | $\mathbf{U}_{\mathrm{in}}/\mathbf{V}$ | $I_{out}/mA$ |
|-----|------------------|-------------|------------|--------------------------------------------------|---------------------------------------|--------------|
| 57  | 1st function     | L_A         | I (3)      | Combined ST/Up interface level detect A          | S/T / Up                              |              |
|     | 2nd function     | GPIO9       | IO (3)     | General purpose I/O pin 9                        | TTL                                   | 3 mA         |
| 58  | 1st function     | R_A         | I (3)      | Combined ST/Up interface receive input A         | S/T / Up                              |              |
|     | 2nd function     | GPIO8       | IO (3)     | General purpose I/O pin 8                        | TTL                                   | 3 mA         |
| 59  |                  | GND         |            | Ground                                           |                                       |              |
| 60  |                  | VDD         |            | +3.3 V power supply                              |                                       |              |
|     |                  |             | Micropro   | cessor bus interface                             |                                       |              |
| 61  | Processor        | /WAIT       | Ood #      | Wait signal for external processor, active low   |                                       | 8 mA         |
|     | SPI              | NC          |            | Must not be connected                            |                                       |              |
| 62  | Processor        | ALE         | I (2 #)    | Address latch enable (only in multiplexed modes) | TTL                                   |              |
|     | SPI              | SPI_INV     | I (2 #)    | Invert SPI clock                                 | TTL                                   |              |
| 63  | Processor        | /IOR        | I (2 #)    | Read enable                                      | TTL                                   |              |
|     | SPI              | SPI_CLK     | I (2 #)    | SPI clock input                                  | TTL                                   |              |
| 64  | Processor<br>SPI | /IOW<br>GND | I (2 #)    | Write enable<br>Ground                           | TTL                                   |              |



| Legend: | IO (1 #) | Bidirectional pin, input 5 V tolerant, 9 pF pin capacitance                                                                        |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------|
|         | IO (3)   | Bidirectional pin                                                                                                                  |
|         | IOpu #   | Bidirectional pin with internal pull-up resistor of $110 \text{ k}\Omega$ typical to VDD, input 5 V tolerant, 9 pF pin capacitance |
|         | I (1 #)  | Input pin, 5 V tolerant, 9 pF pin capacitance                                                                                      |
|         | I (2 #)  | Input pin, 5 V tolerant, 3 pF pin capacitance                                                                                      |
|         | I (3)    | Line interface input pin                                                                                                           |
|         | I (4)    | Oscillator input pin, 12 pF pin capacitance                                                                                        |
|         | Isch #   | Schmitt Trigger input pin, 5 V tolerant, 9 pF pin capacitance                                                                      |
|         | O (1)    | Output pin, 9 pF pin capacitance                                                                                                   |
|         | O (2)    | Line interface output pin                                                                                                          |
|         | O (3)    | Oscillator output pin, 10 pF pin capacitance                                                                                       |
|         | Ood #    | Output pin with open drain, 5 V tolerant, 9 pF pin capacitance                                                                     |
|         | NC       | Must not be connected                                                                                                              |

Pins with 5 V tolerant input are marked with #.

Unused input pins should be connected to ground.

Unused I/O pins should be connected with pull-down resistor to ground. It is recommended to use a maximum of  $22 k\Omega$  for pins with internal pull-up resistor and a maximum of  $100 k\Omega$  for pins without internal pull-up resistor.



# Chapter 2

# **Microprocessor bus interface**

| Write only | registers: |    | Read only  | registers:    |      |
|------------|------------|----|------------|---------------|------|
| Address    | Name Page  |    | Address    | Name          | Page |
| 0x01       | R_CTRL     | 70 | 0x15       | R_RAM_USE     | 72   |
| 0x08       | R_RAM_ADDR | 71 | 0x16       | R_CHIP_ID     | 72   |
| 0x09       | R_RAM_CTRL | 71 | 0x1F       | R_CHIP_RV     | 72   |
|            |            |    | 0x88       | R_INT_DATA    | 73   |
|            |            |    | Read / wri | te registers: |      |
|            |            |    | Address    | Name          | Page |
|            |            |    | 0xC0       | R_RAM_DATA    | 74   |

Table 2.1: Overview of the XHFC-1SU bus interface registers



## 2.1 Mode selection

XHFC-1SU has an integrated microprocessor bus interface which can be configured as parallel 8 bit microprocessor interface and serial processor interface (SPI). Table 2.2 shows how to select these bus modes via the two pins MODE0 and MODE1.

|  | Table 2.2: | Microprocessor | access types |
|--|------------|----------------|--------------|
|--|------------|----------------|--------------|

| Bus mode                         | MODE1 | MODE0 |
|----------------------------------|-------|-------|
| Serial processor interface (SPI) | 0     | 0     |
| Parallel processor interface     |       |       |
| Modes 2 and 2m: Motorola         | 0     | 1     |
| Modes 3 and 3m: Intel            | 1     | 0     |
| Auto-EEPROM mode                 | 1     | 1     |

The Auto-EEPROM mode lets XHFC-1SU operate without an external microprocessor. The complete setup procedure can be stored in an external EEPROM. This mode is useful for applications that do not need a microprocessor intervention during operation (i.e. only static initialization required), e.g.  $U_p$  repeater applications.

The mode selection pins MODE0 and MODE1 must be stable during hardware reset. Sections 2.2 to 2.4 explain how to use XHFC-1SU in the different bus modes.



## **2.2** Parallel processor interface

| Number | Name  | Description                                         |
|--------|-------|-----------------------------------------------------|
| 14     | /INT  | Interrupt request pin, active low/high programmable |
| 15     | /RES  | Reset input pin, active low                         |
| 25     | MODE0 | Interface mode pin 0                                |
| 26     | MODE1 | Interface mode pin 1                                |
| 61     | /WAIT | Wait signal for external processor, active low      |
| 62     | ALE   | Address latch enable (only in multiplexed modes)    |
| 63     | /IOR  | Read enable                                         |
| 64     | /IOW  | Write enable                                        |
| 1      | /CS   | Chip select, active low                             |
| 2      | A0    | Address                                             |
| 114    | D0D7  |                                                     |

**Table 2.3:** Overview of the parallel processor interface pins

#### 2.2.1 Overview

XHFC-1SU has four different parallel microprocessor interface modes. According to the name conventions of other Cologne Chip products (HFC series) the non-multiplexed processor interface modes are numbered 2 and 3 like shown in Table 2.4. The corresponding multiplexed modes are named 2m and 3m.<sup>1</sup>

The interface mode is determined with power-on. For the non-multiplexed modes 2 and 3, the ALE pin must be stable after reset and should be fixed to ground.

Multiplexed modes are selected after reset with the first rising edge of ALE. XHFC-1SU then switches permanently from mode 2 into mode 2m or from mode 3 into mode 3m respectively. XHFC-1SU cannot switch to multiplexed modes before end of reset time. Rising and falling edges of ALE are ignored during reset time.

#### 2.2.2 Interface signals

The processor interface signals have different names for Motorola and Intel microprocessors. Table 2.5 shows the mapping with the pin names of XHFC-1SU.

<sup>&</sup>lt;sup>1</sup>Mode 3m is formerly known as mode 4 from previous chips of the HFC series.



| Pin   | Mode 2<br>Motorola<br>Non-mult | Mode 3<br>Intel<br>tiplexed | Mode 2m<br>Motorola<br>Multip | Mode 3m<br>Intel<br>Jlexed |
|-------|--------------------------------|-----------------------------|-------------------------------|----------------------------|
| MODE0 | 1                              | 0                           | 1                             | 0                          |
| MODE1 | 0                              | 1                           | 0                             | 1                          |
| ALE   | $0^{*1}$                       | $0^{*1}$                    | *2                            | *2                         |

**Table 2.4:** Parallel processor interface mode selection

<sup>\*1</sup>: This pin should be fixed to ground

\*2: 1-pulse latches register address

| Table 2.5: Pins and signal names of the parallel processor interface modes |          |                                       |                                    |                                    |                                 |  |  |
|----------------------------------------------------------------------------|----------|---------------------------------------|------------------------------------|------------------------------------|---------------------------------|--|--|
| XHFC-1                                                                     | ISU pins |                                       | Signal name                        | es                                 |                                 |  |  |
| lumber                                                                     | Name     | Mode 2<br>Motorola<br>Non-multiplexed | Mode 3<br>Intel<br>Non-multiplexed | Mode 2m<br>Motorola<br>Multiplexed | Mode 3m<br>Intel<br>Multiplexed |  |  |
| 1                                                                          | /CS      | /CS                                   | /CS                                | /CS                                | /CS                             |  |  |
| 63                                                                         | /IOR     | /DS                                   | /RD                                | /DS                                | /RD                             |  |  |
| 64                                                                         | /IOW     | R/W                                   | /WR                                | R/W                                | /WR                             |  |  |
| 62                                                                         | ALE      | '0'                                   | '0'                                | ALE                                | ALE                             |  |  |

A0

D7..D0

'0'

AD7 .. AD0

'0'

AD7 .. AD0

#### 2.2.3 Register access

2

4..11

A0

D7..D0

ľ

#### 2.2.3.1 Non-multiplexed / multiplexed access

A0

D7..D0

**Non-multiplexed modes:** With this indirect addressing method, modes 2 and 3, A0 is the address input line. A0 = '0' is used for data write and read, while A0 = '1' is used for address write and read-back accesses.

Both, register address and data, are transferred through the pins D7..D0 (D0 is LSB). The address must first be written on D7..D0 with A0 = '1'. Then data read or write can be performed with A0 = '0' on the same bus D7..D0. Several data accesses can be executed to the same register address without writing the address again. Access details are shown in the timing diagrams in Figures 2.1 and 2.2.

**Multiplexed modes:** Direct addressing is supported with the multiplexed modes 2m and 3m. These do not use A0 and require A0 = '0' all the time.

All registers can directly be accessed in multiplexed mode. ALE latches the register address. The multiplexed address and data bus is D7..D0 (D0 is LSB). Timing diagrams are shown in Figures 2.3 and 2.4.



#### 2.2.3.2 Read\* access

Some registers must be read with an indirect method, the so-called Read<sup>\*</sup> access (written as 'r<sup>\*</sup>' characteristic in register tables). This refers to all readable registers in the address range 0xC0..0xFF, here called *target register*.

The Read\* access performs two consecutive read accesses to XHFC-1SU:

- 1. First, a read access to the target register must be executed. The returned value is not the value of the register and must be ignored.
- 2. Then, the target register value can be read from register R\_INT\_DATA.

The Read\* access is practical for the target registers R\_RAM\_DATA, A\_SL\_CFG, A\_CH\_MSK, A\_CON\_HDLC, A\_SUBCH\_CFG, A\_CHANNEL, A\_FIFO\_SEQ and A\_FIFO\_CTRL. All other registers have a direct read access.

#### 2.2.3.3 Register address read-back capability

When the non-multiplexed modes 2 and 3 are used, the address read access can be executed to readback the address of the currently selected register.

#### 2.2.3.4 Problems with interrupts between address write and data read / write accesses

The register address read-back capability is useful for interrupt procedures, e.g., to save and restore the previous state:

```
interrupt procedure: - execute address read access and store the register address
- ... (execute the interrupt service routine)
- address write access to restore the previous register address
```

This procedure is important to avoid data read or write to an unexpected register address after a register read or write access has been split by an interrupt service routine which executes any access to XHFC-1SU.

#### 2.2.4 Signal and timing characteristics

Table 2.6 shows the interface signals for the different microprocessor interface modes. Timing characteristics are shown in Figures 2.1 and 2.2 for non-multiplexed modes 2 and 3. Figures 2.3 and 2.4 show multiplexed modes 2m and 3m timing characteristics. Please see Table 2.7 for a quick timing and symbol list finding.

#### **2.2.4.1** Bus interface in mode 2 and mode 3 (non-multiplexed)

#### Read access

8 bit processors read data like shown in Figure 2.1. Timing values are listed in Table 2.8.

Cologne Chip



Figure 2.1: Bus interface read access in mode 2 (Motorola) and mode 3 (Intel)

Notes:

- (1) It is not necessary to use /WAIT if the processor is able to ensure the  $t_{CYCLE}$  timing constraint.
- (2) /WAIT signal is only active if the interval of two consecutive data phases is less than  $t_{CYCLE}$ .
- (3) For faster access, it is recommended to set up a processor timing which does not require the /WAIT signal.



| /CS | / <b>IOR</b><br>(/DS, /RD) | / <b>IOW</b><br>(R/W, /WR) | ALE | A0 | Operation     | Processor<br>interface mode |
|-----|----------------------------|----------------------------|-----|----|---------------|-----------------------------|
| 1   | Х                          | Х                          | Х   | Х  | no access     | all                         |
| 0   | 1                          | 1                          | 0   | 0  | no access     | all                         |
| 0   | 0                          | 1                          | 0   | 1  | read address  | mode 2                      |
| 0   | 0                          | 0                          | 0   | 1  | write address | mode 2                      |
| 0   | 0                          | 1                          | 0   | 0  | read data     | mode 2                      |
| 0   | 0                          | 0                          | 0   | 0  | write data    | mode 2                      |
| 0   | 0                          | 1                          | 0   | 1  | read address  | mode 3                      |
| 0   | 1                          | 0                          | 0   | 1  | write address | mode 3                      |
| 0   | 0                          | 1                          | 0   | 0  | read data     | mode 3                      |
| 0   | 1                          | 0                          | 0   | 0  | write data    | mode 3                      |
| 0   | 0                          | 1                          |     | 0  | read data     | mode 2m                     |
| 0   | 0                          | 0                          |     | 0  | write data    | mode 2m                     |
| 0   | 0                          | 1                          |     | 0  | read data     | mode 3m                     |
| 0   | 1                          | 0                          | *   | 0  | write data    | mode 3m                     |

**Table 2.6:** Overview of accesses in parallel microprocessor interface mode (X = don't care)

\*: 1-pulse latches register address

| Table 2.7: | Timing diagrams | of the parallel | microprocessor | · interface |
|------------|-----------------|-----------------|----------------|-------------|
|            |                 |                 |                |             |

| Mode    | Access | Timing |         | Timing values |         |  |
|---------|--------|--------|---------|---------------|---------|--|
|         | type   | Figure | on page | table         | on page |  |
| 2 & 3   | read   | 2.1    | 46      | 2.8           | 48      |  |
| 2 & 3   | write  | 2.2    | 49      | 2.9           | 50      |  |
| 2m & 3m | read   | 2.3    | 52      | 2.10          | 51      |  |
| 2m & 3m | write  | 2.4    | 54      | 2.11          | 53      |  |

Data can be read with<sup>2</sup>

$$(/DS + /CS) = '0'$$
 and  $R/W = '1'$ .

in mode 2 (Motorola) or with

$$(/RD + /CS) = '0'$$
 and  $/WR = '1'$ 

in mode 3 (Intel). The data bus is stable after  $t_{RD min}$  and returns into tristate after  $t_{DRDH}$ .

The address line A0 requires a setup time  $t_{AS}$ . The hold time of this line is  $t_{AH}$ .

 $<sup>^{2}</sup>$ /DS + /CS means logical OR function of the two signals.



| Symbol                    | min / ns            | max / ns                  | Characteristic                                       |  |  |
|---------------------------|---------------------|---------------------------|------------------------------------------------------|--|--|
| tas                       | 20                  |                           |                                                      |  |  |
| 115                       |                     |                           | A0 valid to /DS+/CS (/WR+/CS) $\$ setup time         |  |  |
| $t_{\rm AH}$              | 0                   |                           | Address hold time after /DS+/CS (/WR+/CS)            |  |  |
| t <sub>WRA</sub>          | 20                  |                           | Write time for address write                         |  |  |
| <i>t</i> <sub>DWRS</sub>  | 25                  |                           | Write data setup time to /DS+/CS (/WR+/CS) _         |  |  |
| <i>t</i> <sub>DWRH</sub>  | 0                   |                           | Write data hold time from /DS+/CS (/WR+/CS) _        |  |  |
| t <sub>RD</sub>           | 25                  |                           | Read time                                            |  |  |
| <i>t</i> <sub>CYCLE</sub> |                     |                           | /DS+/CS (/RD+/CS)                                    |  |  |
|                           | 30                  |                           | Register address range 0x000x7F                      |  |  |
|                           | $3.5 \cdot t_{SYS}$ |                           | Register address range 0x800xFF                      |  |  |
| t <sub>DRDZ</sub>         | 3                   |                           | /DS+/CS (/RD+/CS) $\$ to data buffer turn on time    |  |  |
| t <sub>DRDH</sub>         | 2                   | 15                        | /DS+/CS (/RD+/CS)                                    |  |  |
| t <sub>RWS</sub>          | 2                   |                           | R/W setup time to /DS+/CS \((in mode 2 only))        |  |  |
| t <sub>RWH</sub>          | 2                   |                           | R/W hold time after /DS+/CS \(\[ (in mode 2 only) \) |  |  |
| t <sub>WS</sub>           |                     | 10                        | /WAIT turn on time to /DS+/CS or /WR+/CS L           |  |  |
| <i>t</i> <sub>WLMIN</sub> | 0                   |                           | Minimum /WAIT low time                               |  |  |
| t <sub>WLMAX</sub>        |                     | <i>t</i> <sub>CYCLE</sub> | Maximum /WAIT low time                               |  |  |

 Table 2.8: Symbols of read accesses in Figure 2.1

The cycle time specifies the time between two consecutive data accesses.  $t_{SYS} = 1/f_{SYS}$  with the system clock  $f_{SYS}$ .

#### Write access

8 bit processors write data like shown in Figure 2.2. Timing values are listed in Table 2.9.

Data is written with  $\Box$  of (/DS + /CS) in mode 2 (Motorola) or with  $\Box$  of (/WR + /CS) in mode 3 (Intel) respectively. XHFC-1SU requires a data setup time  $t_{DWRS}$  and a data hold time  $t_{DWRH}$ .

The address line A0 requires a setup time  $t_{AS}$  which starts when the address signal is valid. The hold time is  $t_{AH} \ge 0$  ns after address write access and it is  $t_{AHD} \ge 0.5 t_{SYS} + 9$  ns after data write access.<sup>3</sup>

<sup>&</sup>lt;sup>3</sup>Please ask Cologne Chip's support team if the intended processor has problems with  $t_{AHD}$  (support@CologneChip.com).



Figure 2.2: Bus interface write access in mode 2 (Motorola) and mode 3 (Intel)

Notes:

- (1) It is not necessary to use /WAIT if the processor is able to ensure the  $t_{CYCLE}$  timing constraint.
- (2) /WAIT signal is only active if the interval of two consecutive data phases is less than  $t_{CYCLE}$ .
- (3) For faster access, it is recommended to set up a processor timing which does not require the /WAIT signal.





| Symbol                    | min / ns                | max / ns                  | Characteristic                                                              |
|---------------------------|-------------------------|---------------------------|-----------------------------------------------------------------------------|
| t <sub>AS</sub>           | 20                      |                           |                                                                             |
| 110                       |                         |                           | A0 valid to /DS+/CS (/WR+/CS) _ setup time                                  |
| $t_{\rm AH}$              | 0                       |                           | Address hold time of address write access after /DS+/CS (/WR+/CS) $\_ \Box$ |
| $t_{\rm AHD}$             | $0.5 \cdot t_{SYS} + 9$ |                           | Address hold time of data write access after /DS+/CS (/WR+/CS) $\_$         |
| t <sub>WRA</sub>          | 20                      |                           | Write time for address write                                                |
| t <sub>DWRS</sub>         | 20                      |                           | Write data setup time to /DS+/CS (/WR+/CS) _                                |
| t <sub>DWRH</sub>         | 0                       |                           | Write data hold time from /DS+/CS (/WR+/CS)                                 |
| t <sub>WR</sub>           | 20                      |                           | Write time                                                                  |
| <i>t</i> <sub>CYCLE</sub> |                         |                           | /DS+/CS (/RD+/CS) _ to next /DS+/CS (/RD+/CS) _                             |
|                           | $1.5 \cdot t_{SYS}$     |                           | Register address range 0x000x7F                                             |
|                           | $3.5 \cdot t_{SYS}$     |                           | Register address range 0x800xFF                                             |
| t <sub>RWS</sub>          | 2                       |                           | R/W setup time to /DS+/CS                                                   |
| t <sub>RWH</sub>          | 2                       |                           | R/W hold time after /DS+/CS \(\[(in mode 2 only))                           |
| t <sub>WS</sub>           |                         | 10                        | /WAIT turn on time to /DS+/CS or /WR+/CS \                                  |
| <i>t</i> <sub>WLMIN</sub> | 0                       |                           | Minimum /WAIT low time                                                      |
| t <sub>WLMAX</sub>        |                         | <i>t</i> <sub>CYCLE</sub> | Maximum /WAIT low time                                                      |

#### Table 2.9: Symbols of write accesses in Figure 2.2



| Symbol                    | min / ns            | max / ns                  | Characteristic                                         |
|---------------------------|---------------------|---------------------------|--------------------------------------------------------|
| t <sub>AS</sub>           | 20                  |                           | Address valid to ALE $\$ setup time                    |
| $t_{\rm AH}$              | 0                   |                           | Address hold time after ALE L                          |
| t <sub>ALE</sub>          | 10                  |                           | Address latch time                                     |
| <i>t</i> <sub>ALEL</sub>  | 0                   |                           |                                                        |
|                           |                     |                           | ALE T to /RD+/CS T                                     |
| t <sub>ALEH</sub>         | 0                   |                           | /RD+/CS _ to ALE _                                     |
| t <sub>RD</sub>           | 25                  |                           | Read time                                              |
| <i>t</i> <sub>CYCLE</sub> |                     |                           | /DS+/CS (/RD+/CS)                                      |
|                           | 30                  |                           | Register address range 0x000x7F                        |
|                           | $3.5 \cdot t_{SYS}$ |                           | Register address range 0x800xFF                        |
| t <sub>DRDZ</sub>         | 3                   |                           | /RD+/CS $\Box$ to data buffer turn on time             |
| t <sub>DRDH</sub>         | 2                   | 15                        | /RD+/CS ⊥ to data buffer turn off time                 |
| t <sub>RWS</sub>          | 2                   |                           | R/W setup time to /DS+/CS ∟(in mode 2 only)            |
| t <sub>RWH</sub>          | 2                   |                           | R/W hold time after /DS+/CS $\square$ (in mode 2 only) |
| t <sub>WS</sub>           |                     | 10                        | /WAIT turn on time to /DS+/CS or /WR+/CS L             |
| t <sub>WLMIN</sub>        | 0                   |                           | Minimum /WAIT low time                                 |
| t <sub>WLMAX</sub>        |                     | <i>t</i> <sub>CYCLE</sub> | Maximum /WAIT low time                                 |

 Table 2.10:
 Symbols of read accesses in Figure 2.3

#### 2.2.4.2 Bus interface in mode 2m and mode 3m (multiplexed)

#### **Read access**

8 bit processors read data like shown in Figure 2.3. Timing values are listed in Table 2.10.

Data can be read with <sup>4</sup>

$$(/DS + /CS) = '0'$$
 and  $R/W = '1'$ .

in mode 2m (Motorola) or with

/WR = '1'

in mode 3m (Intel). The data bus is stable after  $t_{RD min}$  and returns into tristate after  $t_{DRDH}$ .

The address line A0 requires a setup time  $t_{AS}$  in relation to  $\neg$  of ALE. The hold time of these lines is  $t_{AH}$ . If consecutive read accesses are on the same register address, multiple address write accesses are not required.

The cycle time specifies the time between two consecutive data accesses.  $t_{SYS} = 1/f_{SYS}$  with the system clock  $f_{SYS}$ .

 $<sup>^4/\</sup>text{DS}+/\text{CS}$  means logical OR function of the two signals.



Microprocessor bus interface

Cologne Chip



| Symbol                    | min / ns            | max / ns                  | Characteristic                                  |  |  |
|---------------------------|---------------------|---------------------------|-------------------------------------------------|--|--|
| t <sub>AS</sub>           | 20                  |                           | Address valid to ALE $\square$ setup time       |  |  |
| $t_{\rm AH}$              | 0                   |                           | Address hold time after /WR+/CS _               |  |  |
| <i>t</i> <sub>ALE</sub>   | 10                  |                           | Address latch time                              |  |  |
| <i>t</i> <sub>ALEL</sub>  | 0                   |                           |                                                 |  |  |
|                           |                     |                           | ALE L to /WR+/CS L                              |  |  |
| $t_{\rm ALEH}$            | 0                   |                           | /WR+/CS _ to ALE _                              |  |  |
| <i>t</i> <sub>DWRS</sub>  | 20                  |                           | Write data setup time to /WR+/CS _              |  |  |
| t <sub>DWRH</sub>         | 0                   |                           | Write data hold time from /WR+/CS _             |  |  |
| t <sub>WR</sub>           | 20                  |                           | Write time                                      |  |  |
| <i>t</i> <sub>CYCLE</sub> |                     |                           | /DS+/CS (/WR+/CS) _ to next /DS+/CS (/WR+/CS) _ |  |  |
|                           | $1.5 \cdot t_{SYS}$ |                           | Register address range 0x000x7F                 |  |  |
|                           | $3.5 \cdot t_{SYS}$ |                           | Register address range 0x800xFF                 |  |  |
| t <sub>RWS</sub>          | 2                   |                           | R/W setup time to /DS+/CS ∟(in mode 2 only)     |  |  |
| t <sub>RWH</sub>          | 2                   |                           | R/W hold time after /DS+/CS _(in mode 2 only)   |  |  |
| $t_{\rm WS}$              |                     | 10                        | /WAIT turn on time to /DS+/CS or /WR+/CS $\Box$ |  |  |
| <i>t</i> <sub>WLMIN</sub> | 0                   |                           | Minimum /WAIT low time                          |  |  |
| t <sub>WLMAX</sub>        |                     | <i>t</i> <sub>CYCLE</sub> | Maximum /WAIT low time                          |  |  |

 Table 2.11: Symbols of write accesses in Figures 2.4

#### Write access

8 bit processors write data like shown in Figure 2.4. Timing values are listed in Table 2.11.

Data is written with  $\Box$  of (/DS + /CS) in mode 2m (Motorola) or with  $\Box$  of (/WR + /CS) in mode 3m (Intel) respectively. XHFC-1SU requires a data setup time  $t_{DWRS}$  and a data hold time  $t_{DWRH}$ .

The address line A0 requires a setup time  $t_{AS}$  in relation to  $\neg$  of ALE. The hold time of these lines is  $t_{AH}$ . If consecutive write accesses are on the same register address, multiple address write accesses are not required.



Cologne Chip



#### 2.2.5 Microprocessor connection circuitries

Figures 2.5 to 2.8 show examples how to connect XHFC-1SU to different parallel processor interfaces.



Figure 2.5: 8 bit Motorola processor circuitry example (mode 2)



Figure 2.6: 8 bit Motorola processor circuitry example (mode 2m)





Figure 2.7: 8 bit Intel processor circuitry example (mode 3)



**Figure 2.8:** 8 bit Intel processor circuitry example (mode 3m)



# 2.3 Serial processor interface (SPI)

| Number | Name    | Description                                           |  |  |
|--------|---------|-------------------------------------------------------|--|--|
| 14     | /INT    | Interrupt request pin, active low / high programmable |  |  |
| 15     | /RES    | Reset input pin, active low                           |  |  |
| 25     | MODE0   | Interface mode pin 0                                  |  |  |
| 26     | MODE1   | Interface mode pin 1                                  |  |  |
| 4      | SPI_TX  | SPI transmit data output                              |  |  |
| 5      | SPI_RX  | SPI receive data input                                |  |  |
| 63     | SPI_CLK | SPI clock input                                       |  |  |
| 1      | /SPISEL | SPI device select, active low                         |  |  |
| 62     | SPI_INV | Invert SPI clock                                      |  |  |
| 11     | DN0     | SPI device number, bit 0                              |  |  |
| 10     | DN1     | SPI device number, bit 1                              |  |  |
| 9      | DN2     | SPI device number, bit 2                              |  |  |
| 8      | DN3     | SPI device number, bit 3                              |  |  |

| Table 2.12: | Overview of the | SPI interface | nins |
|-------------|-----------------|---------------|------|
|             |                 | or r michaec  | pino |

XHFC-1SU has a serial processor interface (SPI) which is compatible with Motorola's SPI. CPUs and MCUs with SPI interface are also available from a variety of semiconductor vendors. The SPI interface has four signal pins as shown in the upper part of Table 2.12. Additional pins are used for SPI clock inversion and SPI device number selection.

SPI interface mode is selected by MODE0 = '0' and MODE1 = '0' (pins 25 and 26). XHFC-1SU supports only SPI slave mode.

Any register access consists of two transactions – an address write transaction first and a data read or write transaction afterwards. SPI transactions of XHFC-1SU have either a length of 16 bits for single byte accesses or 40 bits for high performance accesses. The first byte is a control byte in both cases, whereas the following bits are either one data byte or four data bytes. Control and data bytes are transmitted with MSB first.

#### 2.3.1 SPI control byte

Tables 2.13 and 2.14 show an overwiev of the control byte construction. R and A are used to specify read/write and address/data transaction types. The meaning of bit position 5 depends on the value of A; broadcasting can be enabled with an address transaction and single or multiple data bytes is selected with a data transaction.

Up to 16 microchips of the XHFC series can be connected to the SPI interface and can operate with the same /SPISEL signal. The desired microchip is selected with the device address C3 .. C0 within an address transaction. Every XHFC microchip must specify its address with DN3.. DN0 pins (device number) connected to ground or power supply. A microchip is selected with C3..C0 = DN3..DN0 where all numbers in the range 0..15 are allowed.



In addition to the chip selection, an SPI write access writes its data into *all* connected XHFC microchips if broadcast is used. SPI read accesses with enabled broadcast execute the register read access in all connected XHFC microchips, but only the specified chip delivers its data to the SPI master. The broadcast write access is useful for initialization procedures, e.g., for those registers, which must be initialized in all connected XHFC microchips.

Table 2.15 summarizes the SPI control commands which are coded in the control byte.

#### **2.3.2** SPI transactions

**Table 2.13:** SPI control byte with A = '0'

The waveforms of an address or data write transaction with 16 bits length are shown in Figure 2.9. XHFC-1SU receives the control byte and the data byte with R = '0' on the SPI\_RX line. The SPI\_TX

| Bit | Name   | Description                                                   | Bit | Name  |
|-----|--------|---------------------------------------------------------------|-----|-------|
| 7   | R      | '0' = write<br>'1' = read                                     | 7   | R     |
| 6   | А      | '0' = register data                                           | 6   | A     |
| 5   | М      | '0' = single data byte<br>'1' = multi data bytes (4<br>bytes) | 5   | В     |
| 4   | ,0,    | This bit must be zero in all SPI transactions                 | 4   | '0'   |
| 30  | '0000' | Must be zero in data transac-<br>tions                        | 50  | 03 00 |

**Table 2.14:** SPI control byte with A = '1'

| Bit | Name | Description                                      |  |
|-----|------|--------------------------------------------------|--|
| 7   | R    | '0' = write                                      |  |
|     |      | '1' = read                                       |  |
| 6   | А    | '1' = register address                           |  |
| 5   | В    | '0' = no broadcast                               |  |
|     |      | '1' = broadcast                                  |  |
| 4   | '0'  | This bit must be zero in all SPI transactions    |  |
| 30  | C3C0 | Device address (used for chip select generation) |  |

Table 2.15: SPI control commands for register read and write operations

| Control byte |   |     | R | Α    | M/B     | Timing  |                     |                 |
|--------------|---|-----|---|------|---------|---------|---------------------|-----------------|
| R            | А | M/B | 0 | C3C0 |         |         |                     | diagram         |
| 0            | 0 | 0   | 0 | 0000 | write   | data    | single data byte    | Fig. 2.9        |
| 1            | 0 | 0   | 0 | 0000 | read    | data    | single data byte    | Fig. 2.10       |
| 0            | 1 | 0   | 0 | CCCC | write   | address | no broadcast        | Fig. 2.9        |
| 1            | 1 | 0   | 0 | CCCC | read    | address | no broadcast        | Fig. 2.10       |
| 0            | 0 | 1   | 0 | 0000 | write   | data    | multiple data bytes | Fig. 2.11       |
| 1            | 0 | 1   | 0 | 0000 | read    | data    | multiple data bytes | Fig. 2.12, 2.13 |
| 0            | 1 | 1   | 0 | CCCC | write   | address | broadcast           | Fig. 2.9        |
| 1            | 1 | 1   | 0 | CCCC | read    | address | broadcast           | Fig. 2.10       |
| Х            | Х | Х   | 1 | XXXX | not all | owed    |                     | _               |



pin is not used for write transactions and has tri-state level all the time.

A read transaction is shown in Figure 2.10. XHFC-1SU receives the control byte on the SPI\_RX line and transmits the requested data byte on the SPI\_TX line afterwards.



\*) A and M / B combinations are 00, 10 and 11 in this timing diagram

**Figure 2.10:** 16 bit SPI read transaction (R = '1', one data byte)

A = '0' and M = '1' specify a 40 bit transaction. This is shown in Figures 2.11 and 2.12 for SPI write and read transactions.

Any SPI transactions can be split by the SPI master into the control byte and the data bytes with /SPISEL = '1'. In this case the transmission pauses and will be continued after /SPISEL returns to low level. An example for a split read transaction with multiple data bytes is shown in Figure 2.13. Write transactions can be split in the same way.

The SPI host is not allowed to break an SPI transaction by an interrupt service routine which executes any access to XHFC-1SU. Otherwise master and slave could have different views wether a specific byte is a control or a data byte. If the SPI master cannot ensure this characteristic, interrupts must be disabled between control byte and data byte.

#### 2.3.3 Transaction duration

16 bit SPI transaction have a minimal length of 16 clock cycles. With  $f_{\text{SPICLK}} = 4 \text{ MHz}$ , e.g., a 16 bit transaction takes 4 µs. XHFC-1SU can operate with a maximum SPI clock of 25 MHz which leads to a minimal 16 bit transaction time of

 $T_{\rm trans 16, min} = \frac{16}{25\,\rm MHz} = 640\,\rm ns$  .













**Figure 2.13:** Split 40 bit SPI read transaction (R = '1')



40 bit SPI transaction have a minimal length of 40 clock cycles. With  $f_{\text{SPICLK}} = 4 \text{ MHz}$ , e.g., a 40 bit transaction takes 10 µs. With the maximum SPI clock of 25 MHz, the minimal 40 bit transaction time is

$$T_{\rm trans40,min} = \frac{40}{25\,\rm MHz} = 1.6\,\mu\rm s$$

which leads to to data rate of 400 ns/byte.

The XHFC-1SU SPI protocol defines the following rules for transactions:

- 1. The SPI master is allowed to stop the SPI clock at any time. When the SPI clock is restarted afterwards, the transaction is continued as if it has not been stopped.
- 2. When a write or read transaction is split with /SPISEL = '1' within the control byte, it is ignored and the next received byte is expected to be a control byte.
- 3. When a write transaction is split with /SPISEL = '1' within the data byte, it is ignored and the next received byte is expected to be the data byte again.
- 4. When a read transaction is split with /SPISEL = '1' within the data byte, the transaction quits immediately (SPI\_TX is always tri-state when /SPISEL = '1'). The next received byte is expected to be the data byte again.

#### 2.3.4 Register write access

Register write accesses consist always of a transaction sequence with an address write transaction first and one or several data write transactions afterwards. XHFC-1SU offers four ways of executing register write accesses:

A register write access is a sequence of two SPI write transactions as shown in Figure 2.14. With the first transaction the SPI master specifies the register address (control byte is '01X0 CCCC'). Afterwards, the new register value is transferred from the SPI master to XHFC-1SU (control byte is '0000 0000').

X' = 0' disables broadcast so that 'CCCC' must specify the desired microchip. Alternatively, broadcast is enabled with 'X' = '1' and 'CCCC' is ignored in this case.

- 2. It is allowed to execute multiple data write transactions to the same register address without address write transactions in between. This is shown in Figure 2.15 and is typically used for transmit FIFO data.
- 3. Another way of writing multiple bytes into the same register is available with the 40 bit write transaction (Figure 2.16). With the first transaction (16 bits) the SPI master specifies the register address (control byte is '01X0 CCCC'). Afterwards, four new register values are transferred from the SPI master to XHFC-1SU (control byte is '0010 0000').

Broadcasting is handled in the same way as described in (1).

4. Finally, a combination of (2) and (3) can be used to write a multiple of four bytes. First, the control byte '01X0 CCCC' executes the address write transaction, and afterwards four data bytes can be written several times with the control byte '0010 0000' in each 40 bit write transaction.

Figures 2.14 to 2.16 show /SPISEL = '1' between the transactions. This splits the sequence into an address write transaction and one or several data write transactions. The split time has an arbitrary duration. It can also decrease to zero, which means that /SPISEL remains '0' for several transactions.









Figure 2.15: Multiple write accesses to the same register



Figure 2.16: Register write access with a 40 bit transaction



The XHFC-1SU SPI protocol defines the following rules for transaction sequences:

- 1. Every data write transaction stores the received data byte into the register which has been selected with the last address write transaction.
- 2. When several consecutive address write transactions occur, the last address write transaction specifies the address for the next data access. All previous address write accesses are ignored, i.e. they have no effect to the XHFC-1SU status.

#### 2.3.5 Register read access

Register read accesses consist always of a transaction sequence with an address write transaction first and one or several data read transactions afterwards. XHFC-1SU offers four ways of executing register read accesses:

1. A register read access is a sequence of one SPI write address transactions and one SPI read data transaction as shown in Figure 2.17. With the first transaction the SPI master specifies the register address (control byte is '01X0 CCCC'). Afterwards, XHFC-1SU transfers the register value to the SPI master (control byte is '1000 0000').

X' = 0' disables broadcast so that 'CCCC' must specify the desired microchip. Alternatively, broadcast is enabled with 'X' = '1' and 'CCCC' is ignored in this case.

- 2. It is allowed to execute multiple data read transactions to the same register address without address write transactions in between. This is shown in Figure 2.18 and is typically used for receiving FIFO data.
- 3. Another way of reading multiple bytes from the same register is available with the 40 bit read transaction (Figure 2.19). With the first transaction (16 bits) the SPI master specifies the register address (control byte is '01X0 CCCC'). Afterwards, four register values are transferred from XHFC-1SU to the SPI master (control byte is '1010 0000').

Broadcasting is handled in the same way as described in (1).

4. Finally, a combination of (2) and (3) can be used to read a multiple of four bytes. First, the control byte '01X0 CCCC' executes the address write transaction, and afterwards four data bytes can be read several times with the control byte '1010 0000' in each 40 bit read transaction.



**Figure 2.17:** *Register read access (transaction sequence)* 

Figures 2.17 to 2.19 show /SPISEL = '1' between the transactions. This splits the sequence into an address write transaction and one or several data read transactions. The split time has an arbitrary duration. It can also decrease to zero, which means that /SPISEL remains '0' for several transactions.





Figure 2.18: Multiple read accesses to the same register



Figure 2.19: Register read access with a 40 bit transaction

#### 2.3.6 Register access duration

There are several SPI data rates due to the different register access types. Table 2.16 gives some examples for  $f_{\text{SPICLK}} = 25 \text{ MHz}$  and either one or 16 accesses to the same register.

Sequence duration and data rates are always calculated without split times neither within nor between transactions.

| Table 2.16: SI | PI data rates |
|----------------|---------------|
|----------------|---------------|

| SPI data<br>transaction<br>control byte | Single or<br>multiple<br>data bytes | Number of<br>accesses to the<br>same register | Minimum<br>number of<br>clock cycles | Sequence<br>duration                            | Data rate for $f_{SPICLK} = 25 \mathrm{MHz}$ and $N = 16$ , e.g. |
|-----------------------------------------|-------------------------------------|-----------------------------------------------|--------------------------------------|-------------------------------------------------|------------------------------------------------------------------|
| 'X000 0000'                             | single                              | 1                                             | 32                                   | $T = \frac{32}{f_{\rm SPICLK}}$                 | $DR = \frac{1}{T} = 781 \mathrm{kByte/s}$                        |
| 'X000 0000'                             | single                              | Ν                                             | $(N+1) \cdot 16$                     | $T = \frac{(N+1)\cdot 16}{f_{\rm SPICLK}}$      | $DR = \frac{N}{T} = 1471 \mathrm{kByte/s}$                       |
| 'X0100000'                              | multiple                            | 4                                             | 56                                   | $T = \frac{56}{f_{\rm SPICLK}}$                 | $DR = \frac{4}{T} = 1786 \mathrm{kByte/s}$                       |
| 'X0100000'                              | multiple                            | 4N                                            | $16 + N \cdot 40$                    | $T = \frac{16 + N \cdot 40}{f_{\text{SPICLK}}}$ | $DR = \frac{4N}{T} = 2439 \mathrm{kByte/s}$                      |

#### 2.3.7 Register address read-back capability

The address read transaction with the control byte '11X0 CCCC' can be executed to read the address of the currently selected register.

This address read transaction does not perform a register read access. Thus it can be used even on those registers that change their contents on a read access, i.e. register contents is changed not until a data read transaction has been executed.



#### **2.3.8** Problems with interrupts during transaction sequences

The address read-back capability is useful for interrupt procedures, e.g., to save and restore the previous state:

```
interrupt procedure: - execute address read transaction and store the register address
- ... (execute the interrupt service routine)
- address write transaction to restore the previous register address
```

This procedure is important to avoid data read or write to an unexpected register address after the transaction sequence has been split between transactions by an interrupt service routine which executes any access to XHFC-1SU. Please note, that transactions are not allowed to be split from the SPI master (see Section 2.3.2).

#### 2.3.9 SPI timing diagrams

Figure 2.20 shows the timing diagram for data write transactions (data from master to slave). Four different variations of the SPI clock are shown. SPI clock can be inverted with  $SPI_INV = '1'$ . Further, idle intervals are allowed during non-selected phases where /SPISEL = '1'. During idle intervals, SPI clock must be low for  $SPI_INV = '0'$  and it must be high otherwise.



Figure 2.20: SPI timing diagram for data write transactions

Address and data is sampled on the rising edge of SPI\_CLK when SPI\_INV = '0'. The SPI selection signal /SPISEL must be '0' with this edge at the latest.

When the SPI access is splitted by the SPI master, the rising edge of /SPISEL is required to be  $t_{\text{DESEL}} \ge 2$  ns after the sampling time at the earliest. When clock idle intervals are used, it is necessary to have at least one clock edge after the last sample edge (marked with 'stop clock' in Figure 2.20). This is important to terminate the access internally.

The timing diagram for data read transactions (data from slave to master) is shown in Figure 2.21. The same different variations of the SPI clock which are shown in Figure 2.20 are valid for data read



| Symbol             | min / ns | max / ns | Characteristic                          |
|--------------------|----------|----------|-----------------------------------------|
| t <sub>CLK</sub>   | 40       |          | SPI clock cycle time                    |
| $t_{\rm L}$        | 15       |          | Clock low time                          |
| t <sub>H</sub>     | 15       |          | Clock high time                         |
| t <sub>SEL</sub>   | 0        |          | SPI selection to sample edge setup time |
| t <sub>DESEL</sub> | 2        |          | SPI deselection delay                   |
| t <sub>DS</sub>    | 7        |          | Data setup time                         |
| t <sub>DH</sub>    | 7        |          | Data hold time                          |

 Table 2.17: Symbols of write access in Figure 2.20

transactions but only continiuos clock with  $SPI_INV = '0'$  is shown here.

Address is sampled on the rising edge of SPI\_CLK when SPI\_INV = '0'. The SPI selection signal /SPISEL must be '0' with this edge at the latest. Data is put out  $t_{\text{DEN}} \leq 10$  ns after the falling edge of SPI\_CLK at the latest.



**Figure 2.21:** SPI timing diagram for data read transactions (see Figure 2.20 for additional clock signals /SPICLK, SPICLK\_IDLE and /SPICLK\_IDLE)



Table 2.18: Symbols of read access in Figure 2.21

| Symbol              | min / ns | max / ns | Characteristic                          |
|---------------------|----------|----------|-----------------------------------------|
| t <sub>CLK</sub>    | 40       |          | SPI clock cycle time                    |
| $t_{\rm L}$         | 15       |          | Clock low time                          |
| t <sub>H</sub>      | 15       |          | Clock high time                         |
| $t_{\rm SEL}$       | 0        |          | SPI selection to sample edge setup time |
| t <sub>DESEL</sub>  | 2        |          | SPI deselection delay                   |
| t <sub>DS</sub>     | 7        |          | Data setup time                         |
| t <sub>DH</sub>     | 7        |          | Data hold time                          |
| t <sub>SELD</sub>   | 0        | 10       | SPI selection to data enable delay      |
| t <sub>DESELD</sub> | 0        |          | SPI deselection to data disable delay   |
| t <sub>DEN</sub>    | 0        | 10       | Clock to data enable setup time         |
| t <sub>DDIS</sub>   | 0        | 10       | Clock to data disable setup time        |



#### 2.3.10 SPI connection circuitry



Figure 2.22: SPI connection circuitry



# 2.4 Auto-EEPROM mode

Please contact Cologne Chip for details if you are interested in using the Auto-EEPROM mode.



# 2.5 Register description

# 2.5.1 Write only registers

| R_ | _CTRL    |                |              | (w)                                                                                                     | (Reset group: H)                                                                                                                                                                                                                                                                                               | 0x01                                                                               |
|----|----------|----------------|--------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| Co | ommon co | ntrol regi     | ster         |                                                                                                         |                                                                                                                                                                                                                                                                                                                |                                                                                    |
|    | Bits     | Reset<br>value | Name         | Descrij                                                                                                 | ption                                                                                                                                                                                                                                                                                                          |                                                                                    |
|    | 0        | 0              | (reserved)   | Must be                                                                                                 | e '0'.                                                                                                                                                                                                                                                                                                         |                                                                                    |
|    | 1        | 0              | V_FIFO_LPRIO | <b>FIFO</b> a<br>'0' = no<br>'1' = low                                                                  | access priority for host accesse<br>rmal priority<br>w priority                                                                                                                                                                                                                                                | 2S                                                                                 |
|    | 2        | 0              | (reserved)   | Must be                                                                                                 | e '0'.                                                                                                                                                                                                                                                                                                         |                                                                                    |
|    | 3        | 0              | V_NT_SYNC    | Synchr<br>The tran<br>can be s<br>'0' = F0<br>'1' = F1<br>(see reg<br>Note: T<br>for the b<br>It is ign | <b>conization source for NT mode</b><br>nsmit data path of the Universal<br>synchronized to different signal<br>I is used as NT synchronizatior<br>_7 is used as NT synchronizatio<br>gister R_SL_SEL7 for time slot<br>This bit selects the synchronizat<br>Universal ISDN Port in NT/LT<br>tored in TE mode. | I ISDN Port<br>s.<br>source<br>on source<br>selection)<br>ion source<br>mode only. |
|    | 4        | 0              | (reserved)   | Must be                                                                                                 | e '0'.                                                                                                                                                                                                                                                                                                         |                                                                                    |
|    | 5        | 0              | V_OSC_OFF    | <b>Disable</b><br>'0' = no<br>'1' = clo<br>This bit<br>or with<br>chip aco<br>frequen                   | e oscillator<br>rmal operation<br>ock oscillator is switched off<br>t is reset at every write access to<br>a wake-up signal on pin WAKE<br>cess is valid not before the oscil<br>icy is stable again.                                                                                                          | ) XHFC-1SU<br>UP. Any<br>llator                                                    |
|    | 76       | 0              | V_SU_CLK     | Line in<br>The line<br>system<br>'00' = $f_{1}$<br>'01' = $f_{2}$<br>'10' = $f_{2}$<br>'11' = $f_{2}$   | terface clock selection<br>e interface clock $f_{SU}$ is derived<br>clock $f_{SYS}$<br>$f_{SYS} / 2$<br>$f_{SYS} / 4$<br>$f_{SYS}$ (normally unused)<br>$f_{SYS} / 8$ (normally unused)<br>st be 12.288 MHz.                                                                                                   | from the                                                                           |



| R_                                  | _RAM_AI    | DDR        |                | (w) | (Reset group: H, 0) | 0x08 |
|-------------------------------------|------------|------------|----------------|-----|---------------------|------|
| A                                   | ddress poi | inter, low | er part        |     |                     |      |
| Lower address byte for SRAM access. |            |            | r SRAM access. |     |                     |      |
|                                     |            | Decet      |                |     |                     |      |
|                                     | Bits       | value      | Name           | Des | cription            |      |
|                                     |            |            |                |     |                     |      |
|                                     | 70         | 0x00       | V_RAM_ADDR0    | Add | lress bits 70       |      |
|                                     |            |            |                |     |                     |      |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)

| R_       | _RAM_CT                                                                             | RL             |             | (w) | (Reset group: H, 0)                                                                                                                            | 0x09       |  |  |
|----------|-------------------------------------------------------------------------------------|----------------|-------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|
| SF<br>Hi | SRAM access control register<br>High address bits and control bits for SRAM access. |                |             |     |                                                                                                                                                |            |  |  |
|          | Bits                                                                                | Reset<br>value | Name        |     | Description                                                                                                                                    |            |  |  |
|          | 30                                                                                  | 0              | V_RAM_ADDR1 |     | Address bits 118                                                                                                                               |            |  |  |
|          | 54                                                                                  | 0              | (reserved)  |     | Must be '00'.                                                                                                                                  |            |  |  |
|          | 6                                                                                   | 0              | V_ADDR_RES  |     | Address reset<br>'0' = normal operation<br>'1' = address bits 011 are set to zero<br>This bit is automatically cleared.                        |            |  |  |
|          | 7                                                                                   | 0              | V_ADDR_INC  |     | Address increment<br>'0' = no address increment<br>'1' = automatically increment of the address a<br>every write or read on register R_RAM_DAT | after<br>A |  |  |



### 2.5.2 Read only registers

| R_                                                                      | _RAM_US | SE             |            | ( <b>r</b> )               | (Reset group: –)                                                             | 0x15 |
|-------------------------------------------------------------------------|---------|----------------|------------|----------------------------|------------------------------------------------------------------------------|------|
| <b>SRAM duty factor</b><br>Usage of SRAM access bandwidth by the interr |         |                |            | l data proc                | essor.                                                                       |      |
|                                                                         | Bits    | Reset<br>value | Name       | Des                        | cription                                                                     |      |
|                                                                         | 70      |                | V_SRAM_USE | <b>Rel</b><br>0x00<br>0x70 | <b>ative duty factor</b><br>0 = 0% bandwidth used<br>C = 100% bandwidth used |      |

| R | _CHIP_IC   | )              |           | ( <b>r</b> ) | (Reset group: H)                                              | 0x16 |
|---|------------|----------------|-----------|--------------|---------------------------------------------------------------|------|
| C | hip identi | fication re    | egister   |              |                                                               |      |
|   | Bits       | Reset<br>value | Name      | I            | Description                                                   |      |
|   | 70         | 0x60           | V_CHIP_ID | (<br>''      | Chip identification code<br>0110 0000' (0x60) means XHFC-1SU. |      |

| R                 | _CHIP_R | v              |            | ( <b>r</b> ) | (Reset group: H) | 0x1F |
|-------------------|---------|----------------|------------|--------------|------------------|------|
| XHFC-1SU revision |         |                |            |              |                  |      |
|                   | Bits    | Reset<br>value | Name       | Desc         | ription          |      |
|                   | 30      | 0              | V_CHIP_RV  | Chip         | revision 0       |      |
|                   | 74      |                | (reserved) |              |                  |      |


| R        | _INT_DA                          | ΓΑ                                 |                           | ( <b>r</b> ) | (Reset group: –) | 0x88 |
|----------|----------------------------------|------------------------------------|---------------------------|--------------|------------------|------|
| In<br>Tł | <b>ternal da</b><br>nis register | <b>ta register</b><br>r can be rea | ad to access data with Re | ad* method.  |                  |      |
|          | Bits                             | Reset<br>value                     | Name                      | Desc         | ription          |      |
|          | 70                               |                                    | V_INT_DATA                | Inter        | nal data buffer  |      |

(See Section 2.2.3.2 on page 45 for details on Read\* access.)



### 2.5.3 Read/write register

| R_              | _RAM_D                 | ATA                      |             | (r*/w)                 | (Reset group: –)                                                                     | 0xC0               |
|-----------------|------------------------|--------------------------|-------------|------------------------|--------------------------------------------------------------------------------------|--------------------|
| <b>SF</b><br>Di | RAM data<br>rect acces | a access<br>s to the int | ternal SRAM |                        |                                                                                      |                    |
|                 | Bits                   | Reset<br>value           | Name        | Descr                  | iption                                                                               |                    |
|                 | 70                     |                          | V_RAM_DATA  | SRAM<br>The ad<br>R_RA | <b>M data access</b><br>ddress must be written into regis<br>M_ADDR and R_RAM_CTRL i | ters<br>n advance. |

(See Section 2.2.3.2 on page 45 for details on Read\* access.)



Chapter 3

# **XHFC-1SU** data flow







## **3.1** Data flow concept

#### 3.1.1 Overview

XHFC-1SU has a programmable data flow unit, in which the FIFOs are connected to the PCM and the  $ST/U_p$  interface. Moreover the data flow unit can directly connect PCM and  $ST/U_p$  interface or two PCM time slots with each other <sup>1</sup>.

The fundamental features of the XHFC-1SU data flow are as follows:

- programmable interconnection capability between FIFOs, PCM time slots and channels of the Universal ISDN Port
- Universal ISDN Port (combined ST/U<sub>p</sub> interface)
- in transmit and receive direction there are
  - up to 16 FIFOs each
  - 12, 32, 64 or 128 PCM time slots each in PCM master mode
  - 1...128 PCM time slots each in PCM slave mode
  - 16 HFC-channels each to connect the above-mentioned data interfaces
- 3 data flow modes to satisfy different application tasks
- subchannel processing for bitwise data handling

The complete XHFC-1SU data flow block diagram is shown in Figure 3.1. Basically, data routing requires an allocation number at each block. So there are three areas where numbering is based on FIFOs, HFC-channels and PCM time slots.

FIFO handling and HDLC controller, PCM and  $ST/U_p$  interface are described in Chapters 4 to 6. So this chapter deals with the data flow unit which is located between and including the HFC-channel assigner, the PCM slot assigner and the line interface assigner.

#### **3.1.2** Term definitions

Figure 3.2 clarifies the relationship and the differences between the numbering of FIFOs, HFCchannels and PCM time slots. The inner circle symbolizes the HFC-channel oriented part of the data flow, while the outer circle shows the connection of three data sources and data drains respectively. The  $ST/U_p$  interface has a fixed mapping between HFC-channels and  $ST/U_p$ -channels so that there is no need of a separate  $ST/U_p$ -channel numbering.

- **FIFO:** The FIFOs are buffers between the microprocessor bus interface and the PCM and  $ST/U_p$  interface. The HDLC controllers are located on the non host bus side of the FIFOs. The number of FIFOs depends on the FIFO size configuration (see Section 4.3) and starts with number 0. The maximum FIFO number is 15. Furthermore data directions transmit and receive are associated with every FIFO number.
- **HFC-channel:** HFC-channels are used to define data paths between FIFOs on the one side and PCM and  $ST/U_p$  interface on the other side. The HFC-channels are numbered 0..15. Furthermore data directions transmit and receive are associated with every HFC-channel number.

<sup>&</sup>lt;sup>1</sup>In this data sheet the shorter expression "slot" instead of "time slot" is also used with the same meaning.





Figure 3.2: Areas of FIFO oriented, HFC-channel oriented and PCM time slot oriented numbering

It is important not to mix up the HFC-channels of the here discussed data flow (inner circle of Figure 3.2) with the  $ST/U_p$ -channels of the  $ST/U_p$  interface.

**PCM time slot:** The PCM data stream is organized in time slots. The number of PCM time slots depends on the data rate, i.e. there are 32 time slots with 2 MBit/s (numbered 0..31), 64 time slots with 4 MBit/s (numbered 0..63) or 128 time slots with 8 MBit/s (numbered 0..127). Every PCM time slot exists both in transmit and receive data directions.

Every FIFO, HFC-channel and PCM time slot number exist for transmit and receive direction. The data rate is always 8 kByte/s for every ST/U<sub>p</sub>-channel and every PCM time slot. FIFOs, HFC-channels, ST/U<sub>p</sub>-channels and PCM time slots have always a width of 8 bit.

## 3.2 Flow controller

#### 3.2.1 Overview

The various connections between FIFOs,  $ST/U_p$ -channels and PCM time slots are set up by programming the flow controller, the HFC-channel assigner and the PCM slot assigner.

The flow controller sets up connections between FIFOs and the  $ST/U_p$  interface, FIFOs and the PCM interface and between the  $ST/U_p$  interface and the PCM interface. Bitmap V\_DATA\_FLOW in register A\_CON\_HDLC (which exists for each FIFO) configures these connections. The numbering of transmit and corresponding receive FIFOs, HFC-channels and PCM time slots is independent from each other. But in practice the connection table is more clear if the same number is chosen for corresponding transmit and receive direction.

A direct connection between two PCM time slots can be set up inside the PCM slot assigner and will be described in Section 3.3.

The flow controller operates on HFC-channel data. Nevertheless it is programmed with a bitmap of



a FIFO-indexed array register. With this concept it is possible to change the FIFO-to-HFC-channel assignment of a ready-configured FIFO without re-programming its parameters again.

The internal structure of the flow controller contains

- 4 switching buffers, i.e. one for the  $ST/U_p$  and PCM interfaces in transmit and receive direction each and
- 3 switches to control the data paths.

#### **3.2.2** Switching buffers

The switching buffers decouple the data inside the flow controller from the data that is transmitted to or received from the  $ST/U_p$  and PCM interfaces. With every 125 µs cycle the switching buffers change their pointers.

If a byte is read from the FIFO and written into a switching buffer, it is transmitted by the connected interface during the *next* 125  $\mu$ s cycle. In the reverse case, a received byte which is stored in a switching buffer is copied to the FIFO during the next 125  $\mu$ s cycle.

A direct PCM-to-ST/ $U_p$  connection delays each data byte two cycles. That means the received byte is stored in the switching buffer during the first 125  $\mu$ s cycle, then copied into the transmit buffer during the second 125  $\mu$ s cycle and finally transmitted from the interface during the third 125  $\mu$ s cycle.

#### **3.2.3** Timed sequence

The data transmission algorithm of the flow controller is FIFO-oriented and handles all FIFOs, and of course all connected HFC-channels, every  $125 \,\mu s$  in the following sequence:

FIFO[0,TX] FIFO[0,RX] FIFO[1,TX] FIFO[1,RX] . . FIFO[*n*,TX] FIFO[*n*,RX]

The number of existing FIFOs, and consequently the value of *n*, depends on the FIFO configuration (see Table 4.2 on page 128). In any case *n* cannot exceed 15. There are other configurations with n = 7 and n = 3.

Due to the FIFO oriented operation, the number of existing FIFOs also defines the number of processed HFC-channels. HFC-channel numbers can be used in the full range 0..15 but with every processed FIFO just one HFC-channel is processed within the same cycle.

If a faulty configuration writes data from several sources into the same switching buffer, the last write access overwrites the previous ones. Only in this case it is necessary to know the process sequence of the flow controller.



XHFC-1SU has three data flow modes. One of them (*FIFO sequence mode*) is used to configure a programmable FIFO sequence which can be used instead of the ascending FIFO numbering. This is explained in Section 3.4.

#### **3.2.4** Transmit operation (FIFO in transmit data direction)

In transmit operation one HDLC or transparent byte is read from a FIFO and can be transmitted to the  $ST/U_p$  and the PCM interface as shown in Figure 3.3. Furthermore, data can be transmitted from the  $ST/U_p$  interface to the PCM interface. From the flow controller point of view, the switches select the source for outgoing data. They are controlled by bitmap V\_DATA\_FLOW[2..1] in register A\_CON\_HDLC[*n*,TX] where *n* is a FIFO number. Transmit operation is configured with V\_FIFO\_DIR = '0' in the multi-register R\_FIFO.



Figure 3.3: The flow controller in transmit operation

- FIFO data is only transmitted to the line interface if  $V\_DATA\_FLOW[1] = '0'$ .
- The PCM interface can transmit a data byte which comes either from the FIFO or from the line interface. Bit V\_DATA\_FLOW[2] selects the source for the PCM transmit slot (see Figure 3.3). The receiving ST / Up-channel has always the same number as the transmitting S/T / Up-channel.
- Bit V\_DATA\_FLOW[0] is ignored in transmit operation.

#### **3.2.5** Receive operation (FIFO in receive data direction)

Figure 3.4 shows the flow controller structure in receive operation. The two switches are controlled by bitmap V\_DATA\_FLOW[1..0] in register A\_CON\_HDLC[n,RX] where n is a FIFO number. Receive operation is configured with V\_FIFO\_DIR = '1' in the multi-register R\_FIFO. FIFO data can either



Figure 3.4: The flow controller in receive FIFO operation

be received from the  $ST/U_p$  or from the PCM interface. Furthermore, data can be transmitted from the PCM interface to the  $ST/U_p$  interface.

- Bit V\_DATA\_FLOW[0] selects the source for the receive FIFO which can either be the PCM or the line interface.
- Furthermore, the received PCM byte can be transferred to the line interface. This requires bit  $V_DATA_FLOW[1] = '1'$ .
- Bit V\_DATA\_FLOW[2] is ignored in receive FIFO operation.

#### **3.2.6** Connection summary

Table 3.1 shows the flow controller connections as a whole. Bidirectional connections  $^2$  are pointed out with a gray box because they are typically used to establish the data transmissions. All rows have an additional connection to a second destination.

The most important connections are bidirectional data transmissions. For these connections it is possible to manage the configuration programming of V\_DATA\_FLOW with only three different values for transmit and receive FIFO operations. Table 3.2 shows the suitable programming values which can be used to simplify the programming algorithm.

<sup>&</sup>lt;sup>2</sup>In fact, all connections are unidirectional. However, in typical applications there is always a pair of transmit and receive data channels which belong together. Instead of "transmit and corresponding receive data connection" the shorter expression "bidirectional connection" is used in this data sheet.



| V_DATA_FLOW    | Trai<br>(V_FIFO_                                                                                                            | nsmit<br>_DIR = '0')                                                                       | Rece<br>(V_FIFO_                                                                                                                   | eive<br>DIR = '1')                                                                                                          |
|----------------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| '000'<br>'001' | $\begin{array}{rcl} \mbox{FIFO} & \rightarrow & \mbox{PCM} \\ \mbox{FIFO} & \rightarrow & \mbox{ST}/\mbox{U}_p \end{array}$ | $\begin{array}{rcl} FIFO & \rightarrow & ST/U_p \\ FIFO & \rightarrow & PCM \end{array}$   | $\begin{array}{rcl} \text{FIFO} & \leftarrow & \text{ST}/\text{U}_{\text{p}} \\ \text{FIFO} & \leftarrow & \text{PCM} \end{array}$ |                                                                                                                             |
| '010'<br>'011' | $FIFO \rightarrow PCM$                                                                                                      | $FIFO \rightarrow PCM$                                                                     | $\begin{array}{rcl} FIFO \ \leftarrow \ ST/U_p \\ FIFO \ \leftarrow \ PCM \end{array}$                                             | $\begin{array}{rcl} ST/U_p & \leftarrow & PCM \\ ST/U_p & \leftarrow & PCM \end{array}$                                     |
| '100'<br>'101' | $\begin{array}{rcl} ST/U_p & \rightarrow & PCM \\ & FIFO & \rightarrow & ST/U_p \end{array}$                                | $\begin{array}{rcl} FIFO & \rightarrow & ST/U_p \\ ST/U_p & \rightarrow & PCM \end{array}$ | $FIFO \leftarrow ST/U_p$<br>$FIFO \leftarrow PCM$                                                                                  |                                                                                                                             |
| '110'<br>'111' |                                                                                                                             | $\begin{array}{rcl} ST/U_p & \rightarrow & PCM \\ ST/U_p & \rightarrow & PCM \end{array}$  | $ST/U_p \leftarrow PCM$<br>$ST/U_p \leftarrow PCM$                                                                                 | $\begin{array}{rcl} \text{FIFO} & \leftarrow & \text{ST}/\text{U}_p\\ \\ \text{FIFO} & \leftarrow & \text{PCM} \end{array}$ |

#### Table 3.1: Flow controller connectivity

| Table 3.2: V_DATA_ | FLOW programming values for bidirectional connections |
|--------------------|-------------------------------------------------------|
|                    |                                                       |

| Connect           | ion           |                   | V_FIFO_DIR | Required<br>V_DATA_FLOW | Recommended<br>V_DATA_FLOW |
|-------------------|---------------|-------------------|------------|-------------------------|----------------------------|
| FIFO              | $\rightarrow$ | ST/U <sub>p</sub> | '0' (TX)   | 'x0x'                   |                            |
| FIFO              | $\leftarrow$  | ST/Up             | '1' (RX)   | 'xx0'                   | ,000,                      |
| FIFO              | $\rightarrow$ | PCM               | '0' (TX)   | '0xx'                   |                            |
| FIFO              | $\leftarrow$  | PCM               | '1' (RX)   | 'xx1'                   | '001'                      |
| ST/U <sub>p</sub> | $\rightarrow$ | PCM               | '0' (TX)   | '1xx'                   |                            |
| ST/U <sub>p</sub> | $\leftarrow$  | PCM               | '1' (RX)   | 'x1x'                   | '110'                      |



## 3.3 Assigners

The data flow block diagram in Figure 3.1 contains three assigners. These functional blocks are used to connect FIFOs,  $ST/U_p$ -channels and PCM time slots to the HFC-channels.

#### **3.3.1** HFC-channel assigner

The HFC-channel assigner interconnects FIFOs and HFC-channels. Its functionality depends on the data flow mode described in Section 3.4.

#### **3.3.2** PCM slot assigner

The PCM slot assigner can connect each PCM time slot to an arbitrary HFC-channel. Therefore, for a selected time slot<sup>3</sup> the connected HFC-channel number and data direction must be written into register A\_SL\_CFG[SLOT] as follows:

| Register | setup: |
|----------|--------|
|----------|--------|

A\_SL\_CFG[SLOT]: V\_CH\_SDIR = <HFC-channel data direction> : V\_CH\_SNUM = <HFC-channel number>

Typically, the data direction of a HFC-channel and its connected PCM time slot is the same.

If two PCM time slots are connected to each other, incoming data on a slot is transferred to the PCM slot assigner and stored in the PCM receive switching buffer of the connected HFC-channel. From there it is read (i.e. same HFC-channel) and transmitted to a transmit PCM time slot.

#### **3.3.3** Line interface assigner

Table 3.3 shows the assignment between HFC-channels and the  $ST/U_p$ -channels . There is no possibility to change this allocation, so there is no register for programming the line interface assigner.

#### **3.3.4** Assigner summary

The three different assigner types of XHFC-1SU are shown in Figure 3.5. Assigner programming is always handled with array registers. This can be a FIFO array register or a PCM slot array register.

- The line interface assigner is not programmable. Every HFC-channel is connected to a specific  $ST/U_p$ -channel like shown in Table 3.3.
- The PCM slot assigner is programmed by register A\_SL\_CFG[SLOT]. The PCM time slot must be selected before by writing the desired slot number and direction into register R\_SLOT.
- The HFC-channel assigner programming depends on the data flow mode which is described in Section 3.4. This section explains in what cases the assigner is programmable and how this can be done. Figure 3.5 gives a hint, that the programming procedure is handled with array register A\_CHANNEL[FIFO]. Please see section 3.4 for details and restrictions.

 $<sup>^{3}</sup>$ A time slot is specified by writing its number and data direction into register R\_SLOT. Then all accesses to the slot array registers belong to this time slot. Please see Chapter 6 for details.



| HFC-channel         | ST/U <sub>p</sub> - | channel   |
|---------------------|---------------------|-----------|
| number<br>direction | channel             | direction |
| [0,TX]              | B1                  | TX        |
| [0,RX]              | B1                  | RX        |
| [1,TX]              | B2                  | TX        |
| [1,RX]              | B2                  | RX        |
| [2,TX]              | D                   | TX        |
| [2,RX]              | D                   | RX        |
| [3,TX]              | BAC/S               | TX        |
| [3,RX]              | Е                   | RX        |

 Table 3.3: Line interface assigner





Figure 3.5: Overview of the assigner programming



## **3.4** Data flow modes

The internal operation of the HFC-channel assigner and the subchannel processor as well depends on the selected data flow mode. Three modes are available and will be described in this section:

- Simple Mode (SM),
- Channel Select Mode (CSM) and
- FIFO Sequence Mode (FSM)

Various array registers are available to configure the data flow. Unused FIFOs and PCM time slots should remain in their reset state.

FIFO array registers are indexed by R\_FIFO in most cases. But there are some exceptions depending on the data flow mode and the target array register. Table 3.4 shows all FIFO array registers and their index registers at the different data flow modes.

#### 3.4.1 Simple Mode (SM)

#### **3.4.1.1** Mode description

In *Simple Mode* (SM) only one-to-one connections are possible. That means one FIFO, one  $ST/U_p$ channel or one PCM time slot can be connected to each other. The number of connections is limited by the number of FIFOs. It is possible to establish as many connections as there are FIFOs<sup>4</sup>. The actual number of FIFOs depends on the FIFO setup (see Section 4.3).

Simple Mode is selected with  $V_DF_MD = '00'$  in register  $R_FIFO_MD$ . All FIFO array registers are indexed by the multi-register  $R_FIFO$  (address 0x0F) in this data flow mode.

The FIFO number is always the same as the HFC-channel number. Thus, the HFC-channel assigner cannot be programmed in *Simple Mode*. In contrast to this, the PCM time slot number can be chosen independently from the HFC-channel number.

Due to the fixed correspondence between FIFO number and HFC-channel, a pair of transmit and receive FIFOs is allocated even if a bidirectional data connection between the PCM interface and the line interface is established without using the FIFO. <u>Nevertheless, in this case the FIFO must be</u> enabled to enable the data transmission.

A direct coupling of two PCM time slots uses a PCM switching buffer and no FIFO has to be enabled. This connection requires a HFC-channel number (resp. the same FIFO number). An arbitrary HFC-channel number can be chosen. If there are less than 16 transmit and receive FIFOs each, it is usefull to choose a HFC-channel number that is greater than the maximum FIFO number. This saves FIFO resources where no data is stored in a FIFO.

<sup>&</sup>lt;sup>4</sup>Except PCM-to-PCM connections which do not need a FIFO resource if the involved HFC-channel number is higher than the maximum FIFO number.

| Context   |
|-----------|
| FIFO data |

86 of 361

|                      | Array | register                |          | Index reg | ister in |           | Index mea   | ning in     |             |
|----------------------|-------|-------------------------|----------|-----------|----------|-----------|-------------|-------------|-------------|
| Context              | name  | address                 | I/O mode | SM        | CSM      | FSM       | SM          | CSM         | FSM         |
| FIFO data counters   | 0x04  | A_Z1[FIFO]              | r        | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
|                      | 0x06  | A_Z2[FIFO]              | r        | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
| FIFO frame counters  | 0x0C  | A_F1[FIFO]              | r        | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
|                      | 0x0D  | A_F2[FIFO]              | r        | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
| FIFO configuration   | 0x0E  | A_INC_RES_FIFO[FIFO]    | W        | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
| FIFO data access     | 0x80  | A_FIFO_DATA[FIFO]       | r/w      | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
|                      | 0x84  | A_FIFO_DATA_NOINC[FIFO] | r/w      | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
| Subchannel processor | 0xF4  | A_CH_MSK[FIFO]          | r*/w     | R_FIFO    | R_FIFO   | R_FIFO    | HFC-channel | HFC-channel | HFC-channel |
| FIFO configuration   | 0xFA  | A_CON_HDLC[FIFO]        | r*/w     | R_FIFO    | R_FIFO   | R_FIFO    | FIFO        | FIFO        | FIFO        |
| Subchannel Processor | 0xFB  | A_SUBCH_CFG[FIFO]       | r*/w     | R_FIFO    | R_FIFO   | R_FSM_IDX | FIFO        | FIFO        | list index  |
| FIFO configuration   | 0xFC  | A_CHANNEL[FIFO]         | r*/w     | R_FIFO    | R_FIFO   | R_FSM_IDX | FIFO        | FIFO        | list index  |
| FIFO configuration   | 0xFD  | A_FIFO_SEQ[FIFO]        | r*/w     | R_FIFO    | R_FIFO   | R_FSM_IDX | FIFO        | FIFO        | list index  |
| FIFO configuration   | 0xFF  | A FIFO CTRLIFIFO]       | r*/w     | R FIFO    | R FIFO   | R FIFO    | FIFO        | FIFO        | FIFO        |

#### **Table 3.4:** Index registers of the FIFO array registers (sorted by address)

ad Please note !

The index of FIFO array registers is always denoted '[FIFO ]' even if the meaning is different from this in particular cases (grey marked fields in Table 3.4).



#### 3.4.1.2 Subchannel processing

If the data stream of a FIFO does not require full 8 kByte/s data rate, the subchannel processor might be used. Unused bits can be masked out and replaced by bits of an arbitrary mask byte which can be specified in A\_CH\_MSK.

For D- and E-channel processing the subchannel functionality must be enabled. Only two bits of a data byte are processed every  $125 \,\mu s$ .

In transparent mode only the non-masked bits of a byte are processed. Masked bits are taken from register A\_CH\_MSK. So the effective FIFO data rate always remains 8 kByte/s whereas the usable data rate depends on the number of non-masked bits.

In HDLC mode the data rate of the FIFO is reduced according to how many bits are not masked out.

Please see Section 3.5 from page 108 for details concerning the subchannel processor.

#### 3.4.1.3 Example for SM

Figure 3.6 shows an example with four bidirectional connections ( $\bigcirc$  FIFO-to-ST/U<sub>p</sub>,  $\oslash$  FIFO-to-PCM,  $\bigcirc$  PCM-to-ST/U<sub>p</sub> and  $\oslash$  PCM-to-PCM). The FIFO box on the left side contains the number and direction information of the used FIFOs. The ST/U<sub>p</sub> and PCM boxes on the right side contain the ST/U<sub>p</sub>-channels and PCM time slot numbers and directions which are used in this example. Black lines illustrate data paths, whereas dotted lines symbolize blocked resources. These are not used for the data transmission, but they are necessary to enable the settings.

#### Please note !

All settings in Figure 3.6 are configured in bidirectional data paths due to typical applications of XHFC-1SU. However, transmit and receive directions are independent from each other and could occur one at a time as well.

The following settings demonstrate the required register values to establish the connections. All involved FIFOs have to be enabled with V\_FIFO\_IRQ  $\neq 0$  in register A\_CON\_HDLC[FIFO].

The subchannel processor is not used in this example. For this reason, registers A\_SUBCH\_CFG and A\_CH\_MSK remain in their reset state.





#### Figure 3.6: SM example



#### **1** FIFO-to-ST/U<sub>p</sub>

As HFC-channel and FIFO numbers are the same in SM, a selected  $ST/U_p$ -channel specifies the corresponding FIFO (and same in inverse, of course). There is no need of programming the HFC-channel assigner.

To set up a FIFO-to-ST/ $U_p$  connection, the desired ST/ $U_p$ -channel has to be chosen and the linked FIFO (see Table 3.3) has to be programmed. Due to the user's requirements, V\_REV can be programmed either to normal or inverted bit order of the FIFO data.

HDLC or transparent mode (V\_HDLC\_TRP) can freely be chosen as well. In addition to the settings shown here, a periodic interrupt (in transparent mode) or a *end of frame* interrupt (in HDLC mode) can be enabled.

| Register setup: |                       | (SM <b>0</b> TX)                                     |
|-----------------|-----------------------|------------------------------------------------------|
| R_FIFO          | : V_FIFO_DIR = $0$    | (transmit FIFO)                                      |
|                 | $: V_FIFO_NUM = 0$    | (FIFO #0)                                            |
|                 | $: V\_REV = 0$        | (normal bit order)                                   |
| A_CON_HDLC[0,T2 | $X]: V\_IFF = 0$      | (0x7E as inter frame fill)                           |
|                 | : V_HDLC_TRP = $0$    | (HDLC mode)                                          |
|                 | : $V_FIFO_IRQ = 7$    | (enable FIFO)                                        |
|                 | : V_DATA_FLOW = '000' | $(FIFO \rightarrow ST/U_p$ , $FIFO \rightarrow PCM)$ |

| Register setup: |               |                  |                            | (SM <b>1</b> RX) |
|-----------------|---------------|------------------|----------------------------|------------------|
| R_FIFO          | : V_FIFO_DIR  | = 1              | (receive FIFO)             |                  |
|                 | : V_FIFO_NUM  | = 0              | (FIFO #0)                  |                  |
|                 | : V_REV       | = 0              | (normal bit order)         |                  |
| A_CON_HDLC[0,RX | ]:V_IFF       | = 0              | (0x7E as inter frame fill) |                  |
|                 | : V_HDLC_TRP  | = 0              | (HDLC mode)                |                  |
|                 | : V_FIFO_IRQ  | = 7              | (enable FIFO)              |                  |
|                 | : V_DATA_FLOW | <i>I</i> = '000' | $(FIFO \gets ST/U_p \ )$   |                  |



#### **2** FIFO-to-PCM

The FIFO-to-PCM connection can use different numbers for the involved HFC-channels and PCM time slots. The desired numbers are linked together in the PCM slot assigner.

As the line interface assigner links the HFC-channels to the ST/ $U_p$ -channels, every used HFCchannel blocks the connected ST/ $U_p$ -channel . In this example a FIFO is chosen, which is not assigned to a line interface channel. Thus there are no resources blocked.

Again, V\_REV and V\_HDLC\_TRP can freely be chosen according to the user's requirements. As in the previous setting, a periodic interrupt in transparent mode or a *end of frame* interrupt in HDLC mode can be enabled.

| Register setup:  |               |           | (SM <b>2</b> TX)                                       |
|------------------|---------------|-----------|--------------------------------------------------------|
| R_FIFO           | : V_FIFO_DIR  | = 0       | (transmit FIFO)                                        |
|                  | : V_FIFO_NUM  | = 15      | (FIFO #15)                                             |
|                  | : V_REV       | = 0       | (normal bit order)                                     |
| A_CON_HDLC[15,TX | ]: V_IFF      | = 0       | (0x7E as inter frame fill)                             |
|                  | : V_HDLC_TRP  | = 0       | (HDLC mode)                                            |
|                  | : V_FIFO_IRQ  | = 7       | (enable FIFO)                                          |
|                  | : V_DATA_FLOW | / = '001' | (FIFO $\rightarrow$ ST / U_p , FIFO $\rightarrow$ PCM) |
| R_SLOT           | : V_SL_DIR    | = 0       | (transmit slot)                                        |
|                  | : V_SL_NUM    | = 23      | (slot #23)                                             |
| A_SL_CFG[23,TX]  | : V_CH_SDIR   | = 0       | (transmit HFC-channel)                                 |
|                  | : V_CH_SNUM   | = 15      | (HFC-channel #15)                                      |
|                  | : V_ROUT      | = '10'    | (data to pin STIO1)                                    |

| Register setup:  |               |                  |                                       | (SM <b>2</b> RX) |
|------------------|---------------|------------------|---------------------------------------|------------------|
| R_FIFO           | : V_FIFO_DIR  | = 1              | (receive FIFO)                        |                  |
|                  | : V_FIFO_NUM  | = 15             | (FIFO #15)                            |                  |
|                  | : V_REV       | = 0              | (normal bit order)                    |                  |
| A_CON_HDLC[15,RX | (]: V_IFF     | = 0              | (0x7E as inter frame fill)            |                  |
|                  | : V_HDLC_TRP  | = 0              | (HDLC mode)                           |                  |
|                  | : V_FIFO_IRQ  | = 7              | (enable FIFO)                         |                  |
|                  | : V_DATA_FLOW | <b>/</b> = '001' | $(\text{FIFO} \leftarrow \text{PCM})$ |                  |
| R_SLOT           | : V_SL_DIR    | = 1              | (receive slot)                        |                  |
|                  | : V_SL_NUM    | = 23             | (slot #23)                            |                  |
| A_SL_CFG[23,RX]  | : V_CH_SDIR   | = 1              | (receive HFC-channel)                 |                  |
|                  | : V_CH_SNUM   | = 15             | (HFC-channel #15)                     |                  |
|                  | : V_ROUT      | = '10'           | (data from pin STIO2)                 |                  |



#### **O** PCM-to-ST/U<sub>p</sub>

A direct PCM-to-ST/U<sub>p</sub> coupling is shown in the third connection set. The array registers of FIFO[1,TX] and FIFO[1,RX] contain the data flow settings, so they must be configured and the FIFOs must be enabled to switch on the data transmission. This is done with V\_FIFO\_IRQ  $\neq 0$  in register A\_CON\_HDLC[FIFO].

In receive direction, data is stored in the connected FIFO. But it is not used and needs not to be read. A FIFO overflow has no effect and can be ignored. Consequently, the V\_HDLC\_TRP setting has no effect to the transferred data between the PCM and the  $ST/U_p$  interface neither in receive nor in transmit direction. A PCM-to- $ST/U_p$  connection operates always in transparent mode.

For a PCM-to-ST/U<sub>p</sub> connection, the data direction changes between the two interfaces. In detail, data is received on a RX line and then transmitted on a TX line to the other interface. Therefore, a TX-RX-exchanger is inserted for this connection. The blocked FIFOs are on the PCM side of the TX-RX-exchanger. Like shown in the register setting below, data direction of FIFO, ST/U<sub>p</sub> and PCM lines are never mixed up when programming the assigners in *Simple Mode*.

| Register setup: |               |         |                              | (SM <b>3</b> TX) |
|-----------------|---------------|---------|------------------------------|------------------|
| R_FIFO          | : V_FIFO_DIR  | = 0     | (transmit FIFO)              |                  |
|                 | : V_FIFO_NUM  | = 1     | (FIFO #1)                    |                  |
|                 | : V_REV       | = 0     | (normal bit order)           |                  |
| A_CON_HDLC[1,TX | ]: V_IFF      | = 0     | (0x7E as inter frame fill)   |                  |
|                 | : V_HDLC_TRP  | = 1     | (transparent mode)           |                  |
|                 | : V_FIFO_IRQ  | = 7     | (enable data transmission)   |                  |
|                 | : V_DATA_FLOW | = '110' | $(ST/U_p \ \rightarrow PCM)$ |                  |
| R_SLOT          | : V_SL_DIR    | = 0     | (transmit slot)              |                  |
|                 | : V_SL_NUM    | = 22    | (slot #22)                   |                  |
| A_SL_CFG[22,TX] | : V_CH_SDIR   | = 0     | (transmit HFC-channel)       |                  |
|                 | : V_CH_SNUM   | = 1     | (HFC-channel #1)             |                  |
|                 | : V_ROUT      | = '10'  | (data to pin STIO1)          |                  |

| Register setup: |               |                  | (SM 🕄 RX)                                         |
|-----------------|---------------|------------------|---------------------------------------------------|
| R_FIFO          | : V_FIFO_DIR  | = 1              | (receive FIFO)                                    |
|                 | : V_FIFO_NUM  | = 1              | (FIFO #1)                                         |
|                 | : V_REV       | = 0              | (normal bit order)                                |
| A_CON_HDLC[1,RX | []: V_IFF     | = 0              | (0x7E as inter frame fill)                        |
|                 | : V_HDLC_TRP  | = 1              | (transparent mode)                                |
|                 | : V_FIFO_IRQ  | = 7              | (enable data transmission)                        |
|                 | : V_DATA_FLOW | <i>I</i> = '110' | $(FIFO \leftarrow ST/U_p, ST/U_p \leftarrow PCM)$ |
| R_SLOT          | : V_SL_DIR    | = 1              | (receive slot)                                    |
|                 | : V_SL_NUM    | = 22             | (slot #22)                                        |
| A_SL_CFG[22,RX] | : V_CH_SDIR   | = 1              | (receive HFC-channel)                             |
|                 | : V_CH_SNUM   | = 1              | (HFC-channel #1)                                  |
|                 | : V_ROUT      | = '10'           | (data from pin STIO2)                             |



#### **4** PCM-to-PCM

A PCM-to-PCM configuration does not occupy any FIFO resources. An example is shown in the last connection set. HFC-channel[14,RX] is used to connect PCM slot[4,RX] to PCM slot[5,TX]. Data from PCM slot[5,RX] to PCM slot[4,TX] is transferred through HFC-channel[14,TX].

A HFC-channel loop is easily established by linking two PCM time slots to the same HFC-channel. It is a good choice to select a HFC-channel which is not assigned to a  $ST/U_p$ -channel to avoid waste of resources.

| Register setup:                        | (SM <b>4</b> no. 1)   |
|----------------------------------------|-----------------------|
| $R\_SLOT : V\_SL\_DIR = 1$             | (receice slot)        |
| : $V\_SL\_NUM = 4$                     | (slot #4)             |
| $A\_SL\_CFG[4,RX]: V\_CH\_SDIR = 1$    | (receive HFC-channel) |
| : $V\_CH\_SNUM = 14$                   | (HFC-channel #14)     |
| : V_ROUT = '11'                        | (data from pin STIO1) |
| $R\_SLOT : V\_SL\_DIR = 0$             | (transmit slot)       |
| $: V_SL_NUM = 5$                       | (slot #5)             |
| $A\_SL\_CFG[5,TX]$ : $V\_CH\_SDIR = 1$ | (receive HFC-channel) |
| : $V\_CH\_SNUM = 14$                   | (HFC-channel #14)     |
| : V_ROUT = '11'                        | (data to pin STIO2)   |

| Register setup:                      | (SM <b>4</b> no. 2)    |
|--------------------------------------|------------------------|
| $R\_SLOT : V\_SL\_DIR = 1$           | (receice slot)         |
| $: V\_SL\_NUM = 5$                   | (slot #5)              |
| $A_SL_CFG[5,RX]: V_CH_SDIR = 0$      | (transmit HFC-channel) |
| : $V\_CH\_SNUM = 14$                 | (HFC-channel #14)      |
| : V_ROUT = '10'                      | (data from pin STIO2)  |
| $R\_SLOT : V\_SL\_DIR = 0$           | (transmit slot)        |
| : $V\_SL\_NUM = 4$                   | (slot #4)              |
| $A\_SL\_CFG[4,TX] : V\_CH\_SDIR = 0$ | (transmit HFC-channel) |
| : $V\_CH\_SNUM = 14$                 | (HFC-channel #14)      |
| : V_ROUT = '10'                      | (data to pin STIO1)    |

## **Rule**

In *Simple Mode* for every used FIFO[*n*] the HFC-channel[*n*] is also used. This is valid in reverse case, too, except for PCM-to-PCM configurations.



#### **3.4.2** Channel Select Mode (CSM)

#### 3.4.2.1 Mode description

The *Channel Select Mode* (CSM) allows an arbitrary assignment between a FIFO and the connected HFC-channel as shown in Figure 3.7 (left side). Beyond this, it is possible to connect several FIFOs to one HFC-channel (Fig. 3.7, right side). This works in transmit and receive direction and can be used to connect one 8 kByte/s ST/U<sub>p</sub>-channel or PCM time slot to multiple FIFO data streams, with lower data rate each. In this case the subchannel processor must be used.



Figure 3.7: HFC-channel assigner in CSM

*Channel Select Mode* is selected with  $V_DF_MD = '01'$  in register  $R_FIFO_MD$ . All FIFO array registers are indexed by the multi-register  $R_FIFO$  (address 0x0F) in this data flow mode.

#### 3.4.2.2 HFC-channel assigner

The connection between a FIFO and a HFC-channel can be established by register A\_CHANNEL which exists for every FIFO. For a selected FIFO, the HFC-channel to be connected must be written into V\_CH\_FNUM of register A\_CHANNEL. Typically, the data direction in V\_CH\_FDIR is the same as the FIFO data direction V\_FIFO\_DIR in the multi-register R\_FIFO. With the following register settings the HFC-channel assigner connects the selected FIFO to HFC-channel *n*.

A direct connection between a PCM time slot and an  $ST/U_p$ -channel allocates one FIFO although this FIFO does not store any data. In *Channel Select Mode* – in contrast to *Simple Mode* – an arbitrary FIFO can be chosen. This FIFO must be enabled to switch on the data transmission.

#### 3.4.2.3 Subchannel Processing

If more than one FIFO is connected to one HFC-channel, this HFC-channel number must be written into the V\_CH\_FNUM bitmap of all these FIFOs. In this case every FIFO contributes one or more bits to construct one HFC-channel byte. Unused bits of a HFC-channel byte can be set with an arbitrary mask byte in register A\_SUBCH\_CFG.

In transparent mode the FIFO data rate always remains 8 kByte/s. In HDLC mode the FIFO data rate is determined by the number of bits transmitted to the HFC-channel.



Please see Section 3.5 on page 108 for details concerning the subchannel processor.

#### 3.4.2.4 Example for CSM

The example for a *Channel Select Mode* configuration in Figure 3.8 shows three bidirectional connections (**1** FIFO-to-ST/U<sub>p</sub>, **2** FIFO-to-PCM and **3** PCM-to-ST/U<sub>p</sub>). The black lines illustrate data paths, whereas the dotted lines symbolize blocked resources. These are not used for data transmission, but they are necessary to enable the settings.



Figure 3.8: CSM example

The following settings demonstrate the required register values to establish the connections. All involved FIFOs have to be enabled with V\_FIFO\_IRQ  $\neq 0$  in register A\_CON\_HDLC[FIFO].

The subchannel processor is not used in this example. For this reason, registers A\_SUBCH\_CFG and A\_CH\_MSK remain in their reset state.



#### **0** FIFO-to-ST/U<sub>p</sub>

HFC-channel and FIFO numbers can be chosen independently from each other. This is shown in the FIFO-to-ST/ $U_p$  connection.

Due to the user's requirements,  $V\_REV$  can be programmed either to normal or inverted bit order of the FIFO data.

HDLC or transparent mode (V\_HDLC\_TRP) can freely be chosen as well. In addition to the settings shown here, a periodic interrupt (in transparent mode) or a *end of frame* interrupt (in HDLC mode) can be enabled.

| Register setup:      |            |           | (CSM <b>1</b> TX)                                        |
|----------------------|------------|-----------|----------------------------------------------------------|
| R_FIFO : V_          | _FIFO_DIR  | = 0       | (transmit FIFO)                                          |
| : V_                 | _FIFO_NUM  | = 4       | (FIFO #4)                                                |
| : V_                 | _REV       | = 0       | (normal bit order)                                       |
| A_CON_HDLC[4,TX]: V_ | _IFF       | = 0       | (0x7E as inter frame fill)                               |
| : V_                 | _HDLC_TRP  | = 0       | (HDLC mode)                                              |
| : V_                 | _FIFO_IRQ  | = 7       | (enable FIFO)                                            |
| : V_                 | _DATA_FLOW | i '000' = | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM) |
| A_CHANNEL[4,TX] : V_ | _CH_FDIR   | = 0       | (transmit HFC-channel)                                   |
| : V_                 | _CH_FNUM   | = 0       | (HFC-channel #0)                                         |

| Register setup:             |           |                               | (CSM <b>1</b> RX) |
|-----------------------------|-----------|-------------------------------|-------------------|
| R_FIFO : V_FIFO_DIR         | = 1       | (receive FIFO)                |                   |
| : V_FIFO_NUM                | = 4       | (FIFO #4)                     |                   |
| : V_REV                     | = 0       | (normal bit order)            |                   |
| A_CON_HDLC[4,RX]: V_IFF     | = 0       | (0x7E as inter frame fill)    |                   |
| : V_HDLC_TRP                | = 0       | (HDLC mode)                   |                   |
| : V_FIFO_IRQ                | = 7       | (enable FIFO)                 |                   |
| : V_DATA_FLOV               | V = '000' | $(FIFO \leftarrow ST/U_p \ )$ |                   |
| A_CHANNEL[4,RX] : V_CH_FDIR | = 1       | (receive HFC-channel)         |                   |
| : V_CH_FNUM                 | = 0       | (HFC-channel #0)              |                   |



#### **2** FIFO-to-PCM

The FIFO-to-PCM connection blocks one transmit and one receive  $ST/U_p$ -channel .

In this example, the selected HFC-channel is not assigned to a line interface channel. So there are no resources blocked.

Again, V\_REV and V\_HDLC\_TRP can freely be chosen according to the user's requirements. As in the previous setting, HDLC mode is selected and the FIFOs are enabled with V\_FIFO\_IRQ = 1.

| Register setup:   |               |           | (CSM <b>2</b> TX)                                        |
|-------------------|---------------|-----------|----------------------------------------------------------|
| R_FIFO            | : V_FIFO_DIR  | = 0       | (transmit FIFO)                                          |
|                   | : V_FIFO_NUM  | = 13      | (FIFO #13)                                               |
|                   | : V_REV       | = 0       | (normal bit order)                                       |
| A_CON_HDLC[13,TX] | : V_IFF       | = 0       | (0x7E as inter frame fill)                               |
|                   | : V_HDLC_TRP  | = 0       | (HDLC mode)                                              |
|                   | : V_FIFO_IRQ  | = 7       | (enable FIFO)                                            |
|                   | : V_DATA_FLOW | / = '001' | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM) |
| A_CHANNEL[13,TX]  | : V_CH_FDIR   | = 0       | (transmit HFC-channel)                                   |
|                   | : V_CH_FNUM   | = 15      | (HFC-channel #15)                                        |
| R_SLOT            | : V_SL_DIR    | = 0       | (transmit slot)                                          |
|                   | : V_SL_NUM    | = 17      | (slot #17)                                               |
| A_SL_CFG[17,TX]   | : V_CH_SDIR   | = 0       | (transmit HFC-channel)                                   |
|                   | : V_CH_SNUM   | = 15      | (HFC-channel #15)                                        |
|                   | : V_ROUT      | = '10'    | (data to pin STIO1)                                      |

| Register setup:   |               |         |                            | (CSM <b>2</b> RX) |
|-------------------|---------------|---------|----------------------------|-------------------|
| R_FIFO            | : V_FIFO_DIR  | = 1     | (receive FIFO)             |                   |
|                   | : V_FIFO_NUM  | = 13    | (FIFO #13)                 |                   |
|                   | : V_REV       | = 0     | (normal bit order)         |                   |
| A_CON_HDLC[13,RX] | ]: V_IFF      | = 0     | (0x7E as inter frame fill) |                   |
|                   | : V_HDLC_TRP  | = 0     | (HDLC mode)                |                   |
|                   | : V_FIFO_IRQ  | = 7     | (enable FIFO)              |                   |
|                   | : V_DATA_FLOW | = '001' | $(FIFO \leftarrow PCM)$    |                   |
| A_CHANNEL[13,RX]  | : V_CH_FDIR   | = 1     | (receive HFC-channel)      |                   |
|                   | : V_CH_FNUM   | = 15    | (HFC-channel #15)          |                   |
| R_SLOT            | : V_SL_DIR    | = 1     | (receive slot)             |                   |
|                   | : V_SL_NUM    | = 17    | (slot #17)                 |                   |
| A_SL_CFG[17,RX]   | : V_CH_SDIR   | = 1     | (receive HFC-channel)      |                   |
|                   | : V_CH_SNUM   | = 15    | (HFC-channel #15)          |                   |
|                   | : V_ROUT      | = '10'  | (data from pin STIO2)      |                   |

#### **\Theta** PCM-to-ST/U<sub>p</sub>

The PCM-to-ST/ $U_p$  connection blocks one transmit and one receive FIFO. Although these FIFOs are not used, they must be enabled to switch on the data transmission between the PCM and the ST/ $U_p$  interface.



In receive direction, data is stored in the connected FIFO. But it is not used and needs not to be read. A FIFO overflow has no effect and can be ignored. Consequently, the V\_HDLC\_TRP setting has no effect to the transferred data between the PCM and the ST/U<sub>p</sub> interface neither in receive nor in transmit direction. A PCM-to-ST/U<sub>p</sub> connection operates always in transparent mode.

For a PCM-to-ST/ $U_p$  connection, the data direction changes between the two interfaces. In detail, data is received on a RX line and then transmitted on a TX line to the other interface. Therefore, a TX-RX-exchanger is inserted for this connection. The blocked FIFOs are on the PCM side of the TX-RX-exchanger, typically.<sup>5</sup>

| Register setup: |               |           |                            | (CSM 3 TX) |
|-----------------|---------------|-----------|----------------------------|------------|
| R_FIFO          | : V_FIFO_DIR  | = 0       | (transmit FIFO)            |            |
|                 | : V_FIFO_NUM  | = 5       | (FIFO #5)                  |            |
|                 | : V_REV       | = 0       | (normal bit order)         |            |
| A_CON_HDLC[5,TX | ]: V_IFF      | = 0       | (0x7E as inter frame fill) |            |
|                 | : V_HDLC_TRP  | = 1       | (transparent mode)         |            |
|                 | : V_FIFO_IRQ  | = 7       | (enable data transmission) |            |
|                 | : V_DATA_FLOW | / = '110' | $(ST/U_p \rightarrow PCM)$ |            |
| A_CHANNEL[5,TX] | : V_CH_FDIR   | = 0       | (transmit HFC-channel)     |            |
|                 | : V_CH_FNUM   | = 1       | (HFC-channel #1)           |            |
| R_SLOT          | : V_SL_DIR    | = 0       | (transmit slot)            |            |
|                 | : V_SL_NUM    | = 7       | (slot #7)                  |            |
| A_SL_CFG[7,TX]  | : V_CH_SDIR   | = 0       | (transmit HFC-channel)     |            |
|                 | : V_CH_SNUM   | = 1       | (HFC-channel #1)           |            |
|                 | : V_ROUT      | = '10'    | (data to pin STIO1)        |            |

| Register setup:  |               |         | (CSM <sup>®</sup> RX)                                    |
|------------------|---------------|---------|----------------------------------------------------------|
| R_FIFO           | : V_FIFO_DIR  | = 1     | (receive FIFO)                                           |
|                  | : V_FIFO_NUM  | = 5     | (FIFO #5)                                                |
|                  | : V_REV       | = 0     | (normal bit order)                                       |
| A_CON_HDLC[5,RX] | : V_IFF       | = 0     | (0x7E as inter frame fill)                               |
|                  | : V_HDLC_TRP  | = 1     | (transparent mode)                                       |
|                  | : V_FIFO_IRQ  | = 7     | (enable data transmission)                               |
|                  | : V_DATA_FLOW | = '110' | $(FIFO \leftarrow ST/U_p \ , \ ST/U_p \ \leftarrow PCM)$ |
| A_CHANNEL[5,RX]  | : V_CH_FDIR   | = 1     | (receive HFC-channel)                                    |
|                  | : V_CH_FNUM   | = 1     | (HFC-channel #1)                                         |
| R_SLOT           | : V_SL_DIR    | = 1     | (receive slot)                                           |
|                  | : V_SL_NUM    | = 7     | (slot #7)                                                |
| A_SL_CFG[7,RX]   | : V_CH_SDIR   | = 1     | (receive HFC-channel)                                    |
|                  | : V_CH_SNUM   | = 1     | (HFC-channel #1)                                         |
|                  | : V_ROUT      | = '10'  | (data from pin STIO2)                                    |

<sup>&</sup>lt;sup>5</sup>It is not forbidden to connect the blocked FIFOs at the  $ST/U_p$  side of the TX-RX-exchanger. 'Advanced users' might find configurations where this is useful. But all typical configuration settings do not require this exceptional option.



## Rule

In Channel Select Mode

- Every used HFC-channel requires at least one enabled FIFO (except for the PCM-to-PCM connection) with the same data direction.
- Every used PCM time slot requires one HFC-channel (except for the PCM-to-PCM connection where a full duplex connection with four time slots allocates only two HFC-channels).



#### **3.4.3** FIFO Sequence Mode (FSM)

#### **3.4.3.1** Mode description

In contrast to the PCM and  $ST/U_p$ -channels, the FIFO data rate is not fixed to 8 kByte/s in *FIFO Sequence Mode*. In the previous section the CSM allows the functional capability of a FIFO data rate with less than 8 kByte/s. This section shows how to use FIFOs with a data rate which is higher than 8 kByte/s. In transmit direction one FIFO can cyclically distribute its data to several HFC-channels. In opposite direction, received data from several HFC-channels can be collected cyclically in one FIFO (see Fig. 3.9, right side). A one-to-one connection between FIFO and HFC-channel is also possible in FSM, of course (Fig. 3.9, left side).



Figure 3.9: HFC-channel assigner in FSM

*FIFO Sequence Mode* is selected with  $V_DF_MD = '11'$  in register  $R_FIFO_MD$ . This data flow mode selects the multi-register  $R_FSM_IDX$  at the address 0x0F for some FIFO array registers (see Table 3.4 on page 86).

#### 3.4.3.2 FIFO sequence

To achieve a FIFO data rate higher than 8 kByte/s, a FIFO must be connected to more than one HFCchannel. As there is only one register A\_CHANNEL[FIFO] for each FIFO, the FSM programming method must differ from the previous modes. Some array registers which are indexed by R\_FIFO must be indexed by R\_FSM\_IDX in *FIFO Sequence Mode* (see Table 3.4).

In FSM all FIFOs are organized in a list with up to 32 entries. Every list entry is assigned to a FIFO. The FIFO configuration can be set up as usual, i.e. HFC-channel allocation, flow controller programming and subchannel processing can be configured as described in the previous sections. Additionally, each list entry specifies the next FIFO of the sequence. The list is terminated by an 'end of list' entry. This procedure is shown in Figure 3.10 with j + 1 list entries. The first FIFO of the sequence must be specified in register R\_FIRST\_FIFO.

A quite simple FSM configuration with every FIFO and every HFC-channel specified only one time in the list, would have the same data transmission result as the CSM with an equivalent FIFO  $\longleftrightarrow$  HFC-channel setup. But if a specific FIFO is selected *n* times in the list and connected to *n* different HFC-channels, the FIFO data rate is  $n \cdot 8$ kByte/s.

The complete list is processed every  $125 \,\mu s$  with ascending list index beginning with 0. Suppose the transmit FIFO *m* occurs several times in the list. Then the first FIFO byte is transferred to the first connected HFC-channel, the second byte of FIFO *m* to the second connected HFC-channel and so on. This is similar in receive data direction. The first byte written into FIFO *m* comes from the first connected HFC-channel, the second byte from the second connected HFC-channel and so on.





Figure 3.10: FSM list processing



#### 3.4.3.3 FSM programming

Register R\_FSM\_IDX specifies the list index with bitmap V\_IDX in the range of 0..31. R\_FSM\_IDX is a multi-register and has the same address as R\_FIFO because in FSM it replaces R\_FIFO for the list programming of the HFC-channel based registers. The array registers A\_CHANNEL, A\_FIFO\_SEQ and A\_SUBCH\_CFG are indexed with the list index V\_IDX instead of the FIFO number (see Table 3.4 on page 86). All other FIFO array registers remain indexed by R\_FIFO.



Figure 3.11: FSM list programming

The first processed FIFO has to be specified in register R\_FIRST\_FIFO with the direction bit V\_FIRST\_FIFO\_DIR and the FIFO number V\_FIRST\_FIFO\_NUM. The next FIFO has to be specified in register A\_FIFO\_SEQ[V\_IDX = 0].

A FIFO handles more than one HFC-channel if a FIFO is specified several times in the 'next FIFO' entries.

The FIFO sequence list terminates with  $V\_SEQ\_END = '1'$  in register  $A\_FIFO\_SEQ$ . The other list entries must specify  $V\_SEQ\_END = '0'$  to continue the sequence processing with the next entry.

Programming of the HFC-channel and FIFO registers is shown in Figure 3.11. The connected HFCchannel array registers are indexed by the list index which is written into register R\_FSM\_IDX. On the other hand, FIFO array registers are indexed by register R\_FIFO as usual.

- After writing the list index *i* into register R\_FSM\_IDX, the registers A\_CHANNEL[*i*] and A\_SUBCH\_CFG[*i*] can be programmed to assign and configure an HFC-channel.
- The next FIFO in the sequence must be specified in register A\_FIFO\_SEQ[*i*].
- Supposed, that the previous list entry i-1 has specified A\_FIFO\_SEQ[i-1] = FIFO x, then the corresponding FIFO array registers have to be programmed by first setting R\_FIFO = x. Afterwards, registers A\_CON\_HDLC[x], A\_FIFO\_CTRL[x] and A\_CH\_MSK can be programmed



in the usual way. Please note, that register A\_CH\_MSK requires the addressed HFC-channel to be specified in register R\_FIFO (see remark on page 109).

#### 3.4.3.4 Example for FSM

Figure 3.12 shows an example with three bidirectional connections (① 8 kByte/s-FIFO-to-ST/U<sub>p</sub>, ② 8 kByte/s-FIFO-to-PCM and ③ 16 kByte/s-FIFO-to-ST/U<sub>p</sub>). The black lines illustrate data paths, whereas the dotted lines symbolize blocked HFC-channels. These are not used for data transmission, but they are necessary to enable the settings.



Figure 3.12: FSM example

The following settings demonstrate the required register values to establish the connections. All involved FIFOs have to be enabled with V\_FIFO\_IRQ  $\neq 0$  in register A\_CON\_HDLC[FIFO].

The subchannel processor is not used in this example. For this reason, registers A\_SUBCH\_CFG and A\_CH\_MSK remain in their reset state.

All FIFOs can be arranged in arbitrary order. In the example the list specification of Table 3.5 is chosen. To select FIFO[12,TX] beeing the first FIFO, R\_FIRST\_FIFO is set as follows:



| Register setup:                        |                 |
|----------------------------------------|-----------------|
| $R_FIRST_FIFO: V_FIRST_FIFO_DIR = '0'$ | (transmit FIFO) |
| : $V\_FIRST\_FIFO\_NUM = 12$           | (FIFO #12)      |

**Table 3.5:** List specification of the example in Figure 3.12

| Example |            |             |               |                                  |
|---------|------------|-------------|---------------|----------------------------------|
| number  | List index |             | Con           | nection                          |
| 0       | 0          | FIFO[12,TX] | $\rightarrow$ | ST/U <sub>p</sub> interf., D TX  |
| 0       | 1          | FIFO[12,RX] | $\leftarrow$  | ST/U <sub>p</sub> interf., D RX  |
| 0       | 2          | FIFO[13,RX] | $\leftarrow$  | PCM time slot[21,RX]             |
| 0       | 3          | FIFO[13,TX] | $\rightarrow$ | PCM time slot[21,TX]             |
| 0       | 4          | FIFO[14,TX] | $\rightarrow$ | ST/U <sub>p</sub> interf., B1 TX |
| 6       | 5          | FIFO[14,RX] | $\leftarrow$  | ST/U <sub>p</sub> interf., B1 RX |
| 6       | 6          | FIFO[14,TX] | $\rightarrow$ | ST/U <sub>p</sub> interf., B2 TX |
| 3       | 7          | FIFO[14,RX] | $\leftarrow$  | ST/U <sub>p</sub> interf., B2 RX |



#### **0** FIFO-to-ST/U<sub>p</sub>

The bidirectional FIFO-to-ST/ $U_p$  connection use the list indices 0 and 1. Registers A\_CHANNEL and A\_FIFO\_SEQ are indexed by the list index.

| Register setup:                 |      | (FSM <b>1</b> list indices 0 and 1)   |
|---------------------------------|------|---------------------------------------|
| R_FSM_IDX : V_IDX               | = 0  | (List index #0, used for FIFO[12,TX]) |
| A_CHANNEL[#0] : V_CH_FDIR       | = 0  | (transmit HFC-channel)                |
| : V_CH_FNUM                     | = 2  | (HFC-channel #2)                      |
| A_FIFO_SEQ[#0]: V_NEXT_FIFO_DIR | = 1  | (next: receive FIFO)                  |
| : V_NEXT_FIFO_NUM               | = 12 | (next: FIFO #12)                      |
| : V_SEQ_END                     | = 0  | (continue)                            |
| R_FSM_IDX : V_IDX               | = 1  | (List index #1, used for FIFO[12,RX]) |
| A_CHANNEL[#1] : V_CH_FDIR       | = 1  | (receive HFC-channel)                 |
| : V_CH_FNUM                     | = 2  | (HFC-channel #2)                      |
| A_FIFO_SEQ[#1]: V_NEXT_FIFO_DIR | = 1  | (next: receive FIFO)                  |
| : V_NEXT_FIFO_NUM               | = 13 | (next: FIFO #13)                      |
| : V_SEQ_END                     | = 0  | (continue)                            |

The FIFO programming sequence is indexed by the FIFO number and direction. V\_REV, V\_HDLC\_TRP and V\_FIFO\_IRQ can be programmed due to the user's requirements. FIFO[12,TX] and FIFO[12,RX] must both be enabled.

| Register setup:  |               |         | (FSM <b>1</b> FIFO programming for list indices 0 and 1) |
|------------------|---------------|---------|----------------------------------------------------------|
| R_FIFO           | : V_FIFO_DIR  | = 0     | (transmit FIFO)                                          |
|                  | : V_FIFO_NUM  | = 12    | (FIFO #12)                                               |
|                  | : V_REV       | = 0     | (normal bit order)                                       |
| A_CON_HDLC[12,T] | X]: V_IFF     | = 0     | (0x7E as inter frame fill)                               |
|                  | : V_HDLC_TRP  | = 0     | (HDLC mode)                                              |
|                  | : V_FIFO_IRQ  | = 7     | (enable FIFO)                                            |
| _                | : V_DATA_FLOW | = '000' | (FIFO $\rightarrow$ ST/U $_p$ , FIFO $\rightarrow$ PCM)  |
| R_FIFO           | : V_FIFO_DIR  | = 1     | (receive FIFO)                                           |
|                  | : V_FIFO_NUM  | = 12    | (FIFO #12)                                               |
|                  | : V_REV       | = 0     | (normal bit order)                                       |
| A_CON_HDLC[12,R] | X]: V_IFF     | = 0     | (0x7E as inter frame fill)                               |
|                  | : V_HDLC_TRP  | = 0     | (HDLC mode)                                              |
|                  | : V_FIFO_IRQ  | = 7     | (enable FIFO)                                            |
|                  | : V_DATA_FLOW | = '000' | $(FIFO \leftarrow ST/U_p)$                               |

#### **2** FIFO-to-PCM

The following two list entries (indices 2 and 3) define the bidirectional FIFO-to-PCM connection.

Using two HFC-channels which are not assigned to line interface channels does not block any resources.



| Register setup:                  |      | (FSM <b>2</b> list indices 2 and 3)   |
|----------------------------------|------|---------------------------------------|
| R_FSM_IDX : V_IDX                | = 2  | (List index #2, used for FIFO[13,RX]) |
| A_CHANNEL[#2] : V_CH_FDIR        | = 1  | (receive HFC-channel)                 |
| : V_CH_FNUM                      | = 11 | (HFC-channel #11)                     |
| A_FIFO_SEQ[#2] : V_NEXT_FIFO_DIR | = 0  | (next: transmit FIFO)                 |
| : V_NEXT_FIFO_NUM                | = 13 | (next: FIFO #13)                      |
| : V_SEQ_END                      | = 0  | (continue)                            |
| R_FSM_IDX : V_IDX                | = 3  | (List index #3, used for FIFO[13,TX]) |
| A_CHANNEL[#3] : V_CH_FDIR        | = 0  | (transmit HFC-channel)                |
| : V_CH_FNUM                      | = 11 | (HFC-channel #11)                     |
| A_FIFO_SEQ[#3]: V_NEXT_FIFO_DIR  | = 0  | (next: transmit FIFO)                 |
| : V_NEXT_FIFO_NUM                | = 14 | (next: FIFO #14)                      |
| : V_SEQ_END                      | = 0  | (continue)                            |

| Register setup:   |               | (FSM <b>2</b> | RX FIFO programming for list indices 2 and 3) |
|-------------------|---------------|---------------|-----------------------------------------------|
| R_FIFO            | : V_FIFO_DIR  | = 1           | (receive FIFO)                                |
|                   | : V_FIFO_NUM  | = 13          | (FIFO #13)                                    |
|                   | : V_REV       | = 0           | (normal bit order)                            |
| A_CON_HDLC[13,RX] | : V_IFF       | = 0           | (0x7E as inter frame fill)                    |
|                   | : V_HDLC_TRP  | = 0           | (HDLC mode)                                   |
|                   | : V_FIFO_IRQ  | = 7           | (enable FIFO)                                 |
|                   | : V_DATA_FLOW | = '001'       | $(\text{FIFO} \leftarrow \text{PCM})$         |
| R_SLOT            | : V_SL_DIR    | = 1           | (receive slot)                                |
|                   | : V_SL_NUM    | = 21          | (slot #21)                                    |
| A_SL_CFG[21,RX]   | : V_CH_SDIR   | = 1           | (receive HFC-channel)                         |
|                   | : V_CH_SNUM   | = 11          | (HFC-channel #11)                             |
|                   | : V_ROUT      | = '10'        | (data from pin STIO2)                         |

| Register setup:  |               | (FSM      | <b>2</b> TX FIFO programming for list indices 2 and 3)   |
|------------------|---------------|-----------|----------------------------------------------------------|
| R_FIFO           | : V_FIFO_DIR  | = 0       | (transmit FIFO)                                          |
|                  | : V_FIFO_NUM  | = 13      | (FIFO #13)                                               |
|                  | : V_REV       | = 0       | (normal bit order)                                       |
| A_CON_HDLC[13,TX | []: V_IFF     | = 0       | (0x7E as inter frame fill)                               |
|                  | : V_HDLC_TRP  | = 0       | (HDLC mode)                                              |
|                  | : V_FIFO_IRQ  | = 7       | (enable FIFO)                                            |
|                  | : V_DATA_FLOW | / = '001' | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM) |
| R_SLOT           | : V_SL_DIR    | = 0       | (transmit slot)                                          |
|                  | : V_SL_NUM    | = 21      | (slot #21)                                               |
| A_SL_CFG[21,TX]  | : V_CH_SDIR   | = 0       | (transmit HFC-channel)                                   |
|                  | : V_CH_SNUM   | = 11      | (HFC-channel #11)                                        |
|                  | : V_ROUT      | = '10'    | (data to pin STIO1)                                      |



#### **③** FIFO to multiple ST/U<sub>p</sub>-channels

The last setting shows a channel bundling configuration of one FIFO to two B-channels of the  $ST/U_p$  interface for both transmit and receive directions. The FIFOs have a data rate of  $16 \, kByte/s$  each.

| Register setup:                       | (FSM <b>3</b> list indices 4 and 5)   |
|---------------------------------------|---------------------------------------|
| $R\_FSM\_IDX : V\_IDX = 4$            | (List index #4, used for FIFO[14,TX]) |
| $A\_CHANNEL[#4] : V\_CH\_FDIR = 0$    | (transmit HFC-channel)                |
| : $V\_CH\_FNUM = 0$                   | (HFC-channel #0)                      |
| $A_FIFO_SEQ[#4]: V_NEXT_FIFO_DIR = 1$ | (next: receive FIFO)                  |
| : $V\_NEXT\_FIFO\_NUM = 14$           | (next: FIFO #14)                      |
| $ : V\_SEQ\_END = 0 $                 | (continue)                            |
| $R_FSM_IDX$ : $V_IDX$ = 5             | (List index #5, used for FIFO[14,RX]) |
| $A\_CHANNEL[\#5] : V\_CH\_FDIR = 1$   | (receive HFC-channel)                 |
| : $V\_CH\_FNUM = 0$                   | (HFC-channel #0)                      |
| $A_FIFO_SEQ[#5]: V_NEXT_FIFO_DIR = 0$ | (next: transmit FIFO)                 |
| : $V\_NEXT\_FIFO\_NUM = 14$           | (next: FIFO #14)                      |
| : $V\_SEQ\_END = 0$                   | (continue)                            |

| Register setup:    |             | (       | (FSM <b>3</b> FIFO programming for list indices 4 and 5) |
|--------------------|-------------|---------|----------------------------------------------------------|
| R_FIFO :           | V_FIFO_DIR  | = 0     | (transmit FIFO)                                          |
| :                  | V_FIFO_NUM  | = 14    | (FIFO #14)                                               |
| :                  | V_REV       | = 0     | (normal bit order)                                       |
| A_CON_HDLC[14,TX]: | V_IFF       | = 0     | (0x7E as inter frame fill)                               |
| :                  | V_HDLC_TRP  | = 0     | (HDLC mode)                                              |
| :                  | V_FIFO_IRQ  | = 7     | (enable FIFO)                                            |
| :                  | V_DATA_FLOW | ·000' = | (FIFO $\rightarrow$ ST / U_p , FIFO $\rightarrow$ PCM)   |
| R_FIFO :           | V_FIFO_DIR  | = 1     | (receive FIFO)                                           |
| :                  | V_FIFO_NUM  | = 14    | (FIFO #14)                                               |
| :                  | V_REV       | = 0     | (normal bit order)                                       |
| A_CON_HDLC[14,RX]: | V_IFF       | = 0     | (0x7E as inter frame fill)                               |
| :                  | V_HDLC_TRP  | = 0     | (HDLC mode)                                              |
| :                  | V_FIFO_IRQ  | = 7     | (enable FIFO)                                            |
| :                  | V_DATA_FLOW | :000' = | $(FIFO \leftarrow ST/U_p)$                               |

When the FIFO[14,TX] and FIFO[14,RX] are used for the second time, they need not to be programmed again. So just the HFC-channels have to programmed for the list indices #6 and #7.



| Register setup:                 |      | (FSM <b>3</b> list indices 6 and 7)   |
|---------------------------------|------|---------------------------------------|
| R_FSM_IDX : V_IDX               | = 6  | (List index #6, used for FIFO[14,TX]) |
| A_CHANNEL[#6] : V_CH_FDIR       | = 0  | (transmit HFC-channel)                |
| : V_CH_FNUM                     | = 1  | (HFC-channel #1)                      |
| A_FIFO_SEQ[#6]: V_NEXT_FIFO_DIR | = 1  | (next: receive FIFO)                  |
| : V_NEXT_FIFO_NUM               | = 14 | (next: FIFO #14)                      |
| : V_SEQ_END                     | = 0  | (continue)                            |
| R_FSM_IDX : V_IDX               | = 7  | (List index #7, used for FIFO[14,RX]) |
| A_CHANNEL[#7] : V_CH_FDIR       | = 1  | (receive HFC-channel)                 |
| : V_CH_FNUM                     | = 1  | (HFC-channel #1)                      |
| A_FIFO_SEQ[#7]: V_NEXT_FIFO_DIR | = 0  |                                       |
| : V_NEXT_FIFO_NUM               | = 0  |                                       |
| : V_SEQ_END                     | = 1  | (end of list)                         |



## 3.5 Subchannel Processing

#### 3.5.1 Overview

Data transmission between a FIFO and the connected HFC-channel can be controlled by the subchannel processor. The behavior of this functional unit depends on the selected data flow mode (SM, CSM or FSM) and the operation mode of the HDLC controller (transparent or HDLC mode). The subchannel controller allows to process less than 8 bits of the transferred FIFO data bytes.

The subchannel processor cannot be used for direct PCM-to-ST/ $U_p$  or PCM-to-PCM connections, because a FIFO must participate in the data flow.

A general overview of the subchannel processor in transmit direction is shown as a simplified example in Figure 3.13. Three transmit FIFOs are connected to one HFC-channel. Details of subchannel processing are described in the following sections, partitioned into the different modes of the data flow and the HDLC controller.



Figure 3.13: General structure of the subchannel processor shown with an example of three connected FIFOs

The essence of the subchannel processor is a bit extraction/insertion unit for every FIFO and a byte mask for every HFC-channel. Therefore, the subchannel processor is divided into two parts A and B like shown in Figure 3.14. The behaviour of the FIFO oriented part A depends on the HDLC or transparent mode selection. The HFC-channel oriented part B has a different behaviour due to the selected data flow SM or CSM/FSM.



Figure 3.14: Location of the subchannel parts A and B in the data flow diagram


## 3.5.2 Subchannel registers

The FIFO bit extraction/insertion requires two register settings. V\_BIT\_CNT defines the number of bits to be extracted/inserted. These bits are always aligned to position 0 in the FIFO data. This bit field can freely be placed in the HFC-channel byte. For this, the start bit can be selected with V\_START\_BIT in the range of 0..7. Both values are located in register A\_SUBCH\_CFG[FIFO].

The HFC-channel mask can be stored in register A\_CH\_MSK[FIFO]. This mask is only used for transmit data. The processed FIFO bits are stored in this register, so it must be re-initialized after changing the settings in A\_SUBCH\_CFG[FIFO]. Each HFC-channel has its own mask byte. To write this byte for HFC-channel [n,TX], the HFC-channel must be written into the multi-register R\_FIFO first. The desired mask byte m can be written with A\_CH\_MSK = m after this index selection.

## **Important**!

Typically, the multi-register R\_FIFO contains always a FIFO index. There is one exception where the R\_FIFO value has a different meaning: The HFC-channel mask byte A\_CH\_MSK is programmed by writing the <u>HFC-channel</u> into the R\_FIFO register.

The default subchannel configuration in register A\_SUBCH\_CFG leads to a transparent behavior. That means, only complete data bytes are transmitted in receive and transmit direction.

## **3.5.3** Details of the FIFO oriented part of the subchannel processor (part A)

The subchannel processor part A lies between the HDLC controller and the HFC-channel assigner. Figure 3.15 shows the block diagram for both receive and transmit data directions.

At the HDLC controller side, there are a data path and two control lines. These communicate the number of bits to be processed and the HDLC/transparent mode selection between the two modules. In transparent mode always one byte is transferred between the HDLC controller and the subchannel controller part A every 125  $\mu$ s cycle. In HDLC mode the number of bits is specified by the subchannel bitmap V\_BIT\_CNT in register A\_SUBCH\_CFG[FIFO].

On the other side, the data path between subchannel processor part A and the HFC-channel assigner transfers always one byte in transmit and receive direction during every  $125 \,\mu s$  cycle.

## **3.5.3.1** FIFO transmit operation in transparent mode

In transparent mode every FIFO has a data rate of 8 kByte/s. Every 125  $\mu$ s one byte of a FIFO is processed. The number of bits specified in V\_BIT\_CNT is placed at position V\_START\_BIT + V\_BIT\_CNT - 1...V\_START\_BIT while the other bits are not used and will be overwritten from the HFC-channel mask in part B of the subchannel processor.





Figure 3.15: Part A of the subchannel processor



## 3.5.3.2 FIFO transmit operation in HDLC mode

The HDLC mode allows to reduce the data rate of a FIFO. With every  $125 \,\mu s$  cycle the subchannel processor requests V\_BIT\_CNT bits from the HDLC controller. The FIFO data rate is

$$DR_{FIFO} = \begin{cases} V\_BIT\_CNTkBit/s : V\_BIT\_CNT > 0\\ 8kBit/s : V\_BIT\_CNT = 0 \end{cases}$$

or might be a little lower due to the bit stuffing (zero insertion).

## **3.5.3.3** FIFO receive operation in transparent mode

The subchannel processor part A receives one byte every  $125 \,\mu s$  cycle. Typically, only some bits – depending on the usage mode of this receive channel – contain valid data. V\_START\_BIT defines the position of the valid bit field in the received HFC-channel byte. The subchannel processor part A shifts the valid bit field to position 0 before a whole byte is transferred to the HDLC controller. The invalid bits must be masked out by software. The FIFO data rate is always 8 kByte/s in this configuration.

If transparent mode is selected, V\_BIT\_CNT must always be '000' in receive direction. The number of valid bits must be handled by the software.

## **3.5.3.4** FIFO receive operation in HDLC mode

From every received HFC-channel data byte only V\_BIT\_CNT bits beginning at position V\_START\_BIT contain valid data. Only these bits are transferred to the HDLC controller. So the FIFO data rate is

$$DR_{FIFO} = \begin{cases} V\_BIT\_CNTkBit/s : V\_BIT\_CNT > 0\\ 8kBit/s : V\_BIT\_CNT = 0 \end{cases}$$

or might be a little lower due to the bit stuffing (zero deletion).

## **3.5.4** Details of the HFC-channel oriented part of the subchannel processor (part B)

Part B of the subchannel processor is located inside the HFC-channel area. With every 125  $\mu$ s cycle it transmits and receives always one data byte to/from the connected interface (either PCM or ST/U<sub>p</sub> interface). On the other side, to/from every connected HFC-channel assigner one byte is transferred in both transmit and receive directions. Figure 3.16 shows the block diagram of this module.

## 3.5.4.1 FIFO transmit operation in SM

As the FIFO and HFC-channel numbers are the same in *Simple Mode*, only one FIFO can be connected to a HFC-channel. Subchannel processing can do nothing more than masking out some bits of every transmitted data byte.

The specified bit field is put into the HFC-channel mask byte before the data byte is transmitted to the connected interface.





Figure 3.16: Part B of the subchannel processor

## 3.5.4.2 FIFO transmit operation in CSM and FSM

In *Channel Select Mode* and *FIFO Sequence Mode*, several FIFOs can contribute data to one HFCchannel data byte. From every connected HFC-channel assigner, one or more bits are extracted and are joined to a single HFC-channel data byte.

Here, the subchannel processor works in the same way as in *Simple Mode*, except that multiple bit insertion is performed. All FIFOs which contribute data bits to the HFC-channel byte should specify different bit locations to avoid overwriting data.

#### 3.5.4.3 FIFO receive operation in SM

The received data byte is transferred to the HFC-channel assigner without modification. Part B of the subchannel processor has no effect to the receive data. Typically, only some bits contain valid data which will be extracted by the part A of the subchannel processor.

## 3.5.4.4 FIFO receive operation in CSM and FSM

If there are several FIFOs connected to one receive HFC-channel in *Channel Select Mode* or *FIFO Sequence Mode*, every received data byte is transferred to all connected HFC-channel assigners without modification. Part B of the subchannel processor has no effect to the receive data. Typically, the HFC-channel data byte contains bit fields for several FIFOs which will be extracted by their part A of the subchannel processor.



## 3.5.5 Subchannel example for SM

The subchannel processing example in Figure 3.17 shows two bidirectional configurations ( $\bigcirc$  FIFO-to-ST/U<sub>p</sub> and  $\oslash$  FIFO-to-PCM) in *Simple Mode*.

## Please note !

All subchannel examples in this document have always the same number of bits and the same start bit for corresponding transmit and receive FIFOs. Actually, transmit and receive configuration settings are independently from each other. The settings are chosen for clearness and can simply be reproduced with looped data pathes.



Figure 3.17: SM example with subchannel processor

## **①** FIFO-to-ST/U<sub>p</sub> (TX)

The first setting shows a FIFO-to-ST/ $U_p$  data transmission in transparent mode.

Register A\_SUBCH\_CFG[FIFO] defines three bits [2..0] to be transmitted from each FIFO byte. These bits have the position [3..1] in the HFC-channel data byte.

All other data bits in the HFC-channel byte are defined by the HFC-channel mask  $V_CH_MSK = '1011\,0000'$  in register A\_CH\_MSK. This array register must be selected by writing the HFC-channel number and direction into register R\_FIFO. The mask bits [3..1] are *don't care* because they are overwritten from the FIFO data.

A detailed overview of the transmitted data is shown in Table 3.6. The first data byte in FIFO[1,TX] is  $a_1$ , the second byte is  $a_2$ , and so on. In transparent mode only  $(a_1[2..0], a_2[2..0], ...)$  are placed in the HFC-channel bytes at the location [3..1] and  $(a_1[7..3], a_2[7..3], ...)$  are ignored and replaced by the HCF-channel mask.



| Register setup:  |               |                  | (SM <b>0</b> TX)                                         |
|------------------|---------------|------------------|----------------------------------------------------------|
| R_FIFO           | : V_FIFO_DIR  | = 0              | (transmit FIFO)                                          |
|                  | : V_FIFO_NUM  | = 1              | (FIFO #1)                                                |
|                  | : V_REV       | = 0              | (normal bit order)                                       |
| A_CON_HDLC[1,TX] | : V_IFF       | = 0              | (0x7E as inter frame fill)                               |
|                  | : V_HDLC_TRP  | = 1              | (transparent mode)                                       |
|                  | : V_FIFO_IRQ  | = 7              | (enable FIFO)                                            |
|                  | : V_DATA_FLOW | <i>i</i> = '000' | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM) |
| A_SUBCH_CFG[1,TX | []: V_BIT_CNT | = 3              | (process 3 bits)                                         |
|                  | : V_START_BIT | = 1              | (start with bit 1)                                       |
|                  | : V_LOOP_FIFO | = 0              | (normal operation)                                       |
|                  | : V_INV_DATA  | = 0              | (normal data transmission)                               |
| R_FIFO           | : V_FIFO_DIR  | = 0              | (transmit HFC-channel)                                   |
|                  | : V_FIFO_NUM  | = 1              | (HFC-channel #1)                                         |
|                  | : V_REV       | = 0              | (normal bit order)                                       |
| A_CH_MSK[1,TX]   | : V_CH_MSK    | = '1011 0000'    | (mask byte)                                              |

## **①** FIFO-to-ST/U<sub>p</sub> (RX)

Only three bits [3..1] from the received HFC-channel byte are assumed to be valid data. Nevertheless, the number of received bits must be set to the value V\_BIT\_CNT = 0 which means 'one byte'. The start position is specified with V\_START\_BIT = 1 in register A\_SUBCH\_CFG. As the received bit field is aligned to position 0, these bits represent FIFO data b[2..0].

A detailed overview of the received data is shown in Table 3.7. The first data byte in FIFO[1,RX] is  $b_1$ , the second byte is  $b_2$ , and so on. Only  $(b_1[2..0], b_2[2..0], ...)$  contain valid data and  $(b_1[7..3], b_2[7..3], ...)$  must be masked out by software.

|             |                                                                                                                                                |                                                                                                                                                                                        | (SM <b>0</b> RX)                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V_FIFO_DIR  | = 1                                                                                                                                            | (receive FIFO)                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_FIFO_NUM  | = 1                                                                                                                                            | (FIFO #1)                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_REV       | = 0                                                                                                                                            | (normal bit order)                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_IFF       | = 0                                                                                                                                            | (0x7E as inter frame fill)                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_HDLC_TRP  | = 1                                                                                                                                            | (transparent mode)                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_FIFO_IRQ  | = 7                                                                                                                                            | (enable FIFO)                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_DATA_FLOW | = '000'                                                                                                                                        | $(FIFO \leftarrow ST/U_p)$                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_BIT_CNT   | = 0                                                                                                                                            | (process 8 bits)                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_START_BIT | = 1                                                                                                                                            | (start with bit 1)                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_LOOP_FIFO | = 0                                                                                                                                            | (normal operation)                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                              |
| V_INV_DATA  | = 0                                                                                                                                            | (normal data transmission)                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                              |
| -           | V_FIFO_DIR<br>V_FIFO_NUM<br>V_REV<br>V_IFF<br>V_HDLC_TRP<br>V_FIFO_IRQ<br>V_DATA_FLOW<br>V_BIT_CNT<br>V_START_BIT<br>V_LOOP_FIFO<br>V_INV_DATA | $V_FIFO_DIR = 1$ $V_FIFO_NUM = 1$ $V_REV = 0$ $V_IFF = 0$ $V_HDLC_TRP = 1$ $V_FIFO_IRQ = 7$ $V_DATA_FLOW = '000'$ $V_BIT_CNT = 0$ $V_START_BIT = 1$ $V_LOOP_FIFO = 0$ $V_INV_DATA = 0$ | $V\_FIFO\_DIR$ = 1(receive FIFO) $V\_FIFO\_NUM$ = 1(FIFO #1) $V\_REV$ = 0(normal bit order) $V\_IFF$ = 0(0x7E as inter frame fill) $V\_HDLC\_TRP$ = 1(transparent mode) $V\_FIFO\_IRQ$ = 7(enable FIFO) $V\_DATA\_FLOW$ = '000'(FIFO $\leftarrow$ ST / U <sub>p</sub> ) $V\_BIT\_CNT$ = 0(process 8 bits) $V\_LOOP\_FIFO$ = 0(normal operation) $V\_INV\_DATA$ = 0(normal data transmission) |



|                              | 7 |   |     |          |          |          | 0 |
|------------------------------|---|---|-----|----------|----------|----------|---|
| HFC-channel mask:            | 1 | 0 | 1 1 | 0        | 0        | 0        | 0 |
|                              |   |   |     |          |          |          | _ |
| HFC-channel transmit byte 1: | 1 | 0 | 1 1 | $a_1[2]$ | $a_1[1]$ | $a_1[0]$ | 0 |
| HFC-channel transmit byte 2: | 1 | 0 | 1 1 | $a_2[2]$ | $a_2[1]$ | $a_2[0]$ | 0 |
| HFC-channel transmit byte 3: | 1 | 0 | 1 1 | $a_3[2]$ | $a_3[1]$ | $a_3[0]$ | 0 |
|                              |   |   |     |          |          |          |   |

 Table 3.6: Subchannel processing according to Figure 3.17 (SM ① TX, transparent mode)

 Table 3.7: Subchannel processing according to Figure 3.17 (SM ① RX, transparent mode)

|                             | 7                                          | 0 |
|-----------------------------|--------------------------------------------|---|
| HFC-channel receive byte 1: | $x  x  x  x  b_1[2]  b_1[1]  b_1[0]$       | x |
| HFC-channel receive byte 2: | $x  x  x  x  b_2[2]  b_2[1]  b_2[0]$       | x |
| HFC-channel receive byte 3: | $x \ x \ x \ x \ b_3[2] \ b_3[1] \ b_3[0]$ | x |
|                             |                                            |   |

## **2** FIFO-to-PCM (TX)

The second *Simple Mode* configuration connects a FIFO in HDLC mode with the PCM interface <sup>6</sup>. Bitmap V\_BIT\_CNT in register A\_SUBCH\_CFG[FIFO] defines three FIFO data bits to be transmitted during every 125 µs cycle. The bit field location in the HFC-channel data byte is specified by bitmap V\_START\_BIT in the same register.

All other data bits in the HFC-channel are defined by the HFC-channel mask in register  $A\_CH\_MSK$ . This array register must be selected by writing the HFC-channel number and direction into register  $R\_FIFO$ . The mask bits [5..3] are *don't care* because they are overwritten from the FIFO data.

A detailed overview of the transmitted data is shown in Table 3.8. The first data byte in FIFO[15,TX] is  $c_1$ , the second byte is  $c_2$ , and so on. In HDLC mode, FIFO bytes are dispersed among several HFC-channel bytes.

<sup>&</sup>lt;sup>6</sup>HDLC bit stuffing is not shown in this example.



|             |                                                                                                                                                                                                                                                                          | (SM <b>2</b> TX)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V_FIFO_DIR  | = 0                                                                                                                                                                                                                                                                      | (transmit FIFO)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V_FIFO_NUM  | = 15                                                                                                                                                                                                                                                                     | (FIFO #15)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V_REV       | = 0                                                                                                                                                                                                                                                                      | (normal bit order)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V_IFF       | = 0                                                                                                                                                                                                                                                                      | (0x7E as inter frame fill)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V_HDLC_TRP  | = 0                                                                                                                                                                                                                                                                      | (HDLC mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| V_FIFO_IRQ  | = 7                                                                                                                                                                                                                                                                      | (enable FIFO)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| V_DATA_FLOW | = '001'                                                                                                                                                                                                                                                                  | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| V_BIT_CNT   | = 3                                                                                                                                                                                                                                                                      | (process 3 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V_START_BIT | = 3                                                                                                                                                                                                                                                                      | (start with bit 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V_LOOP_FIFO | = 0                                                                                                                                                                                                                                                                      | (normal operation)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V_INV_DATA  | = 0                                                                                                                                                                                                                                                                      | (normal data transmission)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| V_FIFO_DIR  | = 0                                                                                                                                                                                                                                                                      | (transmit HFC-channel)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| V_FIFO_NUM  | = 15                                                                                                                                                                                                                                                                     | (HFC-channel #15)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| V_REV       | = 0                                                                                                                                                                                                                                                                      | (normal bit order)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| V_CH_MSK    | = '1011 0011'                                                                                                                                                                                                                                                            | (mask byte)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| V_SL_DIR    | = 0                                                                                                                                                                                                                                                                      | (transmit slot)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| V_SL_NUM    | = 7                                                                                                                                                                                                                                                                      | (slot #7)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| V_CH_SDIR   | = 0                                                                                                                                                                                                                                                                      | (transmit HFC-channel)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| V_CH_SNUM   | = 15                                                                                                                                                                                                                                                                     | (HFC-channel #15)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| V_ROUT      | = '10'                                                                                                                                                                                                                                                                   | (data to pin STIO1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|             | V_FIFO_DIR<br>V_FIFO_NUM<br>V_REV<br>V_IFF<br>V_HDLC_TRP<br>V_FIFO_IRQ<br>V_DATA_FLOW<br>V_BIT_CNT<br>V_START_BIT<br>V_LOOP_FIFO<br>V_INV_DATA<br>V_FIFO_DIR<br>V_FIFO_NUM<br>V_REV<br>V_CH_MSK<br>V_SL_DIR<br>V_SL_DIR<br>V_CH_SDIR<br>V_CH_SDIR<br>V_CH_SNUM<br>V_ROUT | $V_FIFO_DIR = 0$ $V_FIFO_NUM = 15$ $V_REV = 0$ $V_IFF = 0$ $V_HDLC_TRP = 0$ $V_FIFO_IRQ = 7$ $V_DATA_FLOW = '001'$ $V_BIT_CNT = 3$ $V_START_BIT = 3$ $V_LOOP_FIFO = 0$ $V_INV_DATA = 0$ $V_FIFO_DIR = 0$ $V_FIFO_DIR = 0$ $V_FIFO_NUM = 15$ $V_REV = 0$ $V_CH_MSK = '10110011'$ $V_SL_DIR = 0$ $V_CH_SDIR = 0$ $V_CH_SNUM = 15$ $V_REV = 15$ |

## **2** FIFO-to-PCM (RX)

Only three bits [5..3] from the received HFC-channel byte are assumed to be valid data. This is done with bitmaps V\_BIT\_CNT = 3 and V\_START\_BIT = 3 in register A\_SUBCH\_CFG. The bit field is aligned to position 0 and transferred to the HDLC controller. There, FIFO data bytes are constructed from several received bit fields.

A detailed overview of the received data is shown in Table 3.9. The first data byte in FIFO[15,RX] is  $d_1$ , the second byte is  $d_2$ , and so on. In HDLC mode, FIFO bytes are constructed from several HFC-channel bytes.



| Register setup:    |               |         |                                       | (SM <b>2</b> RX) |
|--------------------|---------------|---------|---------------------------------------|------------------|
| R_FIFO             | : V_FIFO_DIR  | = 1     | (receive FIFO)                        |                  |
|                    | : V_FIFO_NUM  | = 15    | (FIFO #15)                            |                  |
|                    | : V_REV       | = 0     | (normal bit order)                    |                  |
| A_CON_HDLC[15,RX]  | : V_IFF       | = 0     | (0x7E as inter frame fill)            |                  |
|                    | : V_HDLC_TRP  | = 0     | (HDLC mode)                           |                  |
|                    | : V_FIFO_IRQ  | = 7     | (enable FIFO)                         |                  |
|                    | : V_DATA_FLOW | = '001' | $(\text{FIFO} \leftarrow \text{PCM})$ |                  |
| A_SUBCH_CFG[15,RX] | : V_BIT_CNT   | = 3     | (process 3 bits)                      |                  |
|                    | : V_START_BIT | = 3     | (start with bit 3)                    |                  |
|                    | : V_LOOP_FIFO | = 0     | (normal operation)                    |                  |
|                    | : V_INV_DATA  | = 0     | (normal data transmission)            |                  |
| R_SLOT             | : V_SL_DIR    | = 1     | (receive slot)                        |                  |
|                    | : V_SL_NUM    | = 7     | (slot #7)                             |                  |
| A_SL_CFG[7,RX]     | : V_CH_SDIR   | = 1     | (receive HFC-channel)                 |                  |
|                    | : V_CH_SNUM   | = 15    | (HFC-channel #15)                     |                  |
|                    | : V_ROUT      | = '10'  | (data from pin STIO2)                 |                  |

## Table 3.8: Subchannel processing according to Figure 3.17 (SM 2 TX, HDLC mode)

|                              | 7 |   |            |            |          |   |   | 0 |
|------------------------------|---|---|------------|------------|----------|---|---|---|
| HFC-channel mask:            | 1 | 0 | 0          | 0          | 0        | 0 | 1 | 1 |
| HFC-channel transmit byte 1: | 1 | 0 | $c_1[2]$   | $c_1[1]$   | $c_1[0]$ | 0 | 1 | 1 |
| HFC-channel transmit byte 2: | 1 | 0 | $c_1[5]$   | $c_1[4]$   | $c_1[3]$ | 0 | 1 | 1 |
| HFC-channel transmit byte 3: | 1 | 0 | $c_{2}[0]$ | $c_1[7]$   | $c_1[6]$ | 0 | 1 | 1 |
| HFC-channel transmit byte 4: | 1 | 0 | $c_{2}[3]$ | $c_{2}[2]$ | $c_2[1]$ | 0 | 1 | 1 |
|                              |   |   |            |            |          |   |   |   |

Table 3.9: Subchannel processing according to Figure 3.17 (SM 2 RX, HDLC mode)

|                             | 7 |   |            |            |            |   |   | 0 |
|-----------------------------|---|---|------------|------------|------------|---|---|---|
| HFC-channel receive byte 1: | x | x | $d_1[2]$   | $d_1[1]$   | $d_1[0]$   | x | x | x |
| HFC-channel receive byte 2: | x | x | $d_1[5]$   | $d_1[4]$   | $d_1[3]$   | x | x | x |
| HFC-channel receive byte 3: | x | x | $d_{2}[0]$ | $d_1[7]$   | $d_1[6]$   | x | x | x |
| HFC-channel receive byte 4: | x | x | $d_2[3]$   | $d_{2}[2]$ | $d_{2}[1]$ | x | x | x |
|                             |   |   |            |            |            |   |   |   |



## 3.5.6 Subchannel example for CSM

In *Channel Select Mode* up to 8 FIFOs can be assigned to one HFC-channel if only 1 bit is processed by every FIFO. The example in Figure 3.18 shows two bidirectional configurations ( $\bigcirc$  FIFO-to-ST/U<sub>p</sub> and  $\bigcirc$  FIFO-to-PCM) with two FIFOs per direction each.



Figure 3.18: CSM example with subchannel processor

## **①** FIFO-to-ST/U<sub>p</sub> (TX)

In the first setting two transmit FIFOs are connected to one HFC-channel. Transparent mode is selected in this example.

Registers A\_SUBCH\_CFG[FIFO] of FIFO[4,TX] and FIFO[5,TX] define both, the number of bits to be extracted from the FIFO data bytes and their position in the HFC-channel byte.

The HFC-channel mask in register A\_CH\_MSK defines the bit values that are not used for FIFO data. The array register must be selected by writing the HFC-channel number and direction into register R\_FIFO. The mask bits [7..6, 3..1] are *don't care* because they are overwritten from the FIFO data.

A detailed overview of the transmitted data is shown in Table 3.10. The first data byte in FIFO[4,TX] is  $a_1$ , the second byte is  $a_2$ , and so on. FIFO[5,TX] is represented by the data bytes  $c_1$ ,  $c_2$ , and so on.



| Register setup:   |                         |               | (CSM <b>0</b> TX)                                          |
|-------------------|-------------------------|---------------|------------------------------------------------------------|
| R_FIFO            | : V_FIFO_DIR            | = 0           | (transmit FIFO)                                            |
|                   | : V_FIFO_NUM            | = 4           | (FIFO #4)                                                  |
|                   | : V_REV                 | = 0           | (normal bit order)                                         |
| A_CON_HDLC[4,TX]  | : V_IFF                 | = 0           | (0x7E as inter frame fill)                                 |
|                   | : V_HDLC_TRP            | = 1           | (transparent mode)                                         |
|                   | : V_FIFO_IRQ            | = 7           | (enable FIFO)                                              |
|                   | : V_DATA_FLOW           | · = '000'     | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM)   |
| A_CHANNEL[4,TX]   | : V_CH_FDIR             | = 0           | (transmit HFC-channel)                                     |
|                   | : V_CH_FNUM             | = 1           | (HFC-channel #1)                                           |
| A_SUBCH_CFG[4,TX] | ]: V_BIT_CNT            | = 3           | (process 3 bits)                                           |
|                   | : V_START_BIT           | = 1           | (start with bit 1)                                         |
|                   | : V_LOOP_FIFO           | = 0           | (normal operation)                                         |
|                   | : V_INV_DATA            | = 0           | (normal data transmission)                                 |
| R_FIFO            | : V_FIFO_DIR            | = 0           | (transmit FIFO)                                            |
|                   | : V_FIFO_NUM            | = 5           | (FIFO #5)                                                  |
|                   | : V_REV                 | = 0           | (normal bit order)                                         |
| A_CON_HDLC[5,TX]  | : V_IFF                 | = 0           | (0x7E as inter frame fill)                                 |
|                   | : V_HDLC_TRP            | = 1           | (transparent mode)                                         |
|                   | : V_FIFO_IRQ            | = 7           | (enable FIFO)                                              |
|                   | : V_DATA_FLOW           | · = '000'     | (FIFO $\rightarrow$ ST / $U_{p}$ , FIFO $\rightarrow$ PCM) |
| A_CHANNEL[5,TX]   | : V_CH_FDIR             | = 0           | (transmit HFC-channel)                                     |
|                   | : V_CH_FNUM             | = 1           | (HFC-channel #1)                                           |
| A_SUBCH_CFG[5,TX  | ]: V_BIT_CNT            | = 2           | (process 2 bits)                                           |
|                   | : V_START_BIT           | = 6           | (start with bit 6)                                         |
|                   | : V_LOOP_FIFO           | = 0           | (normal operation)                                         |
|                   | : V_INV_DATA            | = 0           | (normal data transmission)                                 |
| R_FIFO            | : V_FIFO DIR            | = 0           | (transmit HFC-channel)                                     |
|                   | : V FIFO NUM            | = 1           | (HFC-channel #1)                                           |
|                   | : V REV                 | = 0           | (normal bit order)                                         |
| A CH MSK[0.TX]    | : V CH MSK              | = '0000 0001' | (mask byte)                                                |
|                   | · · _ • · _ · · • • · · |               | (                                                          |

## $\textbf{0} \quad FIFO-to-ST/U_p \quad (RX)$

The received HFC-channel byte is distributed to two FIFOs. The bit fields [7..6] and [3..1] from the received HFC-channel byte are assumed to be valid data. Nevertheless, the number of received bits must be set to the value V\_BIT\_CNT = 0 which means 'one byte'. The start position is specified with V\_START\_BIT in register A\_SUBCH\_CFG. As the received bit fields are aligned to position 0, these bits represent FIFO data b[2..0] and d[1..0].

A detailed overview of the received data is shown in Table 3.11. The first data byte in FIFO[4,RX] is  $b_1$ , the second byte is  $b_2$ , and so on. FIFO[5,RX] data bytes are  $d_1$ ,  $d_2$ , and so on.



| Register setup:  |               |           |                               | (CSM <b>1</b> RX) |
|------------------|---------------|-----------|-------------------------------|-------------------|
| R_FIFO           | : V_FIFO_DIR  | = 1       | (receive FIFO)                |                   |
|                  | : V_FIFO_NUM  | = 4       | (FIFO #4)                     |                   |
|                  | : V_REV       | = 0       | (normal bit order)            |                   |
| A_CON_HDLC[4,RX] | : V_IFF       | = 0       | (0x7E as inter frame fill)    |                   |
|                  | : V_HDLC_TRP  | = 1       | (transparent mode)            |                   |
|                  | : V_FIFO_IRQ  | = 7       | (enable FIFO)                 |                   |
|                  | : V_DATA_FLOW | i '000' = | $(FIFO \leftarrow ST/U_p \ )$ |                   |
| A_CHANNEL[4,RX]  | : V_CH_FDIR   | = 1       | (receive HFC-channel)         |                   |
|                  | : V_CH_FNUM   | = 1       | (HFC-channel #1)              |                   |
| A_SUBCH_CFG[4,RX | ]: V_BIT_CNT  | = 0       | (process 8 bits)              |                   |
|                  | : V_START_BIT | = 1       | (start with bit 1)            |                   |
|                  | : V_LOOP_FIFO | = 0       | (normal operation)            |                   |
|                  | : V_INV_DATA  | = 0       | (normal data transmission)    |                   |
| R_FIFO           | : V_FIFO_DIR  | = 1       | (receive FIFO)                |                   |
|                  | : V_FIFO_NUM  | = 5       | (FIFO #5)                     |                   |
|                  | : V_REV       | = 0       | (normal bit order)            |                   |
| A_CON_HDLC[5,RX] | : V_IFF       | = 0       | (0x7E as inter frame fill)    |                   |
|                  | : V_HDLC_TRP  | = 1       | (transparent mode)            |                   |
|                  | : V_FIFO_IRQ  | = 7       | (enable FIFO)                 |                   |
|                  | : V_DATA_FLOW | = '000'   | $(FIFO \leftarrow ST/U_p \ )$ |                   |
| A_CHANNEL[5,RX]  | : V_CH_FDIR   | = 1       | (receive HFC-channel)         |                   |
|                  | : V_CH_FNUM   | = 1       | (HFC-channel #1)              |                   |
| A_SUBCH_CFG[5,RX | ]: V_BIT_CNT  | = 0       | (process 8 bits)              |                   |
|                  | : V_START_BIT | = 6       | (start with bit 6)            |                   |
|                  | : V_LOOP_FIFO | = 0       | (normal operation)            |                   |
|                  | : V_INV_DATA  | = 0       | (normal data transmission)    |                   |

 Table 3.10: Subchannel processing according to Figure 3.18 (CSM ① TX, transparent mode)

|                              | 7          |            |   |   |          |          |          | 0 |
|------------------------------|------------|------------|---|---|----------|----------|----------|---|
| HFC-channel mask:            | 0          | 0          | 0 | 0 | 0        | 0        | 0        | 1 |
| HFC-channel transmit byte 1: | $c_1[1]$   | $c_1[0]$   | 0 | 0 | $a_1[2]$ | $a_1[1]$ | $a_1[0]$ | 1 |
| HFC-channel transmit byte 2: | $c_2[1]$   | $c_{2}[0]$ | 0 | 0 | $a_2[2]$ | $a_2[1]$ | $a_2[0]$ | 1 |
| HFC-channel transmit byte 3: | $c_{3}[1]$ | $c_{3}[0]$ | 0 | 0 | $a_3[2]$ | $a_3[1]$ | $a_3[0]$ | 1 |
|                              |            |            |   |   | •••      |          |          |   |



|                              | 7                                                        | 0           |
|------------------------------|----------------------------------------------------------|-------------|
| HFC-channel transmit byte 1: | $d_1[1]$ $d_1[0]$ $x$ $x$ $b_1[2]$ $b_1[1]$              | $b_1[0]  x$ |
| HFC-channel transmit byte 2: | $d_{2}[1]  d_{2}[0]  x  x  b_{2}[2]  b_{2}[1]  d_{2}[1]$ | $b_2[0]  x$ |
| HFC-channel transmit byte 3: | $d_3[1]  d_3[0]  x  x  b_3[2]  b_3[1]  d_3[1]$           | $b_3[0]  x$ |
|                              |                                                          |             |

 Table 3.11: Subchannel processing according to Figure 3.18 (CSM ① RX, transparent mode)

## **2** FIFO-to-PCM (TX)

A FIFO-to-PCM configuration in HDLC mode with two FIFOs in transmit and receive direction each is shown in the second example setting <sup>7</sup>.

Registers A\_SUBCH\_CFG[FIFO] of FIFO[12,TX] and FIFO[8,TX] define both, the numbers of FIFO data bits to be transmitted during every  $125 \,\mu s$  cycle and their position in the HFC-channel byte.

All other data bits in the HFC-channel are defined by the HFC-channel mask in register  $A\_CH\_MSK$ . This array register must be selected by writing the HFC-channel number and direction into register  $R\_FIFO$ . The mask bits [5..2] are *don't care* because they are overwritten from the FIFO data.

A detailed overview of the transmitted data is shown in Table 3.12. The first data byte in FIFO[12,TX] is  $e_1$ , the second byte is  $e_2$ , and so on. FIFO[8,TX] transmits bytes  $g_1$ ,  $g_2$ , and so on. In HDLC mode, FIFO bytes are dispersed among several HFC-channel bytes.

<sup>&</sup>lt;sup>7</sup>HDLC bit stuffing is not shown in this example.



| Register setup:   |               |               | (CSM <b>2</b> TX)                                        |
|-------------------|---------------|---------------|----------------------------------------------------------|
| R_FIFO            | : V_FIFO_DIR  | = 0           | (transmit FIFO)                                          |
|                   | : V_FIFO_NUM  | = 12          | (FIFO #12)                                               |
|                   | : V_REV       | = 0           | (normal bit order)                                       |
| A_CON_HDLC[12,TX] | : V_IFF       | = 0           | (0x7E as inter frame fill)                               |
|                   | : V_HDLC_TRP  | = 0           | (HDLC mode)                                              |
|                   | : V_FIFO_IRQ  | = 7           | (enable FIFO)                                            |
|                   | : V_DATA_FLOW | · = '001'     | (FIFO $\rightarrow$ ST / $U_p$ , FIFO $\rightarrow$ PCM) |
| A_CHANNEL[12,TX]  | : V_CH_FDIR   | = 0           | (transmit HFC-channel)                                   |
|                   | : V_CH_FNUM   | = 15          | (HFC-channel #15)                                        |
| A_SUBCH_CFG[12,TX | ]: V_BIT_CNT  | = 3           | (process 3 bits)                                         |
|                   | : V_START_BIT | = 3           | (start with bit 3)                                       |
|                   | : V_LOOP_FIFO | = 0           | (normal operation)                                       |
|                   | : V_INV_DATA  | = 0           | (normal data transmission)                               |
| R_FIFO            | : V_FIFO_DIR  | = 0           | (transmit FIFO)                                          |
|                   | : V_FIFO_NUM  | = 8           | (FIFO #8)                                                |
|                   | : V_REV       | = 0           | (normal bit order)                                       |
| A_CON_HDLC[8,TX]  | : V_IFF       | = 0           | (0x7E as inter frame fill)                               |
|                   | : V_HDLC_TRP  | = 0           | (HDLC mode)                                              |
|                   | : V_FIFO_IRQ  | = 7           | (enable FIFO)                                            |
|                   | : V_DATA_FLOW | · = '001'     | $(FIFO \rightarrow ST/U_p$ , $FIFO \rightarrow PCM)$     |
| A_CHANNEL[8,TX]   | : V_CH_FDIR   | = 0           | (transmit HFC-channel)                                   |
|                   | : V_CH_FNUM   | = 15          | (HFC-channel #15)                                        |
| A_SUBCH_CFG[8,TX] | : V_BIT_CNT   | = 1           | (process 1 bit)                                          |
|                   | : V_START_BIT | = 2           | (start with bit 2)                                       |
|                   | : V_LOOP_FIFO | = 0           | (normal operation)                                       |
|                   | : V_INV_DATA  | = 0           | (normal data transmission)                               |
| R_FIFO            | : V_FIFO_DIR  | = 0           | (transmit HFC-channel)                                   |
|                   | : V_FIFO_NUM  | = 15          | (HFC-channel #15)                                        |
|                   | : V_REV       | = 0           | (normal bit order)                                       |
| A_CH_MSK[15,TX]   | : V_CH_MSK    | = '1000 1100' | (mask byte)                                              |
| R_SLOT            | : V_SL_DIR    | = 0           | (transmit slot)                                          |
|                   | : V_SL_NUM    | = 7           | (slot #7)                                                |
| A_SL_CFG[7,TX]    | : V_CH_SDIR   | = 0           | (transmit HFC-channel)                                   |
|                   | : V_CH_SNUM   | = 15          | (HFC-channel #15)                                        |
|                   | : V_ROUT      | = '10'        | (data to pin STIO1)                                      |

## **2** FIFO-to-PCM (RX)

HFC-channel[15,RX] receives data bits that are to be distributed to FIFO[12,RX] and FIFO[8,RX].

Registers A\_SUBCH\_CFG[FIFO] of FIFO[12,RX] and FIFO[8,RX] define the numbers of valid data bits and their positions in the HFC-channel byte. These bits are dispersed to FIFO[12,RX] and FIFO[8,RX] where they are aligned to bit 0.

A detailed overview of the received data is shown in Table 3.13. The first data byte in FIFO[12,RX] is  $f_1$ , the second byte is  $f_2$ , and so on. FIFO[8,RX] receives bytes  $h_1$ ,  $h_2$ , and so on. In HDLC mode, FIFO bytes are collected from several HFC-channel bytes.



| Register setup:        |            |         |                            | (CSM <b>2</b> RX) |
|------------------------|------------|---------|----------------------------|-------------------|
| R_FIFO : V_            | _FIFO_DIR  | = 1     | (receive FIFO)             |                   |
| : V_                   | _FIFO_NUM  | = 12    | (FIFO #12)                 |                   |
| : V_                   | _REV       | = 0     | (normal bit order)         |                   |
| A_CON_HDLC[12,RX] : V_ | _IFF       | = 0     | (0x7E as inter frame fill) |                   |
| : V_                   | _HDLC_TRP  | = 0     | (HDLC mode)                |                   |
| : V_                   | _FIFO_IRQ  | = 7     | (enable FIFO)              |                   |
| : V_                   | _DATA_FLOW | = '001' | $(FIFO \leftarrow PCM)$    |                   |
| A_CHANNEL[12,RX] : V_  | _CH_FDIR   | = 1     | (receive HFC-channel)      |                   |
| : V_                   | _CH_FNUM   | = 15    | (HFC-channel #15)          |                   |
| A_SUBCH_CFG[12,TX]: V_ | _BIT_CNT   | = 3     | (process 3 bits)           |                   |
| : V_                   | _START_BIT | = 3     | (start with bit 3)         |                   |
| : V_                   | _LOOP_FIFO | = 0     | (normal operation)         |                   |
| : V_                   | _INV_DATA  | = 0     | (normal data transmission) |                   |
| R_FIFO : V_            | _FIFO_DIR  | = 1     | (receive FIFO)             |                   |
| : V_                   | _FIFO_NUM  | = 8     | (FIFO #8)                  |                   |
| : V_                   | _REV       | = 0     | (normal bit order)         |                   |
| A_CON_HDLC[8,RX] : V_  | _IFF       | = 0     | (0x7E as inter frame fill) |                   |
| : V_                   | _HDLC_TRP  | = 0     | (HDLC mode)                |                   |
| : V_                   | _FIFO_IRQ  | = 7     | (enable FIFO)              |                   |
| : V_                   | _DATA_FLOW | = '001' | $(FIFO \leftarrow PCM)$    |                   |
| A_CHANNEL[8,RX] : V_   | _CH_FDIR   | = 1     | (receive HFC-channel)      |                   |
| : V_                   | _CH_FNUM   | = 15    | (HFC-channel #15)          |                   |
| A_SUBCH_CFG[8,TX] : V_ | _BIT_CNT   | = 1     | (process 1 bit)            |                   |
| : V_                   | _START_BIT | = 2     | (start with bit 2)         |                   |
| : V_                   | _LOOP_FIFO | = 0     | (normal operation)         |                   |
| : V_                   | _INV_DATA  | = 0     | (normal data transmission) |                   |
| R_SLOT : V_            | _SL_DIR    | = 1     | (receive slot)             |                   |
| : V_                   | _SL_NUM    | = 7     | (slot #7)                  |                   |
| A_SL_CFG[7,RX] : V_    | _CH_SDIR   | = 1     | (receive HFC-channel)      |                   |
| : V_                   | _CH_SNUM   | = 15    | (HFC-channel #15)          |                   |
| : V_                   | _ROUT      | = '10'  | (data from pin STIO2)      |                   |



| 7                                                      | 0                                                      |
|--------------------------------------------------------|--------------------------------------------------------|
| 1 0 0 0 1 1                                            | 0 0                                                    |
|                                                        |                                                        |
| $1  0  e_1[2]  e_1[1]  e_1[0]  g_1[0]$                 | 0 0                                                    |
| $1  0  e_1[5]  e_1[4]  e_1[3]  g_1[1]$                 | 0 0                                                    |
|                                                        |                                                        |
| $1  0  e_2[0]  e_1[7]  e_1[6]  g_1[2]$                 | 0 0                                                    |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | 0 0                                                    |
|                                                        |                                                        |
|                                                        | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ |

Table 3.12: Subchannel processing according to Figure 3.18 (CSM 2 TX, HDLC mode)

Table 3.13: Subchannel processing according to Figure 3.18 (CSM 2 RX, HDLC mode)

|                              | 7                                                                 | 0 |
|------------------------------|-------------------------------------------------------------------|---|
| HFC-channel transmit byte 1: | $x \mid x \mid f_1[2] \mid f_1[1] \mid f_1[0] \mid h_1[0] \mid x$ | x |
| HFC-channel transmit byte 2: | $x \ x \ f_1[5] \ f_1[4] \ f_1[3] \ h_1[1] \ x$                   | x |
| HFC-channel transmit byte 3: | $x \mid x \mid f_2[0] \mid f_1[7] \mid f_1[6] \mid h_1[2] \mid x$ | x |
| HFC-channel transmit byte 4: | $\begin{array}{c c c c c c c c c c c c c c c c c c c $            | x |
|                              |                                                                   |   |



# Chapter 4

# **FIFO handling and HDLC controller**

| Write only | registers:     |      | Read/write registers: |                   |      |
|------------|----------------|------|-----------------------|-------------------|------|
| Address    | Name           | Page | Address               | Name              | Page |
| 0x0B       | R_FIRST_FIFO   | 133  | 0x80                  | A_FIFO_DATA       | 145  |
| 0x0C       | R_FIFO_THRES   | 134  | 0x84                  | A_FIFO_DATA_NOINC | 145  |
| 0x0D       | R_FIFO_MD      | 135  | 0xF4                  | A_CH_MSK          | 146  |
| 0x0E       | A_INC_RES_FIFO | 136  | 0xFA                  | A_CON_HDLC        | 147  |
| 0x0F       | R_FIFO         | 137  | 0xFB                  | A_SUBCH_CFG       | 149  |
| 0x0F       | R_FSM_IDX      | 137  | 0xFC                  | A_CHANNEL         | 150  |
|            |                |      | 0xFD                  | A_FIFO_SEQ        | 151  |
| Read only  | register:      |      | 0xFF                  | A_FIFO_CTRL       | 152  |
| Address    | Name           | Page |                       |                   |      |
| 0x04       | A_Z1           | 138  |                       |                   |      |
| 0x06       | A_Z2           | 138  |                       |                   |      |
| 0x0C       | A_F1           | 138  |                       |                   |      |
| 0x0D       | A_F2           | 139  |                       |                   |      |
| 0x0E       | A_FIFO_STA     | 140  |                       |                   |      |
| 0x14       | A_USAGE        | 141  |                       |                   |      |
| 0x24       | R_FILL_BL0     | 141  |                       |                   |      |
| 0x25       | R_FILL_BL1     | 142  |                       |                   |      |
| 0x26       | R_FILL_BL2     | 143  |                       |                   |      |
| 0x27       | R_FILL_BL3     | 144  |                       |                   |      |

Table 4.1: Overview of the XHFC-1SU FIFO registers



## 4.1 Overview

There are up to 16 receive FIFOs and up to 16 transmit FIFOs with 32 HDLC controllers in whole. The HDLC controllers are located on the  $ST/U_p$  interface side of the FIFOs. Thus plain data is always stored in the FIFOs. Automatic zero insertion is done in HDLC mode when HDLC data goes from the FIFOs to the  $ST/U_p$  interface or to the PCM bus (transmit FIFO operation). Automatic zero deletion is done in HDLC mode when the HDLC data comes from the  $ST/U_p$  interface or PCM bus (receive FIFO operation).

There are more transmit and receive FIFOs than B-, D- and E-channels. These can be used for PCM-to-FIFO and PCM-to-ST/ $U_p$  configurations.

The FIFO control registers are used to select and control the FIFOs of XHFC-1SU. The FIFO register set exists for every FIFO number and receive/transmit direction. A FIFO is selected by the FIFO select register  $R_FIFO$ .

All FIFOs are disabled after reset (hardware reset, global software reset or HFC reset). With register A\_CON\_HDLC the selected FIFO is enabled by setting V\_FIFO\_IRQ to a value different from zero.

## 4.2 FIFO counters

The FIFOs are realized as ring buffers in the internal SRAM. They are controlled by counters. The counter sizes depend on the setting of the FIFO sizes. *Z*1 is the FIFO input counter and *Z*2 is the FIFO output counter.

Each counter points to a byte position in the SRAM. On a FIFO input operation Z1 is incremented. On an output operation Z2 is incremented. If Z1 = Z2 and F1 = F2 the FIFO is empty.

After every pulse on the F0IO signal, HDLC bytes are written into the  $ST/U_p$  interface (from a transmit FIFO) and HDLC bytes are read from the  $ST/U_p$  interface (to a receive FIFO). A connection to the PCM interface is also possible.

The D-channel data is processed in exactly the same way as the B-channel data, except that the D-FIFO data rate is reduced in HDLC mode.

Additionally there are two 4 bit counters F1 and F2 for every FIFO. They count the HDLC frames and form a ring buffer as Z1 and Z2 do, too.

F1 is incremented when a complete frame has been received and stored in the FIFO. F2 is incremented when a complete frame has been read from the FIFO. If F1 = F2 there is no complete frame in the FIFO.

The reset state of the Z- and F-counters are

- $Z1 = Z2 = Z_{MAX}^{1}$  and
- $F1 = F2 = F_{MAX} = 0x07$ .

This initialization can be carried out with a global software reset or a HDLC reset. For this, bits V\_SRES or V\_HFC\_RES in register R\_CIRM have to be set. Individual FIFOs can be reset with bit V\_RES\_FIFO in register A\_INC\_RES\_FIFO.

<sup>&</sup>lt;sup>1</sup>See  $Z_{\text{max}}$  value in Table 4.2.



In addition, a hardware reset initializes the counters.

## Please note !

#### Abort D-channel transmission

A FIFO reset should never be initiated while an HDLC ending flag is just in transmission. If this cannot be ensured – or to be on the safe side – any FIFO reset can be wrapped in a D-channel reset as shown below.

Additionally, V\_RES\_FIFO\_ERR should always be set together with a FIFO reset even if no FIFO error is pending. This can be done with a single register write access.

| Register setup:                                                     |                      |       |                                  |  |  |
|---------------------------------------------------------------------|----------------------|-------|----------------------------------|--|--|
| R_FIFO                                                              | : V_FIFO_DIR         | = dir | Select FIFO data direc-<br>tion* |  |  |
|                                                                     | : V_FIFO_NUM         | = n   | Select FIFO number               |  |  |
| repeat until                                                        |                      |       |                                  |  |  |
| R_STATUS                                                            | : V_BUSY             | = 0   | Wait until not busy              |  |  |
| R_SU_CTRL1                                                          | : V_D_RES            | = 1   | D-channel reset                  |  |  |
| A_INC_RES_FIFO[F                                                    | IFO]: V_RES_FIFO_ERI | R = 1 | Reset FIFO error *               |  |  |
|                                                                     | : V_RES_FIFO         | = 1   | Reset selected FIFO              |  |  |
| repeat until                                                        |                      |       |                                  |  |  |
| R_STATUS                                                            | : V_BUSY             | = 0   | Wait until not busy              |  |  |
| R_SU_CTRL1                                                          | : V_D_RES            | = 0   | Normal D-channel oper-           |  |  |
|                                                                     |                      |       | ation                            |  |  |
| * Single register write access together with the following command. |                      |       |                                  |  |  |
|                                                                     |                      |       |                                  |  |  |

## **Important** !

#### Busy status after FIFO change, FIFO reset and F1/F2 incrementation

Changing a FIFO, reseting a FIFO or incrementing the *F*-counters causes a short BUSY period of XHFC-1SU. This means an access to FIFO control registers is not allowed until BUSY status is cleared (bit V\_BUSY in register R\_STATUS). The maximum duration takes 25 clock cycles ( $\sim 1 \mu s$ ). Status, interrupt and control registers can be read and written at any time.

## **Please note !**

The counter state  $Z_{\text{MIN}}$  (resp.  $F_{\text{MIN}}$ ) of the Z-counters (resp. F-counters) follows counter state  $Z_{\text{MAX}}$  (resp.  $F_{\text{MAX}}$ ) in the FIFOs.

Please note that  $Z_{\text{MIN}}$  and  $Z_{\text{MAX}}$  depend on the FIFO number and FIFO size (s. Section 4.3 and Table 4.2).



## 4.3 FIFO size setup

Table 4.2 shows how the FIFO size can be varied. Additionally, the initial  $Z_{\text{max}}$  and  $Z_{\text{min}}$  values are given in Table 4.2. A global software reset should be initiated after changing the FIFO size.

Normal operation with transmit and receive FIFOs is configured with V\_UNIDIR\_MD = '0' in register R\_FIFO\_MD. Some applications may use only transmit or only receive FIFOs. In this case V\_UNIDIR\_MD = '1' provides two settings as shown in Table 4.2. The data direction can be chosen either with V\_UNIDIR\_RX = '0' (only transmit FIFOs available) or with V\_UNIDIR\_RX = '1' (only receive FIFOs available). V\_UNIDIR\_RX is ignored if V\_UNIDIR\_MD = '0'.

| V_FIFO_MD | V_UNIDIR_MD | FIF<br>numl | TO<br>bers | $\mathbf{Z}_{\mathrm{MIN}}$ | Z <sub>MAX</sub> | FIFO size<br>(byte) |
|-----------|-------------|-------------|------------|-----------------------------|------------------|---------------------|
| '00'      | '0'         | 0           | 15         | 0x00                        | 0x3F             | 64                  |
| '01'      | '0'         | 0           | 7          | 0x00                        | 0x7F             | 128                 |
| '10'      | '0'         | 0           | 3          | 0x00                        | 0xFF             | 256                 |
| '00'      | '1'         | 0           | 15         | 0x00                        | 0x7F             | 128                 |
| '01'      | '1'         | 0           | 7          | 0x00                        | 0xFF             | 256                 |

Table 4.2: FIFO size setup

\*: Please note, that any configuration that uses *receive FIFOs beyond the maximum FIFO number* can store data in the RAM. This may destroy data from other FIFOs.

## 4.4 FIFO operation

## Important !

The HDLC controller needs F0IO and either C4IO or C2IO clocks for operation. These clocks are generated from XHFC-1SU if PCM master mode is selected  $(V\_PCM\_MD = '1')$ .

In PCM slave mode (V\_PCM\_MD = '0'), F0IO and either C4IO or C2IO clocks must be feed into these pins (see Figure 6.5 on page 221, signal C4I is required).

## 4.4.1 HDLC transmit FIFOs

Data can be transmitted from the host bus interface to the FIFO with write access to registers A\_FIFO\_DATA and A\_FIFO\_DATA\_NOINC. XHFC-1SU converts the data into HDLC code and tranfers it from the FIFO to the ST/ $U_p$  or the PCM bus interface.

XHFC-1SU checks Z1 and Z2. If Z1 = Z2 (FIFO empty), XHFC-1SU generates a HDLC flag ('0111 1110') or continuous '1's (depending on bit V\_IFF in register A\_CON\_HDLC) and transmits it to the ST/U<sub>p</sub> interface. In this case Z2 is not incremented. If also F1 = F2 only HDLC flags





Figure 4.1: FIFO organization

or continuous '1's are sent to the ST/U<sub>p</sub> interface and all counters remain unchanged. If the frame counters are unequal F2 is incremented and XHFC-1SU tries to transmit the next frame. At the end of a frame (Z2 reaches Z1) it automatically generates the 16 bit CRC checksum and adds an ending flag. If there is another frame in the FIFO ( $F1 \neq F2$ ) the F2 counter is incremented again.

With every byte being written from the host bus side to the FIFO, Z1 is incremented automatically. If a complete frame has been sent into the FIFO F1 must be incremented to transmit the next frame. If the frame counter F1 is incremented the Z-counters may also change because Z1 and Z2 are functions of F1 and F2. Thus there are Z1(F1), Z2(F1), Z1(F2) and Z2(F2) (see Fig. 4.1).

Z1(F1) is used for the frame which is just written from the host bus side. Z2(F2) is used for the frame which is just being transmitted to the PCM or ST/U<sub>p</sub> interface side of XHFC-1SU. Z1(F2) is the end of frame pointer of the current output frame.

In the transmit HFC-channels F1 is only incremented from the host interface side if the software driver wants to say "end of transmit frame". This is done by setting bit V\_INC\_F in register A\_INC\_RES\_FIFO. Then the current value of Z1 is stored, F1 is incremented and Z1 is used as start address of the next frame.

## **4.4.2** Automatic D-channel frame repetition (for S/T in TE mode only)

The D-channel transmit FIFO has a special feature. If the  $ST/U_p$  interface signals a D-channel contention before the CRC is sent the Z2 counter is set to the starting address of the current frame and XHFC-1SU tries to repeat the frame automatically.



## Please note !

XHFC-1SU begins to transmit the bytes from a FIFO at the moment the FIFO is changed (writing  $R_FIFO$ ) or the *F*1 counter is incremented. Switching to the FIFO that is already selected also starts the transmission. Thus by selecting the same FIFO again transmission can be started.



Figure 4.2: FIFO data organization in HDLC mode

## 4.4.3 HDLC receive FIFOs

The receive HFC-channels receive data from the  $ST/U_p$  or PCM bus interface read registers. The data is converted from HDLC into plain data and sent to the FIFO. The data can then be read via the host bus interface.

XHFC-1SU checks the HDLC data coming in. If it finds a flag or more than 5 consecutive '1's it does not generate any output data. In this case Z1 is not incremented. Proper HDLC data being received is converted by XHFC-1SU into plain data. After the ending flag of a frame, XHFC-1SU checks the HDLC CRC checksum. If it is correct one byte with all '0's is inserted behind the CRC data in the FIFO named STAT (see Fig. 4.2). This last byte of a frame in the FIFO is different from all '0's if there is no correct CRC field at the end of the frame.

If the STAT value is 0xFF, the HDLC frame ended with at least 8 bits '1's. This is similar to an abort HDLC frame condition.

The ending flag of a HDLC frame can also be the starting flag of the next frame.

After a frame is received completely, F1 is incremented by XHFC-1SU automatically and the next frame can be received.

After reading a frame via the host bus interface F2 has to be incremented. If the frame counter F2 is incremented also the Z-counters may change because Z1 and Z2 are functions of F1 and F2. Thus there are Z1(F1), Z2(F1), Z1(F2) and Z2(F2) (see Fig. 4.1).

Z1(F1) is used for the frame which is just received from the ST/U<sub>p</sub> interface side of XHFC-1SU.



Z2(F2) is used for the frame which is just beeing transmitted to the host bus interface. Z1(F2) is the end of frame pointer of the current output frame.

To calculate the length of the current receive frame the software has to evaluate Z1 - Z2 + 1. When Z2 reaches Z1 the complete frame has been read.

In the receive HFC-channels F2 must be incremented from the host interface side after the software detects an end of receive frame (Z1 = Z2) and  $F1 \neq F2$ . Then the current value of Z2 is stored, F2 is incremented and Z2 is copied as start address of the next frame. This is done by setting bit V\_INC\_F in register A\_INC\_RES\_FIFO. If Z1 = Z2 and F1 = F2 the FIFO is totally empty. Z1(F1) can not be accessed.

## **Important**!

Before reading a new frame, a change FIFO operation (write access to register R\_FIFO) has to be done even if the desired FIFO is already selected. The change FIFO operation is required to update the internal buffer of XHFC-1SU. Otherwise the first byte of the FIFO will be taken from the internal buffer and may be invalid.

## 4.4.4 Transparent mode of XHFC-1SU

It is possible to switch off the HDLC operation for each FIFO independently by bit V\_HDLC\_TRP in register A\_CON\_HDLC. If this bit is set, data from the FIFO is sent directly to the  $ST/U_p$  or PCM bus interface and data from the  $ST/U_p$  or PCM bus interface is sent directly to the FIFO.

Be sure to switch into transparent mode only if F1 = F2. Being in transparent mode the *F*-counters remain unchanged. Z1 and Z2 are the input and output pointers respectively. Because F1 = F2, the Z-counters are always accessable and have valid data for FIFO input and output.

If a transmit FIFO changes to FIFO empty condition no CRC is generated and the last data byte written into the FIFO is repeated until there is new data.

Normally the last byte is undefined because of the *Z*-counter pointing to a previously unwritten address. To define the last byte, the last write access to the FIFO must be done without *Z* increment (see register A\_FIFO\_DATA\_NOINC).

In receive HFC-channels there is no check on flags or correct CRCs and no status byte added.

Unlike in HDLC mode, where byte synchronization is achieved with HDLC flags, the byte boundaries are not arbitrary. The data is just the same as it comes from or is sent to the  $ST/U_p$  or PCM bus interface.

Transmit and receive transparent data can be done in two ways. The usual way is transporting FIFO data to the  $ST/U_p$  interface with the LSB first as usual in HDLC mode. The second way is transmitting the bytes in reverse bit order as usual for PCM data. So the first bit is the MSB. The bit order can be reversed by setting bit V\_REV in register R\_FIFO when the FIFO is selected.



# Important !

For normal data transmission register A\_SUBCH\_CFG must be set to 0x00. To use 56 kbit/s restricted mode for U.S. ISDN lines, register A\_SUBCH\_CFG must be set to 0x07 for B-channels.



## 4.5 Register description

## 4.5.1 Write only registers

| R_              | _FIRST_F                                                                                                                                                 | IFO            |                  | (w)                      | (Reset group: H, 0, 1)                                                                                                              | 0x0B          |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------|--|--|
| <b>Fi</b><br>Th | <b>First FIFO of the FIFO sequence</b><br>This register is only used in <i>FIFO Sequence Mode</i> , see register R_FIFO_MD for data flow mode selection. |                |                  |                          |                                                                                                                                     |               |  |  |
|                 | Bits                                                                                                                                                     | Reset<br>value | Name             | Ľ                        | escription                                                                                                                          |               |  |  |
|                 | 0                                                                                                                                                        | 0              | V_FIRST_FIFO_DIR | E<br>T<br>iu<br>'(<br>'1 | Pata direction<br>This bit defines the data direction of the<br>h FIFO sequence.<br>' = transmit FIFO data<br>' = receive FIFO data | e first FIFO  |  |  |
|                 | 41                                                                                                                                                       | 0              | V_FIRST_FIFO_NUM | F<br>T<br>tl             | <b>TFO number</b><br>This bitmap defines the number of the ne FIFO sequence.                                                        | first FIFO in |  |  |
|                 | 75                                                                                                                                                       | 0              | (reserved)       | Ν                        | 1ust be '000'.                                                                                                                      |               |  |  |



| R_        | FIFO_TH           | IRES           |                    | (w)          | (Reset group: H, 0, 1, 2, 3)                                                                                                | 0x0C       |
|-----------|-------------------|----------------|--------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------|------------|
| FI        | FO fill lev       | vel contro     | l register         |              |                                                                                                                             |            |
| Th<br>FII | e FIFO fi<br>FOs. | ll level ca    | n be controlled by | a theshold w | which is specified separately for transmit an                                                                               | nd receive |
|           | Bits              | Reset<br>value | Name               |              | Description                                                                                                                 |            |
|           | 30                | 1              | V_THRES_TX         |              | Threshold for all transmit FIFOs<br>The threshold is a multiple of 16 bytes.<br>0 = 0 bytes<br>1 = 16 bytes<br>2 = 32 bytes |            |
|           |                   |                |                    |              | 15 = 240 bytes                                                                                                              |            |

7..41V\_THRES\_RXThreshold for all receive FIFOs<br/>The threshold is a multiple of 16 bytes.<br/>0 = 0 bytes<br/>1 = 16 bytes<br/>0 = 32 bytes<br/> $\dots$ <br/>15 = 240 bytes

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)



| R_       | _FIFO_M             | )              | (                           | <b>w</b> )                                                                                                               | (Reset group: H)                                                                                                                                                                                                                                                                                        | 0x0D                                                             |
|----------|---------------------|----------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| FI       | FO mode             | configura      | tion                        |                                                                                                                          |                                                                                                                                                                                                                                                                                                         |                                                                  |
| Th<br>va | is register<br>lue. | defines th     | e FIFO number and size. The | e actual FIFC                                                                                                            | ) size depends also on the V_UN                                                                                                                                                                                                                                                                         | IIDIR_MD                                                         |
|          | Bits                | Reset<br>value | Name                        | Descript                                                                                                                 | ion                                                                                                                                                                                                                                                                                                     |                                                                  |
|          | 10                  | 0              | V_FIFO_MD                   | <b>FIFO</b> me<br>This bitm<br>organize<br><b>FIFO</b> me<br>'00' = 16<br>'01' = 8 F<br>'10' = 4 F<br>'11' = not         | ode<br>hap and V_UNIDIR_MD are used<br>the FIFOs.<br>ode with V_UNIDIR_RX = '0':<br>FIFOs with 64 bytes for TX and<br>FIFOs with 128 bytes for TX and<br>FIFOs with 256 bytes for TX and<br>t allowed<br>ode with V_UNIDIR_RX = '1':                                                                    | l to<br>l RX each<br>l RX each<br>l RX each<br>l RX each         |
|          |                     |                |                             | '00' = 16<br>each<br>'01' = 8 F<br>'10' = not<br>'11' = not                                                              | FIFOs with 256 bytes for TX and<br>t allowed                                                                                                                                                                                                                                                            | nd RX<br>I RX each                                               |
|          | 32                  | 0              | V_DF_MD                     | <b>Data flov</b><br>'00' = Sin<br>'01' = Ch<br>'10' = not<br>'11' = FL                                                   | w mode selection<br>nple Mode (SM)<br>cannel Select Mode (CSM)<br>t allowed<br>FO Sequence Mode (FSM)                                                                                                                                                                                                   |                                                                  |
|          | 4                   | 0              | V_UNIDIR_MD                 | Unidirec<br>'0' = both<br>(normal d<br>'1' = unic<br>receive F<br>value<br>Unidirec<br>recording<br>Note: Th<br>must not | etional FIFO data direction<br>in transmit and receive FIFOs ava<br>operation), V_UNIDIR_RX is ig<br>directional FIFO mode, either tra<br>FIFOs available due to V_UNIDII<br>tional FIFO data is used for void<br>g, e.g., and has double FIFO size<br>the FIFOs of the unused data dire<br>be enabled. | ilable<br>nored<br>unsmit or<br><b>A_RX</b><br>:e<br>2.<br>ction |
|          | 5                   | 0              | V_UNIDIR_RX                 | FIFO da<br>This bit i<br>(V_UNIC<br>'0' = only<br>'1' = only                                                             | <b>Ita direction</b><br>s only used in unidirectional FII<br>DIR_MD = '1').<br>/ transmit FIFOs available<br>/ receive FIFOs available                                                                                                                                                                  | FO mode                                                          |
|          | 76                  | 0              | (reserved)                  | Must be                                                                                                                  | '00'.                                                                                                                                                                                                                                                                                                   |                                                                  |



| Α_ | A_INC_RES_FIFO [FIFO] |                | FIFO]                | (w)         | (Reset group: H, 0, 1, 2, 3)                                                                                                                                                                                                                                                                                                           | 0x0E                       |  |
|----|-----------------------|----------------|----------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|
| In | crement a             | nd reset ]     | FIFO register        |             |                                                                                                                                                                                                                                                                                                                                        |                            |  |
| Be | fore writin           | ng this arr    | ay register the FIFO | must be sel | ected by register R_FIFO.                                                                                                                                                                                                                                                                                                              |                            |  |
|    | Bits                  | Reset<br>value | Name                 |             | Description                                                                                                                                                                                                                                                                                                                            |                            |  |
|    | 0                     | 0              | V_INC_F              |             | Increment the <i>F</i> -counters of the selected <b>F</b><br>'0' = no increment<br>'1' = increment<br>This bit is automatically cleared after the cour<br>increment has been processed.                                                                                                                                                | ' <b>IFO</b>               |  |
|    | 1                     | 0              | V_RES_FIFO           |             | FIFO reset<br>'0' = no reset<br>'1' = reset selected FIFO ( <i>F</i> - and <i>Z</i> -counters and<br>channel mask A_CH_MSK are reset)<br>This bit is automatically cleared after the FIFO<br>reset has been processed.                                                                                                                 |                            |  |
|    | 2                     | 0              | V_RES_LOST           |             | LOST error bit reset<br>'0' = no reset<br>'1' = reset LOST<br>This bit is automatically cleared with the LOS<br>error bit reset.                                                                                                                                                                                                       | ST                         |  |
|    | 3                     | 0              | V_RES_FIFO_EF        | R           | FIFO error reset<br>'0' = no operation<br>'1' = Resets bit V_FIFO_ERR in register<br>A_FIFO_STA<br>This bit automatically reset to '0' after the FII<br>error reset has been executed.<br>Note: for transmit FIFOs, this bit should be se<br>'1' not before V_ABO_DONE = '1' in register<br>A_FIFO_STA to ensure a completed frame all | FO<br>set to<br>r<br>bort. |  |
|    | 74                    | 0              | (reserved)           |             | Must be '0000'.                                                                                                                                                                                                                                                                                                                        |                            |  |



| R_FIFO | (w) | (Reset group: H, 0, 1) | 0x0F |
|--------|-----|------------------------|------|
|        |     |                        |      |

#### FIFO selection register

This register is used to select a FIFO. Before a FIFO array register can be accessed, this index register must specify the desired FIFO number and data direction.

**Note:** This register is a multi-register. It is selected with bitmap V\_DF\_MD less than '11' in register  $R_FIFO_MD$  (SM and CSM). In FSM (V\_DF\_MD = '11') some FIFO array registers are indexed by the multi-register  $R_FSM_IDX$  instead, but most FIFO array registers remain indexed by this register.

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                               |
|------|----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0              | V_FIFO_DIR | FIFO data direction<br>'0' = transmit FIFO data<br>'1' = receive FIFO data                                                                                                                                                                                |
| 41   | 0              | V_FIFO_NUM | FIFO number                                                                                                                                                                                                                                               |
| 65   | 0              | (reserved) | Must be '00'.                                                                                                                                                                                                                                             |
| 7    | 0              | V_REV      | <b>Bit order</b><br>'0' = LSB first<br>'1' = MSB first<br>LSB first is used in HDLC mode while MSB first<br>is used in transparent mode. The bit order is being<br>reversed for the data written into the FIFO or when<br>the data is read from the FIFO. |

| R_                                                                                                                                                                                                                                        | _FSM_ID                                                                                                                                                                                                                                           | x              |            | (w)    | (Reset group: H, 0, 1)                                   | 0x0F |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------|--------|----------------------------------------------------------|------|--|--|--|
| In                                                                                                                                                                                                                                        | Index register of the FIFO sequence                                                                                                                                                                                                               |                |            |        |                                                          |      |  |  |  |
| This register is used to select a list number in <i>FIFO Sequence Mode</i> . Some FIFO array registers are indexed by this list number. Before these registers can be accessed, this index register must specify the desired list number. |                                                                                                                                                                                                                                                   |                |            |        |                                                          |      |  |  |  |
| No<br>In<br>rei                                                                                                                                                                                                                           | <b>Note:</b> This register is a multi-register. It is selected with bitmap V_DF_MD = '11' in register R_FIFO_MD. In FSM only few FIFO array registers are indexed by this multi-register, but most FIFO array registers remain indexed by R_FIFO. |                |            |        |                                                          |      |  |  |  |
|                                                                                                                                                                                                                                           | Bits                                                                                                                                                                                                                                              | Reset<br>value | Name       | D      | escription                                               |      |  |  |  |
|                                                                                                                                                                                                                                           | 40                                                                                                                                                                                                                                                | 0x00           | V_IDX      | L<br>T | <b>ist index</b><br>he list index must be in the range 0 | 31.  |  |  |  |
|                                                                                                                                                                                                                                           | 75                                                                                                                                                                                                                                                | 0              | (reserved) | Ν      | lust be '000'.                                           |      |  |  |  |



## 4.5.2 Read only registers

| <b>A</b> _                                                                             | <b>_Z1</b> [FIFO | ]              |                               | ( <b>r</b> ) | (Reset group: H, 0, 1)                                                                         | 0x04 |
|----------------------------------------------------------------------------------------|------------------|----------------|-------------------------------|--------------|------------------------------------------------------------------------------------------------|------|
| <b>FIFO input counter</b> <i>Z</i> 1<br>Before reading this array register the FIFO mu |                  |                | 1<br>ay register the FIFO mus | t be sele    | cted by register R_FIFO.                                                                       |      |
|                                                                                        | Bits             | Reset<br>value | Name                          |              | Description                                                                                    |      |
|                                                                                        | 70               |                | V_Z1                          |              | <b>Counter value of</b> $Z1$<br>The reset value is $Z_{max}$ and depends on the configuration. | FIFO |

(See Table 4.2 for reset value.)

| A                                                                                                                                 | _ <b>Z2</b> [FIFO | )]             |      | (r)                       | (Reset group: H, 0, 1)                                                                      | 0x06        |
|-----------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------|------|---------------------------|---------------------------------------------------------------------------------------------|-------------|
| <b>FIFO output counter</b> <i>Z</i> 2<br>Before reading this array register the FIFO must be selected by register <b>R_FIFO</b> . |                   |                |      | ected by register R_FIFO. |                                                                                             |             |
|                                                                                                                                   | Bits              | Reset<br>value | Name |                           | Description                                                                                 |             |
|                                                                                                                                   | 70                |                | V_Z2 |                           | <b>Counter value of</b> $Z^2$<br>The reset value is $Z_{max}$ and depends<br>configuration. | on the FIFO |

(See Table 4.2 for reset value.)

| Α_       | _ <b>F1</b> [FIFC                                                                                                             | D]             |      | ( <b>r</b> ) | (Reset group: H, 0, 1)                           | 0x0C               |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------|----------------|------|--------------|--------------------------------------------------|--------------------|--|
| FI<br>Be | <b>FIFO input HDLC frame counter</b> $F1$<br>Before reading this array register the FIFO must be selected by register R_FIFO. |                |      |              |                                                  |                    |  |
|          | Bits                                                                                                                          | Reset<br>value | Name | Ε            | Description                                      |                    |  |
|          | 70                                                                                                                            | 7              | V_F1 | (<br>L       | Counter value<br>Ip to 7 HDLC frames can be stor | red in every FIFO. |  |



| Α_       | _ <b>F2</b> [FIFO                                                                                                              | )]             |      | ( <b>r</b> ) | (Reset group: H, 0, 1)                             | 0x0D       |  |
|----------|--------------------------------------------------------------------------------------------------------------------------------|----------------|------|--------------|----------------------------------------------------|------------|--|
| FI<br>Be | <b>FIFO output HDLC frame counter</b> $F2$<br>Before reading this array register the FIFO must be selected by register R_FIFO. |                |      |              |                                                    |            |  |
|          |                                                                                                                                | 0              |      |              | , ,                                                |            |  |
|          | Bits                                                                                                                           | Reset<br>value | Name | De           | scription                                          |            |  |
|          |                                                                                                                                |                |      |              |                                                    |            |  |
|          | 70                                                                                                                             | 7              | V_F2 | Co<br>Up     | unter value<br>to 7 HDLC frames can be stored in e | very FIFO. |  |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)



| Α_ | _FIFO_ST                                                                         | A [FIFO]       |            | ( <b>r</b> ) | (Reset group: H, 0, 1)                                                                                                                                                                                                                                                                                                                     | 0x0E                                                   |  |
|----|----------------------------------------------------------------------------------|----------------|------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--|
| FL | FIFO status register                                                             |                |            |              |                                                                                                                                                                                                                                                                                                                                            |                                                        |  |
| Be | Before reading this array register the FIFO must be selected by register R_FIFO. |                |            |              |                                                                                                                                                                                                                                                                                                                                            |                                                        |  |
|    | Bits                                                                             | Reset<br>value | Name       |              | Description                                                                                                                                                                                                                                                                                                                                |                                                        |  |
|    | 0                                                                                | 0              | V_FIFO_ERR |              | FIFO errorThis status bit has different meaning for transmand receive FIFOs.Transmit FIFO: There are two different situat<br>for a FIFO to run empty.(1) A valid HDLC frame has been sent when the<br>FIFO runs empty at the end of a frame and<br>$F1 = F2$ gets true after Z2 increment.(2) An invalid HDLC frame has been sent when<br> | nit<br>tions<br>he<br>F2<br>an<br>he<br>licate<br>ne). |  |
|    | 31                                                                               |                | (reserved) |              |                                                                                                                                                                                                                                                                                                                                            |                                                        |  |
|    | 4                                                                                | 0              | V_ABO_DONE |              | Frame abort done<br>This status bit is only used for transmit FIFOs<br>is not defined for receive FIFOs.<br>This bit is set after sixteen consecutive '1's hav<br>been transmitted. It is reset together with<br>V_FIFO_ERR.                                                                                                               | and<br>7e                                              |  |
|    | 75                                                                               |                | (reserved) |              |                                                                                                                                                                                                                                                                                                                                            |                                                        |  |
|    |                                                                                  |                |            |              |                                                                                                                                                                                                                                                                                                                                            |                                                        |  |



| A_USAGE [FIFO]                                                          |      |                |                          | ( <b>r</b> ) | (Reset group: H, 0, 1)                                                                               | 0x14                  |
|-------------------------------------------------------------------------|------|----------------|--------------------------|--------------|------------------------------------------------------------------------------------------------------|-----------------------|
| <b>FIFO fill level</b><br>Before reading this array register the FIFO n |      |                | ay register the FIFO mus | t be select  | ted by register R_FIFO.                                                                              |                       |
|                                                                         | Bits | Reset<br>value | Name                     | D            | Description                                                                                          |                       |
|                                                                         | 70   | 0x00           | V_USAGE                  | N<br>T<br>01 | <b>Tumber of bytes currently stored in the</b><br>The FIFO is empty when this register has a<br>x00. | <b>FIFO</b> the value |

| R_FILL_BL0 | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x24 |
|------------|--------------|------------------------|------|
|------------|--------------|------------------------|------|

| Bits | Reset<br>value | Name            | Description           |
|------|----------------|-----------------|-----------------------|
| 0    | 0              | V_FILL_FIFO0_TX | FIFO[0,TX] fill level |
| 1    | 0              | V_FILL_FIFO0_RX | FIFO[0,RX] fill level |
| 2    | 0              | V_FILL_FIFO1_TX | FIFO[1,TX] fill level |
| 3    | 0              | V_FILL_FIFO1_RX | FIFO[1,RX] fill level |
| 4    | 0              | V_FILL_FIFO2_TX | FIFO[2,TX] fill level |
| 5    | 0              | V_FILL_FIFO2_RX | FIFO[2,RX] fill level |
| 6    | 0              | V_FILL_FIFO3_TX | FIFO[3,TX] fill level |
| 7    | 0              | V_FILL_FIFO3_RX | FIFO[3,RX] fill level |



| R_FILL_BL1 | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x25 |
|------------|--------------|------------------------|------|
|            |              |                        |      |

| Bits | Reset<br>value | Name            | Description           |
|------|----------------|-----------------|-----------------------|
| 0    | 0              | V_FILL_FIFO4_TX | FIFO[4,TX] fill level |
| 1    | 0              | V_FILL_FIFO4_RX | FIFO[4,RX] fill level |
| 2    | 0              | V_FILL_FIFO5_TX | FIFO[5,TX] fill level |
| 3    | 0              | V_FILL_FIFO5_RX | FIFO[5,RX] fill level |
| 4    | 0              | V_FILL_FIFO6_TX | FIFO[6,TX] fill level |
| 5    | 0              | V_FILL_FIFO6_RX | FIFO[6,RX] fill level |
| 6    | 0              | V_FILL_FIF07_TX | FIFO[7,TX] fill level |
| 7    | 0              | V_FILL_FIFO7_RX | FIFO[7,RX] fill level |



| R_FILL_BL2 | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x26 |
|------------|--------------|------------------------|------|
|------------|--------------|------------------------|------|

| Bits | Reset<br>value | Name             | Description            |
|------|----------------|------------------|------------------------|
| 0    | 0              | V_FILL_FIFO8_TX  | FIFO[8,TX] fill level  |
| 1    | 0              | V_FILL_FIFO8_RX  | FIFO[8,RX] fill level  |
| 2    | 0              | V_FILL_FIFO9_TX  | FIFO[9,TX] fill level  |
| 3    | 0              | V_FILL_FIFO9_RX  | FIFO[9,RX] fill level  |
| 4    | 0              | V_FILL_FIFO10_TX | FIFO[10,TX] fill level |
| 5    | 0              | V_FILL_FIFO10_RX | FIFO[10,RX] fill level |
| 6    | 0              | V_FILL_FIFO11_TX | FIFO[11,TX] fill level |
| 7    | 0              | V_FILL_FIFO11_RX | FIFO[11,RX] fill level |



| R_FILL_BL3 | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x27 |
|------------|--------------|------------------------|------|
|            |              |                        |      |

| Bits | Reset<br>value | Name             | Description            |
|------|----------------|------------------|------------------------|
| 0    | 0              | V_FILL_FIFO12_TX | FIFO[12,TX] fill level |
| 1    | 0              | V_FILL_FIFO12_RX | FIFO[12,RX] fill level |
| 2    | 0              | V_FILL_FIFO13_TX | FIFO[13,TX] fill level |
| 3    | 0              | V_FILL_FIFO13_RX | FIFO[13,RX] fill level |
| 4    | 0              | V_FILL_FIFO14_TX | FIFO[14,TX] fill level |
| 5    | 0              | V_FILL_FIFO14_RX | FIFO[14,RX] fill level |
| 6    | 0              | V_FILL_FIFO15_TX | FIFO[15,TX] fill level |
| 7    | 0              | V_FILL_FIFO15_RX | FIFO[15,RX] fill level |


### 4.5.3 Read/write registers

| A                                                                                                     | _FIFO_D | ATA [FIFO      | ]           | ( <b>r/w</b> )                      | (Reset group: -)                                                                         | 0x80                       |
|-------------------------------------------------------------------------------------------------------|---------|----------------|-------------|-------------------------------------|------------------------------------------------------------------------------------------|----------------------------|
| FIFO data register<br>Before writing or reading this array register the FIFO must be selected by regi |         |                |             | selected by register R_FIFO.        |                                                                                          |                            |
|                                                                                                       | Bits    | Reset<br>value | Name        | Descr                               | iption                                                                                   |                            |
|                                                                                                       | 70      |                | V_FIFO_DATA | <b>Data</b><br>Read<br>with r<br>1. | <b>byte</b><br>Write one byte from / to the FIF<br>egister <b>R_FIFO</b> and increment 2 | O selected<br>Z-counter by |

| A_FIFO_DATA_NOINC [FIFO]                                                         |      | (r/w)           | (Reset group: -)                | 0x84                               |                                                                                                            |          |  |
|----------------------------------------------------------------------------------|------|-----------------|---------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------|----------|--|
| <b>FIFO data register</b><br>Before writing or reading this array register the H |      | FIFO must l     | be selected by register R_FIFO. |                                    |                                                                                                            |          |  |
|                                                                                  | Bits | Bits Reset Name |                                 | Description                        |                                                                                                            |          |  |
|                                                                                  | 70   |                 | V_FIFO_DATA_NOINC               | C Data<br>Write<br>select<br>incre | a byte<br>the one byte to or read one byte from<br>the with register R_FIFO without<br>ementing Z-counter. | the FIFO |  |

(This register can be used to store the last FIFO byte in transparent transmit mode. Then this byte is repeately transmitted.)



| A.                                                                                       | _CH_MSI                                                                                                           | (FIFO]         |          | ( <b>r*/w</b> )                       | (Reset group: H, 0, 1)                                                                                                                                                                                                        | 0xF4                                   |  |
|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|----------------|----------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|
| H<br>Fo                                                                                  | <b>HFC-channel data mask for the selected transmit HFC-channel</b><br>For receive FIFOs this register is ignored. |                |          |                                       |                                                                                                                                                                                                                               |                                        |  |
| Before writing this array register, the HFC-channel must be selected by register R_FIFO. |                                                                                                                   |                |          |                                       |                                                                                                                                                                                                                               |                                        |  |
|                                                                                          | Bits                                                                                                              | Reset<br>value | Name     | me Description                        |                                                                                                                                                                                                                               |                                        |  |
|                                                                                          | 70                                                                                                                | 0xFF           | V_CH_MSK | M<br>Th<br>bi<br>HI<br>re<br>Th<br>V_ | ask byte<br>is bitmap defines bit values for not p<br>s of a HFC-channel. All not processe<br>C-channel are set to the value define<br>sister.<br>is register has only a meaning when<br>BIT_CNT $\neq 0$ in register A_SUBCH | rocessed<br>ed bits of a<br>ed in this |  |



| Α_ | A_CON_HDLC [FIFO] |                |                         | (r*/w)      | (Reset group: H, 0, 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0xFA                                                                                                                                                |
|----|-------------------|----------------|-------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| н  | DLC and o         | connectio      | n settings of the selec | ted FIFO    | )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                     |
| Ве | fore writin       | ig this arra   | ay register the FIFO m  | ust be sele | ected by register R_FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                     |
|    | Bits              | Reset<br>value | Name                    |             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                     |
|    | 0                 | 0              | V_IFF                   |             | Inter frame fill<br>'0' = write HDLC flags 0x7E as inter fra<br>'1' = write all '1's as inter frame fill<br>Note: For D-channel this bit must be '1'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | me fill                                                                                                                                             |
|    | 1                 | 0              | V_HDLC_TRP              |             | HDLC mode / transparent mode select<br>'0' = HDLC mode<br>'1' = transparent mode<br>Note: For D-channel this bit must be '0'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | tion                                                                                                                                                |
|    | 42                | 0              | V_FIFO_IRQ              |             | <b>FIFO interrupt configuration</b><br>This bitmap has a different meaning in H<br>transparent mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HDLC and                                                                                                                                            |
|    |                   |                |                         |             | <b>Transparent mode (V_HDLC_TRP = '</b><br>The FIFO is enabled with any value $\neq 0$<br>interrupt is generated all $2^n$ bytes when<br>[n-1:0] of the Z2-counter (in transmit di<br>the Z1-counter (in receive direction) cha<br>all '1's to all '0's. $n = V_FIFO_IRQ + 2$ .<br>0 = FIFO disabled, no interrupt<br>$1 = FIFO$ enabled, all $2^3 = 8$ bytes an in<br>generated<br>$2 = FIFO$ enabled, all $2^4 = 16$ bytes an i<br>generated<br>$3 = FIFO$ enabled, all $2^5 = 32$ bytes an i<br>generated<br>$4 = FIFO$ enabled, all $2^6 = 64$ bytes an i<br>generated<br>$5 = FIFO$ enabled, all $2^7 = 128$ bytes an<br>is generated<br>6 7 = FIFO enabled, no interrupt | 1'):<br>A FIFO<br>the bits<br>rection) or<br>ange from<br>ange from<br>anterrupt is<br>interrupt is<br>interrupt is<br>interrupt is<br>interrupt is |
|    |                   |                |                         |             | HDLC mode (V_HDLC_TRP = '0'):<br>The FIFO is enabled with any value $\neq 0$<br>interrupt can be generated at end of fram<br>0 = FIFO disabled, no interrupt<br>17 = FIFO enabled, interrupt enabled<br><b>Note:</b> When mixed interrupt generation<br>with V_MIX_IRQ = '1' in register A_FIF<br>FIFO interrupts occur at end of frame as<br>after $2^n$ bytes.                                                                                                                                                                                                                                                                                                               | <ul> <li>A FIFO</li> <li>ne.</li> <li>is selected</li> <li>O_CTRL,</li> <li>s well as</li> </ul>                                                    |
|    |                   |                |                         |             | <b>Note:</b> A FIFO must be enabled even for connections between line interface and I interface. No data transmission is perfor disabled FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCM<br>rmed with                                                                                                                                    |



(continued from previous page)

| Bits | Reset<br>value | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|------|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 75   | 0              | V_DATA_FLOW | <b>Data flow configuration</b><br>In transmit operation (V_FIFO_DIR = '0' in register R_FIFO):<br>'000', '001' = FIFO $\rightarrow$ ST/U <sub>p</sub> , FIFO $\rightarrow$ PCM<br>'100', '011' = FIFO $\rightarrow$ PCM<br>'100', '101' = FIFO $\rightarrow$ ST/U <sub>p</sub> , ST/U <sub>p</sub> $\rightarrow$ PCM<br>'110', '111' = ST/U <sub>p</sub> $\rightarrow$ PCM<br>In receive operation (V_FIFO_DIR = '1' in register R_FIFO):<br>'000', '100' = FIFO $\leftarrow$ ST/U <sub>p</sub><br>'001', '101' = FIFO $\leftarrow$ PCM<br>'010', '110' = FIFO $\leftarrow$ ST/U <sub>p</sub> , ST/U <sub>p</sub> $\leftarrow$ PCM<br>'010', '110' = FIFO $\leftarrow$ ST/U <sub>p</sub> , ST/U <sub>p</sub> $\leftarrow$ PCM<br>'011', '111' = FIFO $\leftarrow$ PCM, ST/U <sub>p</sub> $\leftarrow$ PCM<br>Note: ST/U <sub>p</sub> $\leftrightarrow$ PCM configurations use<br>V_FIFO_IRQ to enable the data transmission, i.e.<br>V_FIFO_IRQ must not be zero. As received<br>PCM-to-ST/U <sub>p</sub> data is stored in the FIFO,<br>interrupt generation can be used. ST/U <sub>p</sub> -to-PCM<br>data transmission is connected to a transmit FIFO<br>and here no interrupt capability is available. |  |  |



| A_SUBCH_CFG [FIFO] |                                                                                  |            |                          | (r*/w)                                                                              | (Reset group: H, 0, 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0xFB                                                                                           |  |
|--------------------|----------------------------------------------------------------------------------|------------|--------------------------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|--|
| Su                 | Subchannel parameters for bit processing of the selected FIFO                    |            |                          |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                |  |
| Ве                 | Before writing this array register the FIFO must be selected by register R_FIFO. |            |                          |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                |  |
| No                 | ote: For D                                                                       | - and E-ch | nannels this register mu | ust be 0x02.                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                |  |
| Resot              |                                                                                  |            |                          |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                |  |
|                    | Bits                                                                             | value      | Name                     | De                                                                                  | escription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                |  |
|                    | 20                                                                               | 0          | V_BIT_CNT                | Nu<br>HI<br>In<br>frc<br>alv<br>on<br>'00<br>'00<br>'01<br>'01<br>'10<br>'11<br>'11 | imber of bits to be processed in theFC-channel byteHDLC mode, only this number of bitsmor written into the FIFO. In transpression ways a whole FIFO byte is read or writevays a whole FIFO byte is read or writevays a whole FIFO byte is read or writevays a whole FIFO byte is read or writevalue by V_BIT_CNT bits contain valid datevalue by 00° = process 8 bits (64 kbit/s)value by 01° = process 1 bit (8 kbit/s)value by 01° = process 2 bits (16 kbit/s)value by 01° = process 3 bits (24 kbit/s)value by 01° = process 4 bits (32 kbit/s)value by 01° = process 5 bits (40 kbit/s)value by 01° = process 6 bits (48 kbit/s)value by 01° = process 7 bits (56 kbit/s) | ts is read<br>parent mode<br>ritten, but<br>ta.                                                |  |
|                    | 53                                                                               | 0          | V_START_BIT              | Sta<br>Th<br>the<br>po<br>V_<br>tha<br>HI<br>pro<br>pro                             | art bit in the HFC-channel byte<br>is bitmap specifies the position of the<br>HFC-channel byte. The bit field is I<br>sition V_START_BIT in the HFC-ch<br>_BIT_CNT + V_START_BIT must no<br>an 7 to get the bit field completely ins<br>FC-channel byte. Any value greater to<br>bouces an undefined behavior of the specessor.                                                                                                                                                                                                                                                                                                                                                | e bit field in<br>ocated at<br>annel byte.<br>ot be greater<br>side the<br>han 7<br>subchannel |  |
|                    | 6                                                                                | 0          | V_LOOP_FIFO              | FI<br>'0'<br>'1'<br>tra<br>No                                                       | FO loop<br>= normal operation<br>= repeat current FIFO data (useful o<br>nsparent mode)<br>ote: This bit is ignored for receive FI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nly in<br>FOs.                                                                                 |  |
|                    | 7                                                                                | 0          | V_INV_DATA               | <b>Im</b><br>'0'<br>'1'                                                             | verted data<br>= normal data transmission<br>= inverted data transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                |  |



| A_CHANNEL [FIFO] |                                                                           |                |                        | (r*/w)                                    | (Reset group: H, 0, 1)                                                                                                                                                                                                     | 0xFC                               |
|------------------|---------------------------------------------------------------------------|----------------|------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| H                | HFC-channel assignment for the selected FIFO                              |                |                        |                                           |                                                                                                                                                                                                                            |                                    |
| Th               | This register is only used in Channel Select Mode and FIFO Sequence Mode. |                |                        |                                           |                                                                                                                                                                                                                            |                                    |
| Ве               | efore writi                                                               | ng this arr    | ay register the FIFO m | ust be selecte                            | d by register R_FIFO.                                                                                                                                                                                                      |                                    |
|                  | Bits                                                                      | Reset<br>value | Name                   | De                                        | scription                                                                                                                                                                                                                  |                                    |
|                  | 0                                                                         | 0              | V_CH_FDIR              | H)<br>'0'<br>'1'<br><b>R(</b><br>as<br>A_ | FC-channel data direction<br>= HFC-channel for transmit data<br>= HFC-channel for receive data<br>set value: This bitmap is reset to the<br>the current FIFO, i.e. V_CH_FDIR of<br>_CHANNEL[number, direction] = direction | same value<br>f<br><i>ection</i> . |
|                  | 41                                                                        | 0              | V_CH_FNUM              | H1<br>(0<br>R6<br>as<br>A_                | FC-channel number<br>15)<br>set value: This bitmap is reset to the<br>the current FIFO, i.e. V_CH_FNUM<br>CHANNEL[number, direction] = num                                                                                 | same value<br>of<br><i>iber</i> .  |
|                  | 75                                                                        |                | (reserved)             | М                                         | ust be '000' when written.                                                                                                                                                                                                 |                                    |



| A_FIFO_SEQ [FIFO]                                                              |                                                   |   |                 | (r*/w)      | (Reset group: H, 0, 1)                                                                                                                                                                                                                                                                    | 0xFD                                       |  |
|--------------------------------------------------------------------------------|---------------------------------------------------|---|-----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|--|
| FI                                                                             | FIFO sequence list                                |   |                 |             |                                                                                                                                                                                                                                                                                           |                                            |  |
| Th                                                                             | This register is only used in FIFO Sequence Mode. |   |                 |             |                                                                                                                                                                                                                                                                                           |                                            |  |
| Before writing this array register the FIFO must be selected by register R_FIF |                                                   |   |                 |             | ected by register R_FIFO.                                                                                                                                                                                                                                                                 |                                            |  |
| Bits Reset value Name Description                                              |                                                   |   |                 | Description |                                                                                                                                                                                                                                                                                           |                                            |  |
|                                                                                | 0                                                 | 0 | V_NEXT_FIFO_DIR |             | FIFO data direction<br>This bit defines the data direction of the n<br>in FIFO sequence.<br>'0' = transmit FIFO data<br>'1' = receive FIFO data<br><b>Reset value:</b> This bitmap is reset to the sa<br>as the current FIFO, i.e. V_NEXT_FIFO_<br>A_FIFO_SEQ[number, direction] = direct | ext FIFO<br>ame value<br>_DIR of<br>ction. |  |
|                                                                                | 41                                                | 0 | V_NEXT_FIFO_NUM | Λ           | FIFO number<br>This bitmap defines the FIFO number of t<br>FIFO in the FIFO sequence.<br>Reset value: This bitmap is reset to the sa<br>as the current FIFO, i.e. V_NEXT_FIFO_<br>A_FIFO_SEQ[ <i>number</i> , <i>direction</i> ] = <i>numb</i>                                            | he next<br>ame value<br>_NUM of<br>ber.    |  |
|                                                                                | 5                                                 |   | (reserved)      |             | Must be '0' when written.                                                                                                                                                                                                                                                                 |                                            |  |
|                                                                                | 6                                                 | 0 | V_SEQ_END       |             | End of FIFO list<br>'0' = FIFO list goes on<br>'1' = FIFO list is terminated after this FIFO<br>(V_NEXT_FIFO_DIR and V_NEXT_FIFO<br>are ignored)                                                                                                                                          | O<br>O_NUM                                 |  |
|                                                                                | 7                                                 |   | (reserved)      |             | Must be '0' when written.                                                                                                                                                                                                                                                                 |                                            |  |



| A_FIFO_CTRL [FIFO] |                 |              | ]                       | (r*/w)      | (Reset group: H, 0, 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0xFF                                                           |
|--------------------|-----------------|--------------|-------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Co                 | ontrol regi     | ster for th  | ne selected FIFO        |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |
| Be                 | fore writin     | ng this arra | ny register the FIFO mu | ust be sele | cted by register R_FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                |
|                    | Bits Reset Name |              |                         | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                |
|                    | 0               | 0            | V_FIFO_IRQMSK           |             | Interrupt mask for the selected FIFO<br>'0' = The FIFO interrupt is not used for gen<br>a signal on the interrupt pin 14. The interru<br>status can be read from registers<br>R_FIFO_BL0_IRQR_FIFO_BL3_IRQ<br>nevertheless.<br>'1' = The FIFO interrupt event generates a s<br>on the interrupt pin 14.<br>Note: In addition to this interrupt mask, FII<br>interrupt must be enabled globally with<br>V_FIFO_IRQ_EN = '1' in register R_IRQ_                                                                              | erating<br>pt<br>ignal<br>FO<br>_CTRL.                         |
|                    | 1               | 0            | V_BERT_EN               |             | <b>BERT enable</b><br>'0' = BERT disabled, normal data is transmi<br>and received<br>'1' = BERT enabled, output of BERT genera<br>transmitted and received data is checked by                                                                                                                                                                                                                                                                                                                                              | itted<br>ator is<br>BERT                                       |
|                    | 2               | 0            | V_MIX_IRQ               |             | <b>Mixed interrupt generation in HDLC mo</b><br>This bit is only used in HDLC mode and it<br>be '0' in transparent mode.<br>'0' = FIFO interrupts are generated either on<br><i>frame</i> (in HDLC mode) or periodically (in<br>transparent mode)<br>'1' = FIFO interrupts are generated both on<br><i>frame</i> and periodically when the bits [n-1:0<br>Z2-counter (in transmit direction) or the<br>Z1-counter (in receive direction) change fro<br>'1's to all '0's ( $n = V_{FIFO_{IRQ}} + 3$ in regis<br>A_CON_HDLC) | ode<br>should<br>a <i>end of</i><br>] of the<br>om all<br>ster |



(continued from previous page)

|      | Deget |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits | value | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3    | 0     | V_FR_ABO   | <ul> <li>Frame abort This bit has a different meaning for transmit and receive FIFOs. </li> <li>Transmit FIFO (FIFO underrun indication): When the selected transmit FIFO runs empty within a frame, a frame abort can be generated, i.e. at least sixteen consecutive '1's are transmitted. The receiver gets an invalid frame in this case. '0' = no frame abort after FIFO empty '1' = generate frame abort when FIFO runs empty within a frame (Z1 = Z2 and already F1 = F2, F-increment cannot be executed) Empty FIFO condition can be watched with bit V_FIFO_ERR in register A_FIFO_STA. </li> <li>Receive FIFO (aborted frame received): When the HDLC controller of the selected receive FIFO gets seven or more consecutive '1's, a frame abort condition can be signaled. '0' = no frame abort indication, FIFO status byte indicates only CRC error with any value not equal to 0x00 '1' = frame abort is indicated with FIFO status byte 0xFF, any other FIFO status byte 0x010xFE indicates a CRC error Note: V_FR_ABO should be '0' in transparent mode.</li></ul> |
| 4    | 0     | V_NO_CRC   | Suppress CRC transmission<br>'0' = CRC is transmitted at the end of a frame<br>(normal operation)<br>'1' = CRC bytes are not transmitted at the end of a<br>frame (must be done by the host processor instead)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5    | 0     | V_NO_REP   | No automatic repetition on HDLC frames<br>(D-channel)<br>'0' = After D-channel contention, the frame is<br>automatically repeated<br>'1' = After D-channel ontention, the frame is not<br>repeated and it is aborted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 76   |       | (reserved) | Must be '00' when written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|      |       |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |





## Chapter 5

# **Universal ISDN Port**

| Write only | y registers: |      | Read only registers: |             |      |  |
|------------|--------------|------|----------------------|-------------|------|--|
| Address    | Name         | Page | Address              | Name        | Page |  |
| 0x30       | R_SU_WR_STA  | 188  | 0x30                 | R_SU_RD_STA | 203  |  |
| 0x31       | R_SU_CTRL0   | 189  | 0x31                 | R_SU_DLYL   | 204  |  |
| 0x32       | R_SU_CTRL1   | 191  | 0x32                 | R_SU_DLYH   | 205  |  |
| 0x33       | R_SU_CTRL2   | 192  | 0x34                 | R_MS_RX     | 206  |  |
| 0x34       | R_MS_TX      | 194  | 0x35                 | R_SU_STA    | 207  |  |
| 0x35       | R_ST_CTRL3   | 195  | 0x3C                 | R_B1_RX     | 208  |  |
| 0x35       | R_UP_CTRL3   | 196  | 0x3D                 | R_B2_RX     | 208  |  |
| 0x36       | R_MS_DF      | 198  | 0x3E                 | R_D_RX      | 209  |  |
| 0x37       | R_SU_CLK_DLY | 199  | 0x3F                 | R_E_RX      | 210  |  |
| 0x3C       | R_B1_TX      | 200  |                      |             |      |  |
| 0x3D       | R_B2_TX      | 200  |                      |             |      |  |
| 0x3E       | R_D_TX       | 201  |                      |             |      |  |
| 0x3F       | R_BAC_S_TX   | 202  |                      |             |      |  |

**Table 5.1:** Overview of the  $ST/U_p$  interface registers



## 5.1 General overview of the S/T and $U_p$ interface

The Universal ISDN Port consists of a line interface with both S/T and  $U_p$  signaling capability. It can be configured to TE or NT/LT mode.

### 5.1.1 Multiregisters

The line interface can be switched either into S/T or  $U_p$  mode; so it is called *Universal ISDN Port*. For both modes there is a complete set of registers. These registers are multi-registers, which means they have the same address and I/O functionality (write or read) but different meaning or bitmap structure. Yet, most of them are very similar in S/T and  $U_p$  mode.

## Important !

The Universal ISDN Port is in S/T mode after reset. When  $U_p$  mode is required, it should be selected after reset, i.e. no other register of the line interface module should be written before.

#### 5.1.2 Block diagram of the Universal ISDN Port module

The line interface module consists of the receive and transmit data pathes with a clock processing unit each, the clock distribution unit and the state machine. The overall connections of these units are shown in Figure 5.1.





Figure 5.1: Overview of the Universal ISDN Port module



## 5.2 S/T interface description

#### 5.2.1 Overview

The Universal ISDN Port is able to provide an S/T line interface in TE or NT mode according to ITU-T I.430 [9] and ETSI TBR 003[4] specifications.

The line interface is a four-wire interface and has separated transmitter and receiver with configurable behaviour. The ISDN data frame structure is handled by hardware. Thus plain data is processed on the host side of the S/T interface.

A specification conform state machine for TE and NT mode is implemented (see Section 5.2.6).

The S/T interface uses the modified AMI coding for input and output signals. This pseudo-ternary coding converts logical ones to 0 V level. Logical zeros are coded by alternating positive and negative voltage with 750 mV nominal amplitude on the line.

#### 5.2.2 Frame Structure

The frame structures on the S/T interface are different for each direction of transmission. Both structures are illustrated in Figure 5.2. The raw data bit rate is 192 kBit/s in transmit and receive direction.

HDLC B-channel data starts with the LSB, PCM B-channel data starts with the MSB.



Figure 5.2: Frame structure at reference points S and T (see legend in Table 5.2 and specification [9])

The nominal 2 bit offset is as seen from the TE in Figure 5.2. The offset can be adjusted for TE mode with bitmap V\_SU\_CLK\_DLY in register R\_SU\_CLK\_DLY. The corresponding offset at the NT is not fixed and may be greater due to delay in the interface cable and varies by configuration.

The TE-to-NT transmission has 10 balancing bits within every frame to achieve independent DC balanced parts for different TEs. This is indicated by lines below the frame structure in Figure 5.2.

In the NT-to-TE direction there is only one real DC-balance bit at the end of the frame because all data comes from the same source. Another L-bit at the beginning of the frame belongs to the preceding F-bit and is used for code violation.



| NT-to-         | TE & TE-to-NT:                                                                                                                                                        | NT-to-TE only: |                                                                                                      |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------------------------------------------------------------------------------------------|--|--|
| Code           | Description                                                                                                                                                           | Code           | Description                                                                                          |  |  |
| F              | Framing bit, marks the start of the frame (1 bit/frame)                                                                                                               | Е              | Bit within the E-channel (D-echo-<br>channel, 4 bit/frame)                                           |  |  |
| B1             | Bit within the B1-channel (2 byte/frame)                                                                                                                              | М              | Multiframing bit, marks the start of                                                                 |  |  |
| B2             | Bit within the B2-channel (2 byte/frame)                                                                                                                              |                | the multiframe in every 20th fram<br>(1 bit/frame)                                                   |  |  |
| D              | Bit within the D-channel (4 bit/frame)                                                                                                                                |                |                                                                                                      |  |  |
| L              | DC balancing bit (NT-to-TE: 2 bit/frame,                                                                                                                              | N              | Boolean complementation of the auxil-<br>iary framing bit $F_A$ , $N = \overline{F}_A$ (1 bit/frame) |  |  |
|                |                                                                                                                                                                       | S              | S-bit of the multiframe (1 bit/frame)                                                                |  |  |
| $\mathbf{F}_A$ | N1-to-1E: Auxiliary framing bit, marks the<br>start of subchannel 1 in every 5th frame, a<br>multiframe bit (S-bit) is transmitted in the<br>same frame (1 bit/frame) | А              | Activation bit (1 bit/frame)                                                                         |  |  |
|                | TE-to-NT: Q-bit of the multiframe (1 bit/frame)                                                                                                                       |                |                                                                                                      |  |  |

 Table 5.2: Legend for Figure 5.2

#### 5.2.3 Multiframe structure

There is a higher frame structure called *multiframe*. A multiframe has the length of 4 bits and consists of the bits Q1, Q2, Q3 and Q4 (TE-to-NT) or S1, S2, S3 and S4 (NT-to-TE). Q1 and S1 are transmitted first. As there is one multiframe bit transferred every fifth 250 µs cycle, a complete multiframe is transferred every 5 ms. This means that a multiframe has a length of 20 S/T frames.

The  $F_{A}$ - and M-bits are used to identify the multiframes. Table 5.3 shows the position of the multiframe bits. A detailed specification of the multiframe structure is given in [9].

Multiframe transmission must be enabled with  $V_ST_SQ_EN = '1'$  in register  $R_SU_CTRL0$ .

#### 5.2.4 Data transmission

B-channel data on the line interface must be enabled for transmit and receive direction separately.

 $V_B1_TX_EN = '1'$  in register  $R_SU_CTRL0$  enables data transmission for the B1-channel and  $V_B2_TX_EN = '1'$  in the same register enables data transmission for the B2-channel.

 $V_B1_RX_EN = '1'$  in register  $R_SU_CTRL2$  enables data receive for the B1-channel and  $V_B2_RX_EN = '1'$  in the same register enables data receive for the B2-channel.

Disabled B-channel data means that all bits are forced to '1' on the line.

Figures 5.3 and 5.4 show the composition and decomposition of the S/T frames. B1-, B2-, D- and E-channel data is normally handled by the data flow controller. The HDLC controller as well as the PCM interface deliver data to the S/T interface and receive data from the S/T interface. For this reason, registers R\_B1\_TX, R\_B2\_TX, R\_D\_TX and R\_BAC\_S\_TX as well as R\_B1\_RX, R\_B2\_RX, R\_D\_RX and R\_E\_RX are normally not written or read from the application software.

Multiframe bits can be handled by the data flow controller (involving registers R\_BAC\_S\_TX and R\_E\_RX) or manually from the application software with registers R\_MS\_TX and R\_MS\_RX.



|                 | NT-to-7<br>frame synchr | ГЕ<br>onization | TE-to-NT<br>multiframe                                               | NT-to-TE<br>multiframe |
|-----------------|-------------------------|-----------------|----------------------------------------------------------------------|------------------------|
| Frame<br>number | F <sub>A</sub> -bit     | M-bit           | <b>Q-bits in</b><br><b>F</b> <sub>A</sub> bit position <sup>*1</sup> | S-bits *2              |
| 1               | '1'                     | '1'             | Q1                                                                   | S1                     |
| 2               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 3               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 4               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 5               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 6               | '1'                     | '0'             | Q2                                                                   | S2                     |
| 7               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 8               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 9               | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 10              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 11              | '1'                     | '0'             | Q3                                                                   | S3                     |
| 12              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 13              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 14              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 15              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 16              | '1'                     | '0'             | Q4                                                                   | S4                     |
| 17              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 18              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 19              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 20              | '0'                     | '0'             | '0'                                                                  | '0'                    |
| 1               | '1'                     | '1'             | Q1                                                                   | S1                     |
| 2               | '0'                     | '0'             | ·0·                                                                  | '0'                    |
|                 |                         |                 |                                                                      |                        |

**Table 5.3:** Multiframe structure of the Q- and S-bits

<sup>\*1</sup>: If the Q-bits are not used by a TE, the Q-bits shall be set to '1' (i.e. echoing of the received  $F_A$  bits).

<sup>\*2</sup>: The specification [9] defines five subchannels for the S-multiframe. Only subchannel 1 is used from XHFC-1SU. All other subchannels are set to '0'.





Figure 5.3: *S*/*T* frame composition for B1-, B2-, D- and multiframe bits (*S*/*T* interface mode, transmit direction)

#### 5.2.5 INFO signals

Signals which are transmitted on the interface line are called *INFO signals*. INFO 0 is defined for both TE-to-NT and NT-to-TE directions. All other INFO signals are either for TE-to-NT signaling (INFO 1, INFO 3) or NT-to-TE signaling (INFO 2, INFO 4). The INFO signals are defined as follows <sup>1</sup>:

**INFO 0:** No signal on line.

- **INFO 1:** Continuous signal at nominal bit rate with a '0011 1111' pattern which has a positive zero first and a negative zero following.
- **INFO 2:** Frames with A-bit and all B-, D- and E-bits in the frame are set to binary zero. The  $F_A$ -, N- and L-bits are set according to the normal coding rule.
- **INFO 3:** Synchronised frames with 2 bit offset and operational data on B- and D-channels.
- INFO 4: Frames with operational data on B-, D- and E-channels. The A-bit is set to binary one.

<sup>&</sup>lt;sup>1</sup>Please see [9] for a detailed description of the INFO signals.





**Figure 5.4:** *S*/*T* frame decomposition for B1-, B2-, D-, E-channel and multiframe bits (S/T interface mode, receive direction)



#### 5.2.6 State machine

A specification conform state machine for TE and NT mode is implemented [9]. So the current Fx or Gx state can be read out of register  $R_SU_RD_STA$ . However, it is possible to overwrite the current state by setting bit  $V_SU_LD_STA$  in register  $R_SU_WR_STA$ .

Activation and deactivation can be initiated by writing bitmap V\_SU\_ACT in the same register. This bitmap can be used for TE and NT mode and can start activation or deactivation from any state. Even in TE mode it can be used to initiate a deactivation from any state to F3. Such a deactivation should only be initiated if the state machine is not in F6 or F7, of course. Writing '11' (start activation) when the state machine is already activated (G2/G3 or F6/F7), will not change the current state.

Before starting the state machine, register  $R_SU_CLK_DLY$  of the S/T interface must be set. The default value is 0x0E for TE and 0x6C for NT mode.

## **Important**!

The S/T state machine is stuck at F0 or G0 after a reset. The interface sends no signal on the S/T line (INFO 0) and is not able to activate it by incoming INFO x in this state. Writing '0' into bit V\_SU\_LD\_STA of register R\_SU\_WR\_STA starts the state machine.

**NT mode:** The NT state machine does not change automatically from G2 to G3 if the TE side sends INFO 3 frames. This transition must be activated each time by  $V_G2_G3$  in register  $R_SU_RD_STA$  or it can permanently be enabled by setting bit  $V_G2_G3_EN$  in register  $R_SU_CTRL1$ .

Incoming INFO 0 at state F 6 cause a state change to F 3 normally. Sometimes an intermediate state F 7 occurs which stops timer T3. In this case another state change to F 3 comes up within 1 ms and F 7 can be ignored. V\_SU\_INFO0 in register R\_SU\_RD\_STA should be checked with every state change from F 6 to F 7. When this bit is set, the state should be checked again after about 1 ms. When it is F 3, the intermediate state F 7 has to be ignored. <sup>2</sup>

Tables 5.4 and 5.5 show the S/T interface activation and deactivation layer 1 of the finite state matrix in NT and TE mode.

<sup>&</sup>lt;sup>2</sup>It might be useful to start a timer of approximately 1 ms to detect the F6 - F7 - F3 state changes.



| State name:              | Reset               | Deactivated                    | Pending activation   | Active           | Pending deactivation           |
|--------------------------|---------------------|--------------------------------|----------------------|------------------|--------------------------------|
| State number:            | G 0                 | G 1                            | G 2                  | G 3              | G 4                            |
| INFO sent:               | INFO 0              | INFO 0                         | INFO 2               | INFO 4           | INFO 0                         |
| Event:                   |                     |                                |                      |                  |                                |
| State machine release *3 | G 1                 |                                |                      |                  |                                |
| Activate request         | start T 1 *1<br>G 2 | start T 1 *1<br>G 2            |                      |                  | start T 1 <sup>*1</sup><br>G 2 |
| Deactivate request       | _                   |                                | start T 2<br>G 4     | start T 2<br>G 4 |                                |
| Expiry T 1 <sup>*1</sup> | _                   | —                              | start T 2<br>G 4     | /                | —                              |
| Expiry T 2 *2            |                     |                                |                      |                  | G 1                            |
| Receiving INFO 0         | _                   | _                              | _                    | G 2              | G 1                            |
| Receiving INFO 1         | —                   | start T 1 <sup>*1</sup><br>G 2 | —                    | /                | —                              |
| Receiving INFO 3         |                     | /                              | stop T 1 *1,4<br>G 3 | —                | —                              |
| Lost framing             | _                   | /                              | /                    | G 2              | —                              |
| Legend: —                | No state chang      | ge                             |                      |                  |                                |
| /                        | Impossible situ     | uation                         |                      |                  |                                |

 Table 5.4: S/T interface activation/deactivation layer 1 matrix for NT mode

<sup>\*1</sup>: Timer T 1 is not implemented and must be implemented in software. T 1 is started with entering G2, runs during G2 state and is stopped when entering G3 or expiry. T 1 should expire after 100 ms .. 1000 ms [5].

Impossible by the definition of the layer 1 service

<sup>\*2</sup>: Timer T 2 prevents unintentional reactivation. Its value is  $256 \cdot 125 \,\mu s = 32 \,ms$ . This implies that a TE has to recognize INFO 0 and to react on it within this time.

 $^{*3}$ : After reset the state machine is fixed to G 0.

<sup>\*4</sup>: Bit V\_SU\_SET\_G2\_G3 in register R\_SU\_WR\_STA must be set to allow this transition or V\_G2\_G3\_EN in register R\_SU\_CTRL1 must be set to allow automatic transition  $G 2 \rightarrow G 3$ .



| State name:<br>State number:<br>INFO sent:                    | F 0<br>INFO 0 | so<br>unising<br>F 2<br>INFO 0 | F 3                                  | F 4 NAMAITING<br>F 4 NALON   | Input<br>Input<br>Input      | pəziuoulu Synchronized<br>F 6<br>INFO 3 | Pottivated<br>F 2<br>INFO 3 | tsor<br>F 8<br>INFO0         |
|---------------------------------------------------------------|---------------|--------------------------------|--------------------------------------|------------------------------|------------------------------|-----------------------------------------|-----------------------------|------------------------------|
| Event:                                                        |               |                                |                                      |                              |                              |                                         |                             |                              |
| State machine release *1                                      | F 2           | /                              | /                                    | /                            | /                            | /                                       | /                           | /                            |
| Activate request,<br>receiving any signal<br>receiving INFO 0 |               |                                | F 5<br>start T3 <sup>*5</sup><br>F 4 |                              |                              |                                         |                             |                              |
| Expiry T 3 <sup>*5</sup>                                      | _             | /                              | —                                    | F 3                          | F 3                          |                                         | —                           | F 3                          |
| Receiving INFO 0                                              |               | F 3                            |                                      |                              | _                            | F 3                                     | F3                          | F 3                          |
| Receiving any signal *2                                       | —             | _                              | —                                    | F 5                          | —                            | /                                       | /                           | —                            |
| Receiving INFO 2 *3                                           | —             | F 6                            | F 6                                  | F6                           | F 6                          |                                         | F6                          | F 6                          |
| Receiving INFO 4 *3                                           | _             | F7                             | stop T3 <sup>*5</sup><br>F 7         | stop T3 <sup>*5</sup><br>F 7 | stop T3 <sup>*5</sup><br>F 7 | stop T3 <sup>*5</sup><br>F 7            | —                           | stop T3 <sup>*5</sup><br>F 7 |
| Lost framing *4                                               | _             | /                              | /                                    | /                            | /                            | F 8                                     | F 8                         | _                            |

| Table 5 5  | S/T interface   | activation  | deactivation | lavor 1 | matrix for | TE mode    |
|------------|-----------------|-------------|--------------|---------|------------|------------|
| Table 5.5. | S/ I IIIleIIace | activation/ | ueactivation | layer r | matrix ior | I E IIIOUe |

Legend: — No state change

/ Impossible situation

Impossible by the definition of the layer 1 service

<sup>\*1</sup>: After reset the state machine is fixed to F0.

 $^{*2}$ : This event reflects the case where a signal is received and the TE has not (yet) determined wether it is INFO 2 or INFO 4.

\*<sup>3</sup>: Bit and frame synchronization achieved.

<sup>\*4</sup>: Loss of Bit or frame synchronization.

\*5: Timer T 3 is not implemented and must be implemented in software.



#### 5.2.7 Clock synchronization

A detailed view inside the line interface block diagram of Figure 5.1 is shown for the S/T interface mode in Figure 5.5. All clocks are derived from a 6.144 MHz clock which is  $f_{SU}/2$ . Frame synchronization is accomplished by evaluating the code violations in the S/T frame.

Received data from the pins R\_A and R\_B is passed through the RX data path to the switching buffer (see Figures 3.3 and 3.4 in Section 3.2). A bit clock and a frame clock are derived from the received data stream. These clocks are used to synchronize the RX data path timing to the incoming data stream. The frame clock can be passed for synchronization purposes to the TX data path and to the PCM timing control as well.

The transmit data clock has different sources in TE and NT mode:

- **NT mode:** The 192 kHz bit clock as well as the 8 kHz frame clock are derived from FSYNC in NT mode. This signal is either F0IO input or F1\_7 (see register R\_SL\_SEL7 and Figure 6.5 on page 221).
- **TE mode:** A TE is always taken as synchronization source for ISDN applications because it delivers the clock from the central office switch. Thus both clocks are taken from the RX clock unit.

The state machine takes several signals from the RX data path and the RX clock unit. The TX data path is controlled by the state machine's output signals.

The multiframe transmission can be synchronized to the PCM interface. The MSS controller (multiframe/superframe synchronization controller) delivers the MSS\_SYNC\_O signal to force the 'start of multiframe' in NT mode. The MSS controller is described in Section 6.6 from page 227.









#### 5.2.8 External circuitries

#### 5.2.8.1 External receive circuitry

The standard external receive circuitry for TE and NT mode is shown in Figure 5.6.

Figure 5.6 connects pins  $R_A/L_A$  through the transformer to a minus (-) pin of the RJ-45 jack, while pins  $R_B/L_B$  are connected to a RJ-45 plus (+) pin. Due to the automatic polarity detection of the XHFC-1SU receiver, it is allowed to swap the pairs  $R_A/L_A$  and  $R_B/L_B$ .



Figure 5.6: External S/T receive circuitry for TE and NT mode

For applications where the S/T interface is not used, the level adjustment pin ADJ should be left open.



#### 5.2.8.2 External transmit circuitry

The standard external transmit circuitry for TE and NT mode is shown in Figure 5.7.

Figure 5.7 connects pin T\_A through the transformer to a minus (–) pin of the RJ-45 jack, while pin T\_B is connected to a RJ-45 plus (+) pin. This is important for interoperability with other devices. Mainly for test purposes, the transmit lines can be swapped internally with  $V_SU_EXCHG = '1'$  in register R\_SU\_CTRL2.



Figure 5.7: External S/T transmit circuitry for TE and NT mode

The signal level of the transmit circuitry has to be adjusted by VDD\_SU. The exact voltage of this pin depends on the used transformer and circuitry dimensioning.



#### 5.2.8.3 Transformer and ISDN jack connection

Figure 5.8 and 5.9 show the connection circuitry of the transformer and the ISDN jack in TE mode<sup>3</sup>. The termination resistors R1 and R2 are optional.



Figure 5.8: Transformer and connector circuitry in TE mode





<sup>3</sup>The ISDN jack RJ-45 has 8 pins and carries two pairs of wires. Standard configuration is

pin 3: TE (+) transmit  $\rightarrow$  NT (+) receive, pin 4: NT (+) transmit  $\rightarrow$  TE (+) receive, pin 5: NT (-) transmit  $\rightarrow$  TE (-) receive, pin 6: TE (-) transmit  $\rightarrow$  NT (-) receive.





#### 5.2.9 S/T transformers

Customers of Cologne Chip can choose from a variety of S/T transformers for ISDN Basic Rate Interface. All S/T transformers are compatible to the XHFC series of Cologne Chip that fulfill two criteria:

- Turns ratio of 1:2 (line side : chip side)
- Center tap on the chip side (required for Cologne Chip transmitter and receiver circuitries)

Several companies provide *transformers* and *transformer modules* that can be used with our ISDN Basic Rate Interface controllers. Most popular are SMD dual transformer modules with choke for EMI reasons. Part numbers and manufacturers are listed in Table 5.6. A more extensive and regularly updated list can be found on Cologne Chip's website http://www.colognechip.com.

The transformer list has not been compiled under aspects of RoHS compliance. For the current RoHS status of the listed parts, please contact the transformer manufacturers straight.

| Bel Fuse Inc., United Kingdom, http://www.b | elfuse.com |
|---------------------------------------------|------------|
|---------------------------------------------|------------|

| Type Device                            | Type Device                         |
|----------------------------------------|-------------------------------------|
| Dual Transformer Module without choke: | Dual Transformer Module with choke: |
| 2798B (SMD)                            | APC 48301 (THT)                     |
| 2798C (SMD)                            |                                     |
| 2798D (SMD)                            |                                     |

#### Pulse Engineering, Inc., United States, http://www.pulseeng.com

| Type D      | evice              | Туре   | Device                           |
|-------------|--------------------|--------|----------------------------------|
| Single tran | nsformer:          | Dual T | ransformer Module without choke: |
| T.          | 5003 (SMD, PCMCIA) |        | T5006 (SMD)                      |
| T.          | 5020 (SMD)         |        | T5007 (SMD)                      |
| T:          | 5023 (SMD)         |        | T5042 (SMD, 3 kV)                |
| T           | 5024 (SMD, 3 kV)   |        | PE-65495 (THT)                   |
| T.          | 5033 (SMD)         |        | PE-65499 (THT)                   |
| T:          | 5035 (THT, 3 kV)   |        | PE-65795 (SMD)                   |
| T:          | 5036 (SMD, 3 kV)   |        | PE-65799 (SMD)                   |
| PI          | E-64995 (THT)      |        |                                  |
| PI          | E-64999 (THT)      | Dual T | ransformer Module with choke:    |
| PI          | E-68992 (THT)      |        | T5012 (THT)                      |
| ST          | Г-5069 (SMD)       |        | T5034 (SMD)                      |
|             |                    |        | T5038 (SMD)                      |



#### **Table 5.6:** S/T transformer part numbers and manufacturers

(continued from previous page)

#### Talema Elektronik GmbH, Germany, http://www.talema.net

| Туре                | Device                           | Туре   | Device                         |
|---------------------|----------------------------------|--------|--------------------------------|
| Single Transformer: |                                  | Dual T | Fransformer Module with choke: |
|                     | ISF-140B1 (THT)                  |        | HVM-140C1 (THT)                |
|                     | ISV-140B1 (THT)                  |        | ISM-140C1 (THT)                |
|                     | ISHF-240B1 (THT, 3 kV)           |        | MUJ-103A-500(SMD, miniature)   |
|                     | SHJ-240B (SMD, 3 kV)             |        | MUJ-103A-101(SMD, miniature)   |
|                     | SMJ-140B (SMD)                   |        | MUJ-103A-501(SMD, miniature)   |
|                     | SWJ-140B (SMD)                   |        | MUJ-103A-502(SMD, miniature)   |
|                     |                                  |        | MAJ-403A-470 (SMD)             |
| Dual T              | ransformer Module without choke: |        | MAJ-403A-101 (SMD)             |
|                     | MUJ-103A-000 (SMD, miniature)    |        | MAJ-403A-501 (SMD)             |
|                     |                                  |        | MAJ-403A-502 (SMD)             |
|                     |                                  |        | MSJ-403A-470 (SMD)             |
|                     |                                  |        | MSJ-403A-101 (SMD)             |
|                     |                                  |        | MSJ-403A-501 (SMD)             |
|                     |                                  |        | MSJ-403A-502 (SMD)             |
|                     |                                  |        | MHJ-240B1-470 (SMD, 3 kV)      |
|                     |                                  |        | MHJ-240B1-101 (SMD, 3 kV)      |
|                     |                                  |        | MHJ-240B1-501 (SMD, 3 kV)      |
|                     |                                  |        | MHJ-240B1-502 (SMD, 3 kV)      |
|                     |                                  |        | MHJ-240B1-123 (SMD, 3 kV)      |



 Table 5.6: S/T transformer part numbers and manufacturers

(continued from previous page)

#### UMEC GmbH, Germany, Taiwan, United States, http://www.umec.de

| Туре                | Device               | Type Device                            |
|---------------------|----------------------|----------------------------------------|
| Single transformer: |                      | Dual Transformer Module without choke: |
|                     | UT 20995 (THT)       | UT 20495 (THT)                         |
|                     | UT 20999 (THT)       | UT 20495-TS (SMD)                      |
|                     | UT 21023 (THT)       | UT 20765-00 (SMD, 3 kV)                |
|                     | UT 21595 (THT)       | UT 20795-00TS (SMD)                    |
|                     | UT 28166 (THT)       |                                        |
|                     | UT 28166-TS (SMD)    | Dual Transformer Module with choke:    |
|                     | UT 28428-TS (SMD)    | UT 20495 CV-TS (SMD)                   |
|                     | UT 28729 (THT, 4 kV) | UT 20765-05TS (SMD, 3 kV)              |
|                     |                      | UT 20765-10TS (SMD, 3 kV)              |
|                     |                      | UT 20765-50TS (SMD, 3 kV)              |
|                     |                      | UT 20795-05TS (SMD)                    |
|                     |                      | UT 20795-10TS (SMD)                    |
|                     |                      | UT 20795-50TS (SMD)                    |
|                     |                      | UT 20795-5M-TS (SMD)                   |
|                     |                      | UT 21644S (SMD, miniature)             |
|                     |                      | UT 28624 (THT)                         |
|                     |                      | UT 28624A (THT)                        |
|                     |                      | UT 28624A-T (SMD)                      |

Vacuumschmelze GmbH & Co. KG, Germany, http://www.vacuumschmelze.com

| Type Device              | Type Device                            |
|--------------------------|----------------------------------------|
| Single transformer:      | Dual Transformer Module without choke: |
| 3-L4021-X066 (THT)       | 7-M4035-X001 (THT)                     |
| 3-L4025-X095 (THT)       | 7-M5014-X001 (SMD, miniature)          |
| 3-L4031-X001 (THT)       | 7-M5026-X001 (SMD)                     |
| 3-L4097-X029 (THT, 3 kV) | 7-M5026-X002 (SMD, 3 kV)               |
| 3-L5024-X028 (SMD)       | 7-M5054-X001 (SMD)                     |
| 3-L5032-X040 (SMD, 3 kV) |                                        |
|                          | Dual Transformer Module with choke:    |
|                          | 7-L5026-X010 (SMD)                     |
|                          | 7-L5026-X011 (SMD, 3 kV)               |
|                          | 7-L5026-X017 (SMD)                     |
|                          | 7-L5051-X014 (THT)                     |
|                          | 7-L5054-X005 (SMD, 3 kV)               |
|                          | 7-L5054-X006 (SMD, 3 kV)               |



#### **Table 5.6:** S/T transformer part numbers and manufacturers

(continued from previous page)

#### Sumida AG, Germany, http://www.sumida-eu.com (formerly known as Vogt electronic AG)

| Туре                | Device                      | Туре   | Device                            |
|---------------------|-----------------------------|--------|-----------------------------------|
| Single transformer: |                             | Dual T | Fransformer Module without choke: |
| -                   | 503 05 901 00 (SMD)         |        | 503 16 504 00 (SMD)               |
|                     | 503 10 009 00 (SMD)         |        | 503 16 513 00 (SMD, 4 kV)         |
|                     | 503 12 001 00 (SMD, PCMCIA) |        | 503 20 981 00 (SMD)               |
|                     | 503 20 010 00 (SMD)         |        | 503 74 003 00 (SMD, 4 kV)         |
|                     | 503 20 019 00 (SMD, 4 kV)   |        | 503 74 006 00 (SMD)               |
|                     | 543 80 008 00 (THT, 4 kV)   |        |                                   |
|                     |                             | Dual T | Fransformer Module with choke:    |
|                     |                             |        | 503 16 017 00 (SMD, miniature)    |
|                     |                             |        | 503 16 501 00 (SMD)               |
|                     |                             |        | 503 16 502 00 (SMD)               |
|                     |                             |        | 503 16 505 00 (SMD)               |
|                     |                             |        | 503 16 506 00 (SMD)               |
|                     |                             |        | 503 20 985 00 (SMD)               |
|                     |                             |        | 543 76 006 00 (SMD)               |

**Please note:** Cologne Chip cannot take any liability concerning the product names, characteristics and availability. Products can change without notice. Please refer to the manufacturer in case of doubt.



## 5.3 U<sub>p</sub> interface description

#### 5.3.1 Overview

The Universal ISDN Port is able to provide a ping-pong type 2-wire interface according to  $U_{p0}$  and  $U_{pN}$  specifications [3] known from SIEMENS Corporation and German Electrical and Electronic Manufacturers' Association (ZVEI).

The line interface is a four-wire interface and has separated transmitter and receiver with configurable behaviour. The ISDN data frame structure is handled by hardware. Thus plain data is processed on the host side of the  $U_p$  interface.

A specification conform state machine for TE and LT mode is implemented (see Section 5.3.6). This is very similar to the S/T state machine (see Section 5.2.6 on page 163).

The  $U_p$  interface uses AMI coding for input and output signals. This pseudo-ternary coding converts logical zeros to 0 V level. Logical ones are coded by alternating positive and negative voltage with 2 V nominal amplitude on the line.

#### 5.3.2 Frame Structure

The  $U_p$  frame structure has a length of 250 µs. Within this period, a transmit phase and a receive phase with 99 µs length each is placed as shown in Figure 5.10. The 38 bit frame has the same structure for LT-to-TE and TE-to-LT transmissions.



Figure 5.10: Up interface frame structure

#### 5.3.3 Superframe structure

There is a higher frame structure called *superframe* (also called *M-channel*). A superframe has the length of 4 bits and consists of the bits CV, T and S as shown in Figure 5.10 and Table 5.8. As there is one superframe bit within every frame, a complete superframe is transmitted and received every 1 ms.



| Symbol                  | min / µs | typ / μs | max / μs | Characteristic          |
|-------------------------|----------|----------|----------|-------------------------|
| t <sub>rep</sub>        |          | 250      |          | Burst repetition period |
| $t_{ m fr}$             |          | 99       |          | Frame time              |
| <i>t</i> <sub>dly</sub> | 0        |          | 20.8     | Line delay              |
| tguard                  |          | 5.2      |          | Guard time (2 bits)     |
| t <sub>res</sub>        | 0        |          | 41.6     | Residual time           |

 Table 5.7: Legend for Figure 5.10

The CV-bit is used for the superframe synchronization. It has always the value '1' and produces a code violation.

Superframe data is transferred through the T-bits while the S-bit can be used for service bits. Received bits are stored in register R\_MS\_RX. When two complete superframes are received, bit V\_MS\_RX\_RDY is set to '1' in the same register. Then the four T-bits in V\_MS\_RX – received within two superframes – are valid. V\_MS\_RX\_RDY is reset to '0' with every read access to register R\_MS\_RX. The first received T-bit is stored in V\_MS\_RX[3], the fourth is stored in V\_MS\_RX[0].

Superframe data to be transmitted must be stored in bitmap V\_MS\_TX of register R\_MS\_TX. Four T-bits must be stored together. They are transmitted with the next two superframes. The first T-bit is V\_MS\_TX[3] and the fourth is V\_MS\_TX[0]. When all T-bits are transferred to the output shift register, bit V\_MS\_TX\_RDY in register R\_MS\_RX changes to '1' to signal 'next data required'. This bit is automatically reset to '0' with a read access to register R\_MS\_RX.

The received service bit S can be read from register V\_UP\_S\_RX. In transmit data direction, the bit value V\_UP\_S\_TX in register R\_MS\_TX will be send in the next superframes until another value is written into V\_UP\_S\_TX.

| Number in sequence | Bit name | Meaning                 | Bit rate |
|--------------------|----------|-------------------------|----------|
| 1                  | CV       | Code violation bit      | 1 kbit/s |
| 2, 4               | Т        | Transparent channel bit | 2 kbit/s |
| 3                  | S        | Service channel bit     | 1 kbit/s |

Table 5.8: Superframe construction

#### **5.3.4** Data transmission

B-channel data on the line interface must be enabled for transmit and receive direction separately.

 $V_B1_TX_EN = '1'$  in register  $R_SU_CTRL0$  enables data transmission for the B1-channel and  $V_B2_TX_EN = '1'$  in the same register enables data transmission for the B2-channel.

 $V_B1_RX_EN = '1'$  in register  $R_SU_CTRL2$  enables data receive for the B1-channel and  $V_B2_RX_EN = '1'$  in the same register enables data receive for the B2-channel.

Disabled B-channel data means that all bits are forced to '1' on the line. Due to the fact that the bit scramblers are functionally arranged in front of the B-channel enable/disable logic (V\_B1\_TX\_EN



and V\_B2\_TX\_EN), it is important always to enable the B-channels during  $U_p$  operation even if no data is send.



**Figure 5.11:**  $U_p$  frame composition for B1-, B2-, D-channel and superframe bits ( $U_p$  interface mode, transmit direction)

Figures 5.11 and 5.12 show the composition and decomposition of the  $U_p$  frames. B1-, B2- and Dchannel data is normally handled by the data flow controller. The HDLC controller as well as the PCM interface deliver data to the  $U_p$  interface and receive data from the  $U_p$  interface. For this reason, registers R\_B1\_TX, R\_B2\_TX, R\_D\_TX and R\_BAC\_S\_TX as well as R\_B1\_RX, R\_B2\_RX, R\_D\_RX and R\_E\_RX<sup>4</sup> are normally not written or read from the application software.

Superframe bits can be handled by the data flow controller (involving registers R\_BAC\_S\_TX and R\_E\_RX) or manually from the application software with registers R\_MS\_TX and R\_MS\_RX. Please note that R\_BAC\_S\_TX contains E-channel data only in S/T interface mode.

#### 5.3.5 INFO signals

Signals which are transmitted on the interface line are called *INFO signals*. INFO 0 is defined for upstream (TE-to-LT) and downstream (LT-to-TE) direction. All other INFO signals are either for

<sup>&</sup>lt;sup>4</sup>Please note, that R\_E\_RX does only contain E-channel bits in S/T interface mode.





**Figure 5.12:**  $U_p$  frame decomposition for B1-, B2-, D-channel and superframe bits ( $U_p$  interface mode, receive *direction*)



upstream (INFO 1W, INFO 1, INFO 3) or downstream (INFO 2, INFO 4) direction. The INFO signals are defined as follows [3]:

**INFO 0:** No signal on line.

**INFO 1W:** Asynchronous awake signal with a 2 kHz burst rate (every second frame used). The frame has the contents

'F 00010001 00010001 0001 01010100 01011111 1'

with code violation in the framing bit F. F is always '1'.

**INFO 1:** 4 kHz burst rate (every frame used). The frame has the contents

'F 00010001 00010001 0001 01010100 01011111 M DC'

with code violation in the framing bit F.

**INFO 2:** 4 kHz burst rate (every frame used). The frame has the contents

'F 00010001 00010001 0001 01010100 01011111 M'

with code violation in the framing bit F.

- **INFO 3:** 4 kHz burst rate (every frame used) with user data in B-, D- and M-channels. The B- channels are scrambled. The framing bit F has no code violation. The DC-bit is used.
- **INFO 4:** 4 kHz burst rate (every frame used) with user data in B-, D- and M-channels. The Bchannels are scrambled. The framing bit F has no code violation. The DC-bit is used.

The F-bit polarity (AMI-violation or no AMI-violation) is calculated in relation to the last bit of the preceding frame in the same direction. The DC-balancing bit is included in the F-bit polarity calculation algorithm when it is present.

#### 5.3.6 State machine

A specification conform state machine for TE and LT mode is implemented. So the current Fx or Gx state of the state machine can be read out of register  $R_SU_RD_STA$ . However, it is possible to overwrite the state machine by setting bit  $V_SU_LD_STA$  in register  $R_SU_WR_STA$ .

Activation and deactivation can be initiated by writing bitmap V\_SU\_ACT in the same register. This bitmap can be used for TE and LT mode and can start activation or deactivation from any state. Even in TE mode it can be used to initiate a deactivation from any state to F3. Such a deactivation should only be initiated if the state machine is not in F6 or F7, of course. Writing '11' (start activation) when the state machine is already activated (G2/G3 or F6/F7), will not change the current state.

Before starting the state machine in TE mode, register  $R_SU_CLK_DLY$  of the  $U_p$  interface must be set. The default value is 0xF for TE mode.

Please note that in contrast to the S/T interface mode, an  $U_p$  device cannot be linked to an already activated  $U_p$  line for monitoring e.g., because the device must pass the entire activation sequence.

Tables 5.9 and 5.10 show the  $U_p$  interface activation and deactivation layer 1 of the finite state matrix in TE and LT mode. They are adopted from the S/T state machine specification according to ITU-T I.430 [9].



| State name:              | Reset          | Deactivated   | Pending                  | Active    | Pending      |
|--------------------------|----------------|---------------|--------------------------|-----------|--------------|
|                          |                |               | activation               |           | deactivation |
| State much and           | CO             | C 1           | <u> </u>                 | C 2       | C 4          |
| State number:            | 60             | GI            | 62                       | 63        | 64           |
| INFO sent:               | INFO 0         | INFO 0        | INFO 2                   | INFO 4    | INFO 0       |
| Event:                   |                |               |                          |           |              |
| State machine release *3 | G 1            |               |                          |           |              |
| Activate request         | start T 1 *1   | start T 1 *1  | I                        | I         | start T 1 *1 |
| rion and rode of         | G2             | G2            | I                        | I         | G2           |
| Deactivate request       |                |               | start T 2                | start T 2 |              |
| Deuenville Tequest       |                | Ι             | G4                       | G4        | I            |
|                          |                |               |                          |           |              |
| Expiry T 1 *1            | —              | —             | start T 2                | /         | —            |
|                          |                |               | G4                       |           |              |
| Expiry T 2 *2            | _              | —             |                          | —         | G 1          |
| Receiving INFO 0         |                |               |                          | G2        | G1           |
| Receiving INFO 1         |                |               |                          |           |              |
|                          |                | <b>m</b> 4 *1 |                          | ,         |              |
| or INFO IW               |                | start T 1     | —                        | /         | —            |
|                          |                | 62            | *1.4                     |           |              |
| Receiving INFO 3         |                | /             | stop T 1 <sup>-1,4</sup> |           | —            |
|                          |                |               | G3                       |           |              |
| Lost framing             | —              | /             | /                        | G 2       | —            |
| Legend: —                | No state chang | ge            |                          |           |              |
| 0                        |                | ,<br>,        |                          |           |              |

| <b>Table 5.9:</b> U <sub>p</sub> interface activation/deactivation layer 1 matrix for LT m |
|--------------------------------------------------------------------------------------------|
|--------------------------------------------------------------------------------------------|

/ Impossible situation

Impossible by the definition of the layer 1 service

<sup>\*1</sup>: Timer T 1 is not implemented and must be implemented in software. T 1 is started with entering G2, runs during G2 state and is stopped when entering G3 or expiry. T 1 should expire after 100 ms .. 1000 ms [5].

<sup>\*2</sup>: Timer T 2 prevents unintentional reactivation. Its value is  $256 \cdot 125 \,\mu s = 32 \,ms$ . This implies that a TE has to recognize INFO 0 and to react on it within this time.

\*3: After reset the state machine is fixed to G0.

<sup>\*4</sup>: Bit V\_SU\_SET\_G2\_G3 in register R\_SU\_WR\_STA must be set to allow this transition or V\_G2\_G3\_EN in register R\_SU\_CTRL1 must be set to allow automatic transition  $G 2 \rightarrow G 3$ .


| State name:<br>State number:<br>INFO sent:                    | F 0 | F 2 | Deactivated<br>F 3                   | ganiting<br>F 4<br>INFO IW   | Input<br>Input               | Synchronized<br>E 9          | Potivated<br>F 7<br>INFO 3 | F 8<br>INFO0                 |
|---------------------------------------------------------------|-----|-----|--------------------------------------|------------------------------|------------------------------|------------------------------|----------------------------|------------------------------|
| Event:                                                        |     |     |                                      |                              |                              |                              |                            |                              |
| State machine release *1                                      | F2  | /   | /                                    | /                            | /                            | /                            | /                          | /                            |
| Activate request,<br>receiving any signal<br>receiving INFO 0 |     |     | F 5<br>start T3 <sup>*5</sup><br>F 4 |                              |                              |                              |                            | _                            |
| Expiry T 3 *5                                                 |     | /   |                                      | F3                           | F 3                          |                              | _                          | F 3                          |
| Receiving INFO 0                                              | _   | F 3 | _                                    | _                            | _                            | F 3                          | F3                         | F 3                          |
| Receiving any signal *2                                       | _   | _   |                                      | F 5                          | _                            | /                            | /                          |                              |
| Receiving INFO 2 *3                                           | _   | F 6 | F 6                                  | F 6                          | F 6                          |                              | F6                         | F 6                          |
| Receiving INFO 4 *3                                           | _   | F7  | stop T3 <sup>*5</sup><br>F 7         | stop T3 <sup>*5</sup><br>F 7 | stop T3 <sup>*5</sup><br>F 7 | stop T3 <sup>*5</sup><br>F 7 | —                          | stop T3 <sup>*5</sup><br>F 7 |
| Lost framing *4                                               | _   | /   | /                                    | /                            | /                            | F 8                          | F 8                        | _                            |
| T J.                                                          | NT  | .1  |                                      |                              |                              |                              |                            |                              |

|             |                          |            |              |         |            | <b>TC</b> ( |
|-------------|--------------------------|------------|--------------|---------|------------|-------------|
| Table 5.10: | U <sub>p</sub> interface | activation | deactivation | layer 1 | matrix for | I E mode    |

Legend: — No state change

/ Impossible situation

Impossible by the definition of the layer 1 service

<sup>\*1</sup>: After reset the state machine is fixed to F0.

 $^{*2}$ : This event reflects the case where a signal is received and the TE has not (yet) determined wether it is INFO 2 or INFO 4.

\*<sup>3</sup>: Bit and frame synchronization achieved.

<sup>\*4</sup>: Loss of Bit or frame synchronization.

\*5: Timer T 3 is not implemented and must be implemented in software.



# **Important**!

The  $U_p$  state machine is stuck at F0 or G0 after a reset. The interface sends no signal on the  $U_p$  line and is not able to activate it by incoming INFO x in this state. Writing '0' into bit V\_SU\_LD\_STA of register R\_SU\_WR\_STA starts the state machine.

**LT mode:** The LT state machine does not change automatically from G2 to G3 if the TE side sends INFO 3 frames. This transition must be activated each time by  $V_G2_G3$  in register  $R_SU_RD_STA$  or it can permanently be activated by setting bit  $V_G2_G3_EN$  in register  $R_SU_CTRL1$ .

#### 5.3.7 Clock synchronization

A detailed view inside the line interface block diagram of Figure 5.1 is shown for the  $U_p$  interface mode in Figure 5.13. All clocks are derived from the 12.288 MHz clock  $f_{SU}$ . Frame synchronization is accomplished by evaluating the code violations in the  $U_p$  frame.

Received data from the pins R\_A and R\_B is passed through the RX data path to the switching buffer. A bit clock and a frame clock are derived from the received data steam. These clocks are used to synchronize the RX data path timing to the incoming data stream. The frame clock can be passed for synchronization purposes to the TX data path and the PCM timing control as well.

The transmit data clock has different sources in TE and LT mode:

- **LT mode:** The 384 kHz bit clock as well as the 8 kHz frame clock are derived from FSYNC in NT mode. This signal is either F0IO input or F1\_7 (see register R\_SL\_SEL7 and Figure 6.5 on page 221).
- **TE mode:** A TE is always taken as synchronization source for ISDN applications because it delivers the clock from the central office switch. Thus both clocks are taken from the RX clock unit.

The state machine takes several signals from the RX data path and the RX clock unit. The TX data path is controlled by the state machine's output signal.

Bit scramblers are inserted into the receive and the transmit data pathes. The scramblers can be switched off with V\_UP\_SCRM\_RX\_OFF = '1' (for the receive data path) and V\_UP\_SCRM\_TX\_OFF = '1' (for the transmit data path) in register R\_UP\_CTRL3. Bit scramblers should only be disabled for test purposes. They shall mandatorily be enabled for normal  $U_p$  operation.

The scrambler mode is configurable according to ITU-T V.27 specification [8] or OCTAT-P compatibility [6] with V\_UP\_SCRM\_MD in the same register.





Figure 5.13: U<sub>p</sub> clock synchronization



#### 5.3.8 External circuitry



Figure 5.14: External  $U_{\rho}$  circuitry for TE and LT mode



#### **5.3.9** U<sub>p</sub> transformers

Customers of Cologne Chip can choose from a variety of  $U_p$  transformers for two-wire ISDN  $U_p$  interface  $(U_{p0}/U_{pN})$ . All  $U_p$  transformers are compatible to the XHFC series of Cologne Chip that fulfill two criteria:

- Turns ratio of 1:1
- Dual winding on line side (required for power feeding)

Several companies provide transformers that can be used with our ISDN Basic Rate Interface controllers. Part numbers and manufacturers are listed in Table 5.11. Please ask our support team for more information.

The transformer list has not been compiled under aspects of RoHS compliance. For the current RoHS status of the listed parts, please contact the transformer manufacturers straight.

**Table 5.11:** Up transformer part numbers and manufacturers

#### UMEC GmbH, Germany, Taiwan, United States, http://www.umec.de

Type Device

Single transformer: UT 21434A-TS (SMD)

Vacuumschmelze GmbH & Co. KG, Germany, http://www.vacuumschmelze.com

Type Device

Single transformer: 3-M5024-X008 (SMD)

Sumida AG, Germany, http://www.sumida-eu.com (formerly known as Vogt electronic AG)

Type Device

Single transformer 503 10 903 00 (SMD)

**Please note:** Cologne Chip cannot take any liability concerning the product names, characteristics and availability. Products can change without notice. Please refer to the manufacturer in case of doubt.



# 5.4 Common features of the S/T and U<sub>p</sub> interface

#### 5.4.1 Direct data access for test purposes

Data accesses from the host processor are normally write operations to the FIFOs or read operations from the FIFOs. For test purposes it is also possible to access directly internal data registers. These registers

- R\_B1\_TX, R\_B2\_TX, R\_D\_TX and R\_BAC\_S\_TX in transmit data direction and
- R\_B1\_RX, R\_B2\_RX, R\_D\_RX and R\_E\_RX in receive data direction

can only be read or written during non-processing phase of the data flow processor. This is indicated with  $V\_PROC = '0'$  in register  $R\_STATUS$ . During processing phase ( $V\_PROC = '1'$ ), read values can be invalid and written values might be overwritten by the data flow processor.

#### **Interrupt capability**

The line interface can cause an interrupt when a state change occurs. State changes can be read from  $V_SU_IRQ$  in register  $R_SU_IRQ$ .  $V_SU_IRQ$  is cleared after reading the register.

 $V_SU_IRQ = '1'$  causes an interrupt if the associated mask bit  $V_SU_IRQMSK$  in register  $R_SU_IRQMSK$  enables the interrupt. Register  $R_SU_IRQ$  can be read even if interrupt is disabled with  $V_SU_IRQMSK = '0'$  and must be polled to watch the interrupt status in this case.



#### 5.4.2 Combined S/T and Up circuitry

An external circuitry of the Universal ISDN Port can be set up which can be used for both S/T and  $U_p$  interface mode. This circuitry requires only one S/T transformer module which is used for  $U_p$  operating mode as well. The circuitry description is available on request.



# 5.5 Register description

# Please note !

The name fragment SU of registers and bitmaps indicates those registers and bitmaps which are valid in both S/T and  $U_p$  interface mode. SU means 'ST/ $U_p$ '.

The name fragments ST or UP are used when a register or bitmap is either valid in S/T or  $\rm U_p$  interface mode.

#### 5.5.1 Write only registers

| R_       | _SU_WR_                        | _STA                    |                            | (w)      | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                               | 0x30                 |
|----------|--------------------------------|-------------------------|----------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| ST<br>Th | <b>Up state</b><br>is register | e machine<br>is used to | set a new state. The curre | ent stat | e can be read from register R_SU_RD_STA.                                                                                                                                                                                                                                                                                                                             |                      |
|          | Bits                           | Reset<br>value          | Name                       |          | Description                                                                                                                                                                                                                                                                                                                                                          |                      |
|          | 30                             | 0                       | V_SU_SET_STA               |          | Binary value of the new state<br>(NT/LT: Gx, TE: Fx)<br>V_SU_LD_STA must also be set to load the                                                                                                                                                                                                                                                                     | state.               |
|          | 4                              | 1                       | V_SU_LD_STA                |          | Load the new state<br>'1' = load the prepared state (V_SU_SET_S<br>and stops the state machine. This bit needs t<br>set for a minimum period of 5.21 µs and mus-<br>cleared by software.<br>'0' = enable the automatic state machine<br>(V_SU_SET_STA is ignored).<br>Note: After writing an invalid state, the state<br>machine goes to deactivated state (G1, F2). | TA)<br>o be<br>st be |
|          | 65                             | 0                       | V_SU_ACT                   |          | Start activation / deactivation<br>'00' = no operation<br>'01' = no operation<br>'10' = start deactivation<br>'11' = start activation<br>These bits are automatically cleared after rea<br>the activated / deactivated state.                                                                                                                                        | aching               |
|          | 7                              | 0                       | V_SU_SET_G2_G3             |          | Allow G2 to G3 transition<br>'0' = no operation<br>'1' = allows transition from G2 to G3 in NT/<br>mode<br>This bit is automatically cleared after the tra<br>and has no function in TE mode.                                                                                                                                                                        | LT<br>nsition        |



| R_ | _SU_CTR     | lL0            |                           | (w) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                                                                | 0x31                              |
|----|-------------|----------------|---------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|
| Co | ontrol regi | ister of th    | e line interface, registe | r 0 |                                                                                                                                                                                                                                                                                                                                                                                                       |                                   |
|    | Bits        | Reset<br>value | Name                      |     | Description                                                                                                                                                                                                                                                                                                                                                                                           |                                   |
|    | 0           | 0              | V_B1_TX_EN                |     | <b>B1-channel transmit</b><br>'0' = B1 send data disabled (permanent '1's se<br>activated states)<br>'1' = B1 send data enabled<br><b>Note:</b> When the bit scrambler is activated in<br>line interface mode (default operation mode)<br>bit must be set to '1' even if the B1-channel i<br>in use.                                                                                                  | ent in<br>Up<br>), this<br>is not |
|    | 1           | 0              | V_B2_TX_EN                |     | <b>B2-channel transmit</b><br>'0' = B2 send data disabled (permanent '1's se<br>activated states)<br>'1' = B2 send data enabled<br><b>Note:</b> When the bit scrambler is activated in<br>line interface mode (default operation mode)<br>bit must be set to '1' even if the B2-channel i<br>in use.                                                                                                  | ent in<br>Up<br>), this<br>is not |
|    | 2           | 0              | V_SU_MD                   |     | Line interface mode<br>'0' = TE mode<br>'1' = NT/LT mode                                                                                                                                                                                                                                                                                                                                              |                                   |
|    | 3           | 0              | V_ST_D_LPRIO              |     | <b>D-channel priority</b><br>'0' = high priority 8/9<br>'1' = low priority 10/11<br><b>Note:</b> This bit is only used when the line interior<br>is in S/T mode. It is ignored in Up interface                                                                                                                                                                                                        | erface<br>mode.                   |
|    | 4           | 0              | V_ST_SQ_EN                |     | <ul> <li>S/Q bits transmission</li> <li>'0' = S/Q bits disabled</li> <li>'1' = S/Q bits (multiframe) enabled</li> <li>Note: This bit is only used when the line interior is in S/T mode. It is ignored in Up interface</li> </ul>                                                                                                                                                                     | erface<br>mode.                   |
|    | 5           | 0              | V_SU_TST_SIG              |     | Send test signal<br>'0' = normal operation<br>'1' = send test signal<br>The test signal depends on the selected line<br>interface mode and V_SU_2KHZ in register<br>R_SU_CTRL2:<br>S/T interface mode: Test signal is 96 kHz<br>(alternating '0's) or 2 kHz (one alternating '0'<br>frame)<br>Up interface mode: Test signal is 192 kHz<br>(alternating '1's) or 2 kHz (one alternating '1'<br>frame) | ' per<br>' per                    |

(continued on next page)



(continued from previous page)

| Bits | Reset<br>value | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | 0              | V_ST_PU_CTRL | End of pulse control<br>The end of pulse edge of the transmit signal can be<br>adjusted in S/T interface mode. The programming<br>value of V_ST_PULSE in register R_ST_CTRL3<br>specifies the end of pulse edge.<br>'0' = no end of pulse control<br>'1' = end of pulse control enabled<br>Note: This bit is only used for line interfaces in<br>S/T mode. It is not used in Up interface mode and<br>must be '0'. |
| 7    | 0              | V_SU_STOP    | <b>Power down</b><br>'0' = external receiver activated<br>'1' = power down, external receiver disabled                                                                                                                                                                                                                                                                                                             |



| R_ | _SU_CTR    | L1             |                           | (w) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                        | 0x32                    |
|----|------------|----------------|---------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Co | ontrol reg | ister of th    | e line interface, registe | r 1 |                                                                                                                                                                                                                                                                                                                               |                         |
|    | Bits       | Reset<br>value | Name                      |     | Description                                                                                                                                                                                                                                                                                                                   |                         |
|    | 0          | 0              | V_G2_G3_EN                |     | Force automatic transition from G2 to G3<br>'0' = V_SU_SET_G2_G3 in register<br>R_SU_WR_STA must be set again for every<br>transition from G2 to G3<br>'1' = transitions from G2 to G3 are always allo<br>and V_SU_SET_G2_G3 is ignored                                                                                       | owed                    |
|    | 1          | 0              | (reserved)                |     | Must be '0'.                                                                                                                                                                                                                                                                                                                  |                         |
|    | 2          | 0              | V_D_RES                   |     | <b>D-channel reset</b><br>'0' = normal operation<br>'1' = D-channel is reset and its bits are forced<br>in transmit direction                                                                                                                                                                                                 | to '1'                  |
|    | 3          | 0              | V_ST_E_IGNO               |     | Ignore E-channel data<br>This bit is only used when the line interface is<br>S/T mode. D-channel data is immediately sen<br>Up interface mode.<br>'0' = normal operation<br>'1' = D-channel always sends data regardless of<br>received E-channel bit<br>Note: This bit is only used in TE mode and is<br>ignored in NT mode. | in<br>d in<br>of the    |
|    | 4          | 0              | V_ST_E_LO                 |     | Force E-channel to low<br>(only in NT mode)<br>'0' = normal operation, E-channel bits echo<br>received D-channel data<br>'1' = E-channel bits are forced to '0'<br>Note: This bit is only used when the line inter<br>is in S/T mode. It is ignored in Up interface m                                                         | rface<br>10de.          |
|    | 5          | 0              | (reserved)                |     | Must be '0'.                                                                                                                                                                                                                                                                                                                  |                         |
|    | 6          | 0              | V_BAC_D                   |     | <ul> <li>BAC-bit disables D-channel transmit</li> <li>'0' = D-channel transmission is enabled</li> <li>'1' = Bac-bit is used to enable or disable D-chatransmission</li> <li>Note: This bit is only used when the line inter is in S/T mode. It is ignored in Up interface mathematical sectors.</li> </ul>                   | annel<br>rface<br>10de. |
|    | 7          | 0              | V_B12_SWAP                |     | Swap B-channels<br>'0' = normal operation<br>'1' = swap B1- and B2-channel registers of the<br>interface                                                                                                                                                                                                                      | e line                  |



| R_ | _SU_CTR     | L2             |                           | (w) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                               | 0x33                             |
|----|-------------|----------------|---------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| Co | ontrol regi | ister of the   | e line interface, registe | r 2 |                                                                                                                                                                                                                                                                                      |                                  |
|    | Bits        | Reset<br>value | Name                      |     | Description                                                                                                                                                                                                                                                                          |                                  |
|    | 0           | 0              | V_B1_RX_EN                |     | Enable B1-channel receive<br>'0' = B1 receive bits are forced to '1'<br>'1' = normal operation                                                                                                                                                                                       |                                  |
|    | 1           | 0              | V_B2_RX_EN                |     | Enable B2-channel receive<br>'0' = B2 receive bits are forced to '1'<br>'1' = normal operation                                                                                                                                                                                       |                                  |
|    | 2           | 0              | V_MS_SSYNC2               |     | Multiframe / superframe single synchroniz<br>pulse<br>The multiframe / superframe synchronization<br>can be configured to occur only once when the<br>is set to '1'.                                                                                                                 | <b>ation</b><br>pulse<br>nis bit |
|    |             |                |                           |     | S/T interface mode:<br>'0' = normal multiframing bit M is transmitte<br>(once every 20 S/T frames)<br>'1' = single multiframing bit can be transmitte                                                                                                                                | d<br>ed                          |
|    |             |                |                           |     | <b>Up interface mode:</b><br>'0' = normal T-bit is transmitted in Up superfit<br>'1' = single T-bit = '0' can be transmitted at T-<br>position in the Up superframe (normal T-bit<br>sources should not be used)                                                                     | rame<br>-bit                     |
|    |             |                |                           |     | <b>Note:</b> When this bit is set to '1', usually also V_MS_SSYNC1 has to be set in register R_N                                                                                                                                                                                     | MSS1.                            |
|    | 3           | 0              | V_BAC_S_SEL               |     | Multiframe / superframe bit source selection<br>This bit has different meaning for the line into<br>in S/T or Up mode:<br>S/T interface mode: Source selection of<br>multiframe S/Q-bits and multframing bit M<br>Up interface mode: Source selection of<br>superframe S- and T-bits | on<br>erface                     |
|    |             |                |                           |     | '0' = bits come from register R_BAC_S_TX<br>'1' = bits come from D-channel register R_D.                                                                                                                                                                                             | _тх                              |
|    |             |                |                           |     | <b>Note:</b> Further source selection is available w register R_MS_DF.                                                                                                                                                                                                               | ith                              |
|    | 4           | 0              | V_SU_SYNC_NT              |     | <ul> <li>8 kHz synchronization pulses of the line interpath are generated even in NT mode.</li> <li>'0' = pulses are only generated in TE mode</li> <li>'1' = pulses are generated in TE and NT mode.</li> </ul>                                                                     | rface<br>e                       |

(continued on next page)



i.

(continued from previous page)

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                            |
|------|----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5    | 0              | V_SU_2KHZ  | Select test signal frequency<br>'0' = transmit 96 kHz (S/T interface mode) or<br>192 kHz (Up interface mode) test signal<br>'1' = transmit 2 kHz test signal<br>The test signal must be switched on with<br>V_SU_TST_SIG = '1' in register R_SU_CTRL0. |
| 6    | 0              | V_SU_TRI   | Line interface ouput buffer tristated<br>'0' = normal operation<br>'1' = set output buffer into tristate mode (i.e.<br>transmitter is switched off)                                                                                                    |
| 7    | 0              | V_SU_EXCHG | <b>Exchange transmit output buffers</b><br>Change of the polarity of the line interface output<br>pins. This is equal to an external crossing of the<br>two transmit pins.                                                                             |



| R_ | _MS_TX    |                |                       | (w) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                                                           | 0x34                  |
|----|-----------|----------------|-----------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
| М  | ultiframe | /superfra      | ame transmit register |     |                                                                                                                                                                                                                                                                                                                                                                                                  |                       |
|    | Bits      | Reset<br>value | Name                  |     | Description                                                                                                                                                                                                                                                                                                                                                                                      |                       |
|    | 30        | 0              | V_MS_TX               |     | Multiframe / superframe bits<br>The meaning of this bitmap depends on the<br>selected line interface mode:<br>S/T interface mode: S/Q bits to be transmitted<br>the multiframe. Bits [30] are Q bits<br>[Q1,Q2,Q3,Q4] in TE mode and S bits<br>[S1,S2,S3,S4] in NT mode.<br>Up interface mode: T bits to be transmitted if<br>superframe (M-channel). Bits [30] are T bits<br>[T1a,T1b,T2a,T2b]. | ed in<br>in the<br>ts |
|    | 54        | 0              | (reserved)            |     | Must be '00'.                                                                                                                                                                                                                                                                                                                                                                                    |                       |
|    | 6         | 0              | V_UP_S_TX             |     | S-bit of the Up superframe<br>S-bit to be transmitted in the superframe<br>(M-channel). The S-bit can be read from regis<br>R_D_TX or R_BAC_S_TX alternatively.<br>Note: This bit is only used when the line inter<br>is in Up interface mode. It must be '0' in S/T<br>interface mode.                                                                                                          | sters<br>rface        |
|    | 7         | 0              | (reserved)            |     | Must be '0'.                                                                                                                                                                                                                                                                                                                                                                                     |                       |



| R_ST_C             | TRL3                              |                                         | (w)                                              | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                 | 0x35                                                   |
|--------------------|-----------------------------------|-----------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|
| Control            | register of th                    | e line interface, reg                   | gister 3                                         |                                                                                                                                                                                                                                                                        |                                                        |
| This regi          | ster is a multi                   | -register. It is selected               | ed with bit V_S                                  | $T\_SEL = '0'$ in this register.                                                                                                                                                                                                                                       |                                                        |
| Note: The when the | nis register is<br>line interface | only used in S/T in<br>e is in Up mode. | iterface mode a                                  | nd should be 0xF8. See register R                                                                                                                                                                                                                                      | _UP_CTRL3                                              |
| Bits               | Reset<br>value                    | Name                                    | De                                               | scription                                                                                                                                                                                                                                                              |                                                        |
| 0                  | 0                                 | V_ST_SEL                                | Lin<br>Th<br>lin<br>'0'<br>mu<br>'1'<br>R_<br>No | ne interface mode selection<br>is bit selects either the S/T or Up n<br>e interface.<br>= line interface is in S/T mode and<br>ilti-register R_ST_CTRL3 is select<br>= line interface is in Up mode and<br>UP_CTRL3 is selected<br>ote: This bit should only be change | node of the<br>ted<br>multi-register<br>d after reset. |
| 71                 | 0                                 | V_ST_PULSE                              | En<br>Th<br>adj<br>sho                           | d of pulse control<br>e triggering point of the pulse end<br>usted with this bitmap. V_ST_PU<br>ould be used.                                                                                                                                                          | can be<br>LSE = 0x7C                                   |



| R_       | _UP_CTR                  | L3                | (w)                                | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                      | 0x35                                |
|----------|--------------------------|-------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Co       | ontrol reg               | ister of th       | e line interface, register 3       |                                                                                                                                                                                                                                                                                                                             |                                     |
| Th       | is register              | is a multi        | -register. It is selected with bit | $/\_ST\_SEL = '1'$ in this register.                                                                                                                                                                                                                                                                                        |                                     |
| No<br>is | ote: This n<br>in S/T mo | egister is<br>de. | only used in Up interface mode     | . See register R_ST_CTRL3 when the line i                                                                                                                                                                                                                                                                                   | nterface                            |
|          | Bits                     | Reset<br>value    | Name                               | Description                                                                                                                                                                                                                                                                                                                 |                                     |
|          | 0                        | 0                 | V_UP_SEL                           | Line interface mode selection<br>This bit selects either the S/T or Up mode of<br>line interface.<br>'0' = line interface is in S/T mode and<br>multi-register R_ST_CTRL3 is selected<br>'1' = line interface is in Up mode and multi-<br>R_UP_CTRL3 is selected<br>Note: This bit should only be changed after             | of the<br>-register<br>r reset.     |
|          | 1                        | 0                 | V_UP_VIO                           | Activation is only done when a superframe violation is found.                                                                                                                                                                                                                                                               |                                     |
|          | 2                        | 0                 | V_UP_DC_STR                        | DC-balancing mode<br>'0' = The DC-balancing bit is only generate<br>a code violation (CV) has been sent in the M<br>position (normal operation)<br>'1' = The DC-balancing bit is always generate<br>achieve a DC-free signal<br>Note: DC-balancing must be enabled with<br>V_UP_DC_OFF = '0' to generate DC-balate<br>bits. | d when<br>M bit<br>ated to<br>ncing |
|          | 3                        | 0                 | V_UP_DC_OFF                        | DC-balancing bit disabled<br>'0' = normal operation<br>'1' = The DC-balancing bit is always '0'                                                                                                                                                                                                                             |                                     |
|          | 4                        | 0                 | V_UP_RPT_PAT                       | Allow repeated patterns of scrambled da<br>'0' = prevent repeated patterns as specified is<br>V_UP_SCRM_MD (normal operation)<br>'1' = repeated patterns are not prevented                                                                                                                                                  | <b>ta</b><br>n bit                  |
|          | 5                        | 0                 | V_UP_SCRM_MD                       | Scrambler / descrambler mode selection<br>'0' = OCTAT-P mode (compatible to<br>Siemens / Infineon Up microchips)<br>'1' = V.27 mode (compatible to ITU-T V.27<br>specification)<br>Note: V_UP_RPT_PAT must be '0' to prev<br>repeated patterns.                                                                             | ent                                 |

(continued on next page)



(continued from previous page)

| Bits | Reset<br>value | Name             | Description                                                                                                                                          |
|------|----------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | 0              | V_UP_SCRM_TX_OFF | <b>Transmit scrambler disabled</b><br>The transmit data is not scrambled when this bit is<br>set to '1'. The scrambler is bypassed in this case.     |
| 7    | 0              | V_UP_SCRM_RX_OFF | <b>Receive descrambler disabled</b><br>The receive data is not descrambled when this bit is<br>set to '1'. The descrambler is bypassed in this case. |



| R_ | _MS_DF    |                |                        | (w)      | (Reset group: H, 0, 3) <b>0</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 36  |
|----|-----------|----------------|------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| M  | ultiframe | / superfra     | me data flow configura | ntion re | gister                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
|    | Bits      | Reset<br>value | Name                   |          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
|    | 0         | 0              | V_BAC_NINV             |          | No BAC-bit inversion<br>'0' = invert BAC-bit<br>'1' = no inversion of BAC-bit                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|    | 1         | 0              | V_SG_AB_INV            |          | Invert S/G or A/B bit<br>'0' = normal operation<br>'1' = invert S/G or A/B bit (depending on<br>V_SQ_T_DST)                                                                                                                                                                                                                                                                                                                                                                                                             |     |
|    | 2         | 0              | V_SQ_T_SRC             |          | Source of S/Q-bits (S/T multiframe) or T-bits<br>(Up superframe)<br>'0' = S/Q- or T-bits come from bitmap V_MS_T.<br>in register R_MS_TX<br>'1' = S/Q- or T-bits come from BAC-bit of D- or<br>E-channel (depending on V_BAC_S_SEL)                                                                                                                                                                                                                                                                                     | x   |
|    | 3         | 0              | V_M_S_SRC              |          | Source of M-bit (S/T multiframing bit) or S-b<br>(Up superframe)<br>S/T interface mode:<br>The meaning of this bit depends on the selected<br>line interface mode:<br>'0' = multiframing bit M comes from<br>multiframe / superframe controller<br>'1' = multiframing bit M comes from D- or<br>E-channel (depending on V_BAC_S_SEL)<br>Up interface mode:<br>'0' = superframe bit S comes from bit<br>V_UP_S_TX in register R_MS_TX<br>'1' = superframe bit S comes from D- or E-channel<br>(depending on V_BAC_S_SEL) | nel |
|    | 4         | 0              | V_SQ_T_DST             |          | Destination of S/Q-bits (S/T multiframe) or<br>T-bits (Up superframe)<br>'0' = received bits are stored as S/G-bit in D- and<br>E-channel registers<br>'1' = received bits are stored as A/B-bit in D- and<br>E-channel registers<br>The unused destination bit is always '1'.                                                                                                                                                                                                                                          | 1   |
|    | 5         | 0              | V_SU_RX_VAL            |          | Value of unused bits in received D- and<br>E-channel<br>The unused bits [31] in registers R_D_RX and<br>R_E_RX are set to V_SU_RX_VAL.                                                                                                                                                                                                                                                                                                                                                                                  | d   |
|    | 76        | 0              | (reserved)             |          | Must be '00'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |



| R_       | SU_CLK                                                                                                                                                                        | _DLY           |              | (w) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0x37                                                                                              |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| Cl<br>Th | <b>Clock control register of the line interface module</b><br>This register is not initialized after reset. It must be initialized before activating the ST/Up state machine. |                |              |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                   |
|          | Bits                                                                                                                                                                          | Reset<br>value | Name         |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                   |
|          | 30                                                                                                                                                                            | 0              | V_SU_CLK_DLY |     | Line interface clock delay<br>TE mode (S/T or Up): 4 bit delay value to a<br>the 2 bit delay between receive and transmit<br>The delay of the external line interface circui<br>can be compensated. The lower the value the<br>smaller the delay between receive and transm<br>direction. The suitable value is 0xE (S/T inter<br>mode) or 0xF (Up interface mode) for normal<br>external circuitries.<br>NT mode (for S/T interface mode only): D<br>sample point. The lower the value the earlier<br>input data is sampled. The normal operation<br>is 0xC.<br>LT mode (for Up interface mode only): Th<br>bitmap is not used when the line interface op<br>in Up mode.<br>The steps are 163 ns for the line interface in 5 | adjust<br>frame.<br>itry<br>itry<br>nit<br>erface<br>il<br>oata<br>the<br>value<br>nis<br>oerates |
|          |                                                                                                                                                                               |                |              |     | mode and 81 ns for the line interface in Up n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | node.                                                                                             |
|          | 64                                                                                                                                                                            | 0              | V_ST_SMPL    |     | Early edge input data shaping<br>(NT mode only)<br>Low pass characteristic of extended bus<br>configurations can be compensated. The low<br>value the earlier input data pulses are sample<br>The default value is 6 ('110') which means th<br>compensation is carried out. Step size is 163<br><b>Note:</b> This bit is only used when the line inter-<br>is in S/T mode. It must be '0' in Up interface                                                                                                                                                                                                                                                                                                                     | er the<br>ed.<br>at no<br>ns.<br>erface<br>mode.                                                  |
|          | 7                                                                                                                                                                             | 0              | (reserved)   |     | Must be '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                   |



| R        | _B1_TX                                                                                                                                          |                |                  | (w)                          | (Reset group: –)                                                                     | 0x3C                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------|------------------------------|--------------------------------------------------------------------------------------|----------------------|
| Tr       | ansmit r                                                                                                                                        | egister for    | the B1-channel o | data                         |                                                                                      |                      |
| Th<br>sh | This register is written automatically by the flow controller and need not be accessed by the user. FIFOs should be used to write data instead. |                |                  |                              |                                                                                      |                      |
|          | Bits                                                                                                                                            | Reset<br>value | Name             | Desc                         | ription                                                                              |                      |
|          | 70                                                                                                                                              |                | V_B1_TX          | <b>B1-c</b><br>Data<br>phase | hannel data byte<br>can be written during the non-p<br>e (see V_PROC in register R_S | rocessing<br>TATUS). |

| R        | _B2_TX                                                                                                                                          |                |                     | (w)                        | (Reset group: -)                                                                          | 0x3D               |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------|----------------------------|-------------------------------------------------------------------------------------------|--------------------|
| Т        | ransmit r                                                                                                                                       | egister for    | the B2-channel data |                            |                                                                                           |                    |
| Tł<br>sh | This register is written automatically by the flow controller and need not be accessed by the user. FIFOs should be used to write data instead. |                |                     |                            |                                                                                           |                    |
|          | Bits                                                                                                                                            | Reset<br>value | Name                | Dese                       | cription                                                                                  |                    |
|          | 70                                                                                                                                              |                | V_B2_TX             | <b>B2-</b><br>Data<br>phas | channel data byte<br>a can be written during the non-pr<br>e (see V_PROC in register R_ST | ocessing<br>ATUS). |
|          |                                                                                                                                                 |                |                     |                            |                                                                                           |                    |



| R_       | _D_TX                                    |                |                           | (w)                                                 | (Reset group: –)                                                                                                                                                        | 0x3E                                    |  |
|----------|------------------------------------------|----------------|---------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--|
| Tr<br>Tł | Transmit register for the D-channel data |                |                           |                                                     |                                                                                                                                                                         |                                         |  |
| sh       | ould be us                               | sed to write   | e data instead.           |                                                     |                                                                                                                                                                         |                                         |  |
| Da       | ata can be                               | written du     | ring the non-processing p | bhase (see V_I                                      | PROC in register R_STATUS).                                                                                                                                             |                                         |  |
|          | Bits                                     | Reset<br>value | Name                      | Desci                                               | iption                                                                                                                                                                  |                                         |  |
|          | 0                                        |                | V_D_TX_S                  | S-bit<br>The tr<br>either<br>V_MS<br>When<br>be use | of the Up superframe<br>ransmitted S-bit of the Up super<br>taken from V_D_TX_S, V_S<br>S_TX.<br>the line interface is in S/T mode<br>as multiframing bit M.            | rframe is<br>_TX or<br>de, this bit can |  |
|          | 41                                       |                | (reserved)                | Must                                                | be '0000' when written.                                                                                                                                                 |                                         |  |
|          | 5                                        |                | V_D_TX_BAC                | BAC-<br>The E<br>multit<br>Altern<br>R_M3<br>multit | bit<br>AC-bit can be used as S/Q-bit<br>frame) or T-bit (Up superframe)<br>natively, bitmap V_MS_TX in r<br>S_TX can be used for the<br>frame / superframe transmission | (S/T<br>).<br>egister<br>1.             |  |
|          | 76                                       |                | V_D_TX                    | D-cha                                               | annel data bits                                                                                                                                                         |                                         |  |



| R_BAC_S_TX                                                                                                                                                                                                         |            | (w)                                                               | (Reset group: –)                                                                                                                                                    | 0x3F                          |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--|--|
| <b>BAC-bit and S-bit for multiframe/superframe transmission</b><br>This register is written automatically by the flow controller and need not be accessed by the user. FIFOs should be used to write data instead. |            |                                                                   |                                                                                                                                                                     |                               |  |  |
| Bits Reset<br>value                                                                                                                                                                                                | Name       | Descrip                                                           | tion                                                                                                                                                                |                               |  |  |
| 0                                                                                                                                                                                                                  | V_S_TX     | S-bit of<br>The tran<br>either be<br>V_D_T.<br>When th<br>be used | the Up superframe<br>smitted S-bit of the Up superfram<br>taken from V_D_TX_S, V_S_T<br>X_S.<br>he line interface is in S/T mode, th<br>as multiframing M-bit.      | ie is<br>"X or<br>iis bit can |  |  |
| 41                                                                                                                                                                                                                 | (reserved) | Must be                                                           | '0000' when written.                                                                                                                                                |                               |  |  |
| 5                                                                                                                                                                                                                  | V_BAC_TX   | BAC-bi<br>The BA<br>multifra<br>Alternat<br>R_MS_<br>multifra     | t<br>C-bit can be used as S/Q-bit (S/T<br>me) or T-bit (Up superframe).<br>ively, bitmap V_MS_TX in regist<br>TX can be used for the<br>me/superframe transmission. | er                            |  |  |
| 76                                                                                                                                                                                                                 | (reserved) | Must be                                                           | '00' when written.                                                                                                                                                  |                               |  |  |



### 5.5.2 Read only registers

| R_ | _SU_RD_                      | _STA           | (                              | ( <b>r</b> )                                                                                  | (Reset group: H, 0, 3)                                                                                                                                                                    | 0x30                     |
|----|------------------------------|----------------|--------------------------------|-----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| ST | ST/Up state machine register |                |                                |                                                                                               |                                                                                                                                                                                           |                          |
| Tł | nis register                 | is used to     | o read the current state. A no | ew state                                                                                      | e can be set with the R_SU_WR_STA                                                                                                                                                         | register.                |
|    | Bits                         | Reset<br>value | Name                           | Ι                                                                                             | Description                                                                                                                                                                               |                          |
|    | 30                           | 0              | V_SU_STA                       | S<br>E                                                                                        | <b>T/Up state</b><br>Binary value of current state (NT/LT: 0                                                                                                                              | Gx, TE: Fx)              |
|    | 4                            | 0              | V_SU_FR_SYNC                   | <b>H</b><br>'(                                                                                | Strame synchronization<br>D' = not synchronized<br>L' = synchronized                                                                                                                      |                          |
|    | 5                            | 0              | V_SU_T2_EXP                    | ]<br>,.                                                                                       | <b>Timer T2 expired</b><br>I' = timer T2 expired (NT/LT mode or                                                                                                                           | nly)                     |
|    | 6                            | 0              | V_SU_INFO0                     | <b>I</b> ,,,                                                                                  | <b>NFO 0</b><br>I' = receiving INFO 0                                                                                                                                                     |                          |
|    | 7                            | 0              | V_G2_G3                        | (<br>'(<br>',<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>'<br>' | <b>G2 to G3 transition allowed</b><br>D' = no operation<br>H' = allows transition from G2 to G3 in<br>hode<br>This bit is automatically cleared after t<br>nd has no function in TE mode. | n NT/LT<br>he transition |



| R_SU_DLYL | ( <b>r</b> ) | (Reset group: –) | 0x31 |
|-----------|--------------|------------------|------|
|           | · /          |                  |      |

#### NT-TE-NT/LT-TE-LT delay

This register shows the round trip delay and is only valid in NT/LT mode. It is updated once every 250 µs.

**Line interface in S/T mode:** This register reports the delay between the F-/L-bit transition of the transmit frame to the F-/L-bit transition of the receive frame of a device in NT mode. The resolution is  $t_0 = 1/6.144$  MHz = 1/32 bit length = 162.8 ns. The minimum delay is 2 bit times because of the NT/TE frame offset.

**Line interface in Up mode:** This register reports the *end of transmit frame* to *begin of receive frame* delay of a device in LT mode. The resolution is  $t_0 = 1/12.288 \text{ MHz} = 1/32 \text{ bit length} = 81.4 \text{ ns}$ . The minimum delay is 2 bit times because of the guard time.

In both line interface modes, the round trip delay is measured within a 10 bit range. The lower 5 bits can be read from this register, the upper 5 bits are stored in register R\_SU\_DLYH.

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40   |                | V_SU_DLYL  | <b>Lower part of the round trip delay</b><br>The lower part of the delay time<br>$t_{dly,l} = t_0 \cdot V\_SU\_DLYL$ .<br>Register R\_SU\_DLYH must also be read to obtain<br>the whole delay $t_{dly} = t_{dly,l} + t_{dly,h}$ .<br><b>S/T interface mode:</b><br>$0 = delay t_{dly,l} = 0 \text{ ns}$<br>$1 = delay t_{dly,l} = 162.8 \text{ ns}$<br>$2 = delay t_{dly,l} = 325.5 \text{ ns}$<br>$3 = delay t_{dly,l} = 488.3 \text{ ns}$<br><br>$31 = delay t_{dly,l} = 5045.6 \text{ ns}$<br><b>Up interface mode:</b><br>$0 = delay t_{dly,l} = 81.4 \text{ ns}$<br>$2 = delay t_{dly,l} = 162.8 \text{ ns}$<br>$3 = delay t_{dly,l} = 244.1 \text{ ns}$<br> |
|      |                |            | $51 = \text{deray } t_{dly,l} = 2522.8 \text{ns}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 75   |                | (reserved) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| R_SU_DLYH | ( <b>r</b> ) | (Reset group: $-$ ) | 0x32 |
|-----------|--------------|---------------------|------|
|           | (1)          | (Itebet Broup. )    | UNUE |

#### NT-TE-NT / LT-TE-LT delay

This register shows the round trip delay and is only valid in NT/LT mode. It is updated once every 250 µs.

**Line interface in S/T mode:** This register reports the delay between the F-/L-bit transition of the transmit frame to the F-/L-bit transition of the receive frame of a device in NT mode. The resolution is  $t_0 = 1/6.144 \text{ MHz} = 1/32 \text{ bit length} = 162.8 \text{ ns.}$  The minimum delay is 2 bit times because of the NT/TE frame offset.

**Line interface in Up mode:** This register reports the *end of transmit frame* to *begin of receive frame* delay of a device in LT mode. The resolution is  $t_0 = 1/12.288 \text{ MHz} = 1/32 \text{ bit length} = 81.4 \text{ ns}$ . The minimum delay is 2 bit times because of the guard time.

In both line interface modes, the round trip delay is measured within a 10 bit range. The lower 5 bits are stored in register R\_SU\_DLYL, the upper 5 bits can be read from this register. if only this register is read, the resolution is  $32 \cdot t_0 = 5.208 \,\mu\text{s}$  for a line interface in S/T mode and  $32 \cdot t_0 = 2.604 \,\mu\text{s}$  for a line interface in Up mode, which is the length of one bit in both cases.

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 40   |                | V_SU_DLYH  | Upper part of the round trip delay<br>The upper part of the delay time<br>$t_{dly,h} = 32 \cdot t_0 \cdot V\_SU\_DLYH.$<br>Register R_SU_DLYL can be read to obtain the<br>fractional part of a bit time delay.<br>S/T interface mode:<br>$0 = delay t_{dly,h} = 0 \mu s$<br>$1 = delay t_{dly,h} = 5.208 \mu s$<br>$2 = delay t_{dly,h} = 10.416 \mu s$<br>$3 = delay t_{dly,h} = 15.625 \mu s$<br><br>$31 = delay t_{dly,h} = 161.458 \mu s$<br>Up interface mode: |
|      |                |            | $0 = \text{ delay } t_{dly,h} = 0 \mu\text{s}$<br>$1 = \text{ delay } t_{dly,h} = 2.604 \mu\text{s}$<br>$2 = \text{ delay } t_{dly,h} = 5.208 \mu\text{s}$<br>$3 = \text{ delay } t_{dly,h} = 7.812 \mu\text{s}$<br><br>$31 = \text{ delay } t_{dly,h} = 80.729 \mu\text{s}$                                                                                                                                                                                         |
| 75   |                | (reserved) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



| R_ | _MS_RX                                   |                |             | ( <b>r</b> ) | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                                                   | 0x34                          |
|----|------------------------------------------|----------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| M  | Multiframe / superframe receive register |                |             |              |                                                                                                                                                                                                                                                                                                                                                                                          |                               |
|    | Bits                                     | Reset<br>value | Name        |              | Description                                                                                                                                                                                                                                                                                                                                                                              |                               |
|    | 30                                       |                | V_MS_RX     |              | Multiframe / superframe bits<br>The meaning of this bitmap depends on the<br>selected line interface mode:<br>S/T interface mode: S/Q bits received in the<br>multiframe. Bits [30] are S bits [S1,S2,S3,<br>TE mode and are Q bits [Q1,Q2,Q3,Q4] in N<br>mode.<br>Up interface mode: T bits received in two<br>consecutive superframes (M-channel). Bits [are T bits [T1a,T1b,T2a,T2b]. | e<br>S4] in<br>IT<br>30]      |
|    | 4                                        | 0              | V_MS_RX_RDY |              | Received multiframe/superframe ready<br>S/T interface mode: This bit gets '1' when a<br>complete S or Q multiframe has been received<br>is ready to get read.<br>Up interface mode: This bit gets '1' when tw<br>complete T superframes have been received a<br>are ready to get read.<br>Reading this register clears this bit.                                                         | ed and<br>vo<br>and           |
|    | 5                                        |                | (reserved)  |              |                                                                                                                                                                                                                                                                                                                                                                                          |                               |
|    | 6                                        |                | V_UP_S_RX   |              | S-bit of the Up superframe<br>Last received S-bit of the superframe (M-cha<br>The S-bit is also stored in registers R_D_RX<br>R_E_RX.<br>Note: This bit is only used when the line inter<br>is in Up mode. It is undefined in S/T interface<br>mode.                                                                                                                                     | annel).<br>and<br>erface<br>e |
|    | 7                                        | 0              | V_MS_TX_RDY |              | Transmitted multiframe/superframe read<br>S/T interface mode: This bit gets '1' when a<br>S or Q multiframe can be written into register<br>R_MS_TX<br>Up interface mode: This bit gets '1' when tw<br>new T superframes can be written into register<br>R_MS_TX<br>Writing to register R_MS_TX clears this bit.                                                                         | ly<br>new<br>r<br>vo<br>er    |



| R_        | _SU_STA                                                                                                                                             |                |                | ( <b>r</b> )                                                                          | (Reset group: –)                                                                                                                                                                                                                                                                          | 0x35                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|---------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| St        | Status register of the line interface                                                                                                               |                |                |                                                                                       |                                                                                                                                                                                                                                                                                           |                                                                  |
| Oi<br>reg | Only bit V_SU_AF0 is used when the line interface is in either S/T or Up mode. All other bits of this register are only used in S/T interface mode. |                |                |                                                                                       |                                                                                                                                                                                                                                                                                           |                                                                  |
|           | Bits                                                                                                                                                | Reset<br>value | Name           | Desc                                                                                  | cription                                                                                                                                                                                                                                                                                  |                                                                  |
|           | 0                                                                                                                                                   | 0              | V_ST_D_HPRIO9  | Curr<br>prior<br>Whe<br>$V_S$<br>this b<br>number<br>allow<br>'0' =<br>'1' =<br>Note  | rent D-channel priority state if<br>rity is selected<br>n high D-channel priority is select<br>T_D_LPRIO = '0' in register R_S<br>bit reports the current access prior<br>ber of '1's before a D-channel acc<br>ved.<br>8 bits '1'<br>9 bits '1'<br>e: This bit is only valid in S/T inte | high<br>ted with<br>SU_CTRL0,<br>rity, i.e. the<br>ess is        |
|           | 1                                                                                                                                                   | 0              | V_ST_D_LPRIO11 | Curr<br>is set<br>Whe<br>$V_S$<br>this b<br>number<br>allow<br>'0' =<br>'1' =<br>Note | rent D-channel priority state if<br>lected<br>n low D-channel priority is select<br>T_D_LPRIO = '1' in register R_S<br>bit reports the current access prior<br>ber of '1's before a D-channel acc<br>ved.<br>10 bits '1'<br>11 bits '1'<br>e: This bit is only valid in S/T inte          | low priority<br>ed with<br>SU_CTRL0,<br>rity, i.e. the<br>ess is |
|           | 2                                                                                                                                                   | 0              | V_ST_D_CONT    | <b>D-ch</b><br>This<br>E-ch<br>'0' =<br>'1' =<br><b>Note</b>                          | annel contention<br>bit reports a difference between I<br>annel.<br>no contention occured<br>contention occured in the last fra<br>this bit is only valid in S/T inte                                                                                                                     | D- and<br>me<br>erface mode.                                     |
|           | 3                                                                                                                                                   | 0              | V_ST_D_ACT     | <b>D-ch</b><br>This<br>just t<br><b>Note</b>                                          | annel active<br>bit has the value '1' when the D-o<br>ransmitting data.<br>This bit is only valid in S/T into                                                                                                                                                                             | hannel is<br>erface mode.                                        |
|           | 64                                                                                                                                                  |                | (reserved)     |                                                                                       |                                                                                                                                                                                                                                                                                           |                                                                  |
| İ         |                                                                                                                                                     |                |                |                                                                                       |                                                                                                                                                                                                                                                                                           |                                                                  |

(continued on next page)



(continued from previous page)

| Bits R | Reset | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 0    |       | V_SU_AF0 | FSC selection<br>The frame synchronisation clock can either be the<br>F0IO input signal or the AF0 signal which is F0IO<br>delayed for 62.5 µs. This bit reports the current<br>selection and can be stored by the application<br>software to detect changes. An interrupt can be<br>enabled which indicates a change of this bit (see<br>V_SLIP_IRQMSK in register R_MISC_IRQMSK).<br>'0' = F0IO used<br>'1' = AF0 used |

| R_                                                                                                                                        | _B1_RX |                |                                                                | ( <b>r</b> )                                  | (Reset group: –)                                                                                                                                                 | 0x3C                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------|--------|----------------|----------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| <b>Receive register for the B1-channel data</b><br>This register is read automatically by the flow contr<br>be used to read data instead. |        |                | <b>ne B1-channel data</b><br>tomatically by the flow<br>stead. | w controller and                              | need not be accessed by the user.                                                                                                                                | FIFOs should                                    |
|                                                                                                                                           | Bits   | Reset<br>value | Name                                                           | Desc                                          | ription                                                                                                                                                          |                                                 |
|                                                                                                                                           | 70     |                | V_B1_RX                                                        | <b>B1-c</b><br>In ac<br>pulse<br>phas<br>Regi | hannel data byte<br>tivated state data is valid after a<br>and can be read during the non-<br>e (see V_PROC in register R_S<br>ster value is 0xFF in deactivated | F0IO or AF0<br>-processing<br>TATUS).<br>state. |

| R_B2_RX | ( <b>r</b> ) | (Reset group: –) | 0x3D |
|---------|--------------|------------------|------|
|         |              |                  |      |

#### Receive register of the B2-channel data

This register is read automatically by the flow controller and need not be accessed by the user. FIFOs should be used to read data instead.

| Bits Reset value | Name    | Description                                                                                                                                                                                                                        |
|------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 70               | V_B2_RX | <b>B2-channel data byte</b><br>In activated state data is valid after a F0IO or AF0<br>pulse and can be read during the non-processing<br>phase (see V_PROC in register R_STATUS).<br>Register value is 0xFF in deactivated state. |



| R_        | D_RX                                    |                           |                                     | ( <b>r</b> )                                       | (Reset group: -)                                                                                                                                                                                                    | 0x3E                                                                 |
|-----------|-----------------------------------------|---------------------------|-------------------------------------|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Re        | Receive register for the D-channel data |                           |                                     |                                                    |                                                                                                                                                                                                                     |                                                                      |
| Th<br>be  | is register<br>used to re               | is read au<br>ead data in | tomatically by the flow cont stead. | roller and                                         | need not be accessed by the user.                                                                                                                                                                                   | FIFOs should                                                         |
| Da<br>reg | ta is valic<br>gister R_S               | l after a F(<br>STATUS).  | DIO or AF0 pulse and can b          | e read dur                                         | ing the non-processing phase (se                                                                                                                                                                                    | e V_PROC in                                                          |
|           | Bits                                    | Reset<br>value            | Name                                | Desc                                               | cription                                                                                                                                                                                                            |                                                                      |
|           | 0                                       |                           | V_D_RX_S                            | S-bi<br>Last<br>The<br>R_M<br>Note<br>is in<br>mod | t of the Up superframe<br>received S-bit of the superframe<br>S-bit is also stored in registers R.<br>IS_RX.<br>This bit is only used when the<br>Up mode. It is undefined in S/T<br>e.                             | (M-channel).<br>_E_RX and<br>line interface<br>interface             |
|           | 31                                      |                           | (reserved)                          | A re<br>of V                                       | ad access to these unused bits ret<br>_SU_RX_VAL in register R_MS                                                                                                                                                   | urns the value                                                       |
|           | 4                                       |                           | V_D_RX_AB                           | A/B<br>Whe<br>cont<br>mult<br>supe<br>V_S<br>from  | <b>bit</b><br>in V_SQ_T_DST = '1', V_D_RX<br>ains either the last received S/Q-1<br>iframe or the last received T-bit of<br>rframe. V_D_RX_AB is constant<br>iQ_T_DST = '0'. The A/B-bit can<br>in register R_E_RX. | (_AB<br>bit of the S/T<br>of the Up<br>it '1' when<br>n also be read |
|           | 5                                       |                           | V_D_RX_SG                           | S/G·<br>Whe<br>cont<br>mult<br>supe<br>V_S<br>from | bit<br>n V_SQ_T_DST = '0', V_D_R)<br>ains either the last received S/Q-1<br>iframe or the last received T-bit of<br>rframe. V_D_RX_SG is constar<br>Q_T_DST = '1'. The S/G-bit can<br>n register R_E_RX.            | (_SG<br>bit of the S/T<br>of the Up<br>nt '1' when<br>n also be read |
|           | 76                                      |                           | V_D_RX                              | <b>D-ch</b><br>Data<br>read<br>V_P                 | nannel data bits<br>is valid after a F0IO or AF0 pul<br>during the non-processing phase<br>PROC in register R_STATUS).                                                                                              | se and can be<br>(see                                                |



|--|

#### **Receive register of the E-channel data**

This register is read automatically by the flow controller and need not be accessed by the user. FIFOs should be used to read data instead.

Data is valid after a F0IO or AF0 pulse and can be read during the non-processing phase (see V\_PROC in register  $R\_STATUS$ ).

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                                                                                                 |
|------|----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    |                | V_E_RX_S   | <ul> <li>S-bit of the Up superframe</li> <li>Last received S-bit of the superframe (M-channel).</li> <li>The S-bit is also stored in registers R_D_RX and</li> <li>R_MS_RX.</li> <li>Note: This bit is only used when the line interface</li> <li>is in Up mode. It is undefined in S/T interface</li> <li>mode.</li> </ul> |
| 31   |                | (reserved) | A read access to these unused bits returns the value of V_SU_RX_VAL in register R_MS_DF.                                                                                                                                                                                                                                    |
| 4    |                | V_E_RX_AB  | A/B-bit<br>When V_SQ_T_DST = '1', V_E_RX_AB<br>contains either the last received S/Q-bit of the S/T<br>multiframe or the last received T-bit of the Up<br>superframe. V_E_RX_AB is constant '1' when<br>V_SQ_T_DST = '0'. The A/B-bit can also be read<br>from register R_D_RX.                                             |
| 5    |                | V_E_RX_SG  | S/G-bit<br>When V_SQ_T_DST = '0', V_E_RX_SG<br>contains either the last received S/Q-bit of the S/T<br>multiframe or the last received T-bit of the Up<br>superframe. V_E_RX_SG is constant '1' when<br>V_SQ_T_DST = '1'. The S/G-bit can also be read<br>from register R_D_RX.                                             |
| 76   |                | V_E_RX     | <b>E-channel data bits</b><br>Data is valid after a F0IO or AF0 pulse and can be<br>read during the non-processing phase (see<br>V_PROC in register R_STATUS).                                                                                                                                                              |



# Chapter 6

# **PCM interface**

| Write only | y registers: |      | Read only registers: |                |       |  |
|------------|--------------|------|----------------------|----------------|-------|--|
| Address    | Name         | Page | Address              | Name           | Page  |  |
| 0x10       | R_SLOT       | 245  | 0x18                 | R_F0_CNTL      | 263   |  |
| 0x14       | R_PCM_MD0    | 246  | 0x19                 | R_F0_CNTH      | 263   |  |
| 0x15       | R_SL_SEL0    | 247  | 0x1D                 | R_SL_MAX       | 263   |  |
| 0x15       | R_SL_SEL1    | 248  | 0x28                 | R_CI_RX        | 264   |  |
| 0x15       | R_SL_SEL7    | 248  | 0x29                 | R_GCI_STA      | 265   |  |
| 0x15       | R_MSS0       | 249  | 0x2A                 | R_MON_RX       | 265   |  |
| 0x15       | R_PCM_MD1    | 251  |                      |                |       |  |
| 0x15       | R_PCM_MD2    | 253  | Read/wri             | ite registers: |       |  |
| 0x15       | R_MSS1       | 255  | Address              | Name           | Раде  |  |
| 0x15       | R_SH0L       | 256  |                      |                | - uge |  |
| 0x15       | R_SH0H       | 256  | 0xD0                 | A_SL_CFG       | 266   |  |
| 0x15       | R_SH1L       | 256  |                      |                |       |  |
| 0x15       | R_SH1H       | 257  |                      |                |       |  |
| 0x17       | R_SU_SYNC    | 258  |                      |                |       |  |
| 0x28       | R_CI_TX      | 259  |                      |                |       |  |
| 0x29       | R_GCI_CFG0   | 260  |                      |                |       |  |
| 0x2A       | R_GCI_CFG1   | 262  |                      |                |       |  |
| 0x2B       | R_MON_TX     | 262  |                      |                |       |  |

 Table 6.1: Overview of the XHFC-1SU PCM interface registers



### 6.1 PCM interface function

XHFC-1SU can operate in PCM master mode or PCM slave mode. This is selected with V\_PCM\_MD in register R\_PCM\_MD0.

The PCM data rate is programmable for PCM master mode as shown in Table 6.2. FOIO has always a frequency of 8 kHz. Each time slot has a width of eight bits.

| V_PCM_DR<br>in register<br>R_PCM_MD1 | C4IO clock<br>output | Number of<br>time slots | Data rate   | Name   |
|--------------------------------------|----------------------|-------------------------|-------------|--------|
| '00'                                 | 4.096 MHz            | 32                      | 2 MBit/s    | PCM30  |
| '01'                                 | 8.192 MHz            | 64                      | 4 MBit/s    | PCM64  |
| '10'                                 | 16.384 MHz           | 128                     | 8 MBit/s    | PCM128 |
| '11'                                 | 1.536 MHz            | 12                      | 0.75 MBit/s |        |

 Table 6.2: PCM master mode

When PCM slave mode is selected, the number of PCM time slots is derived from the C4IO input frequency and  $V\_PCM\_DR$  is ignored. Any frequency

 $f(C4IO) = n \cdot 128 \,\text{kHz}$  with n = 1..128

is allowed and leads to *n* PCM time slots. F0IO must always have a frequency of 8 kHz.

XHFC-1SU has two PCM data pins STIO1 and STIO2 which can both be input or output. Data direction can be selected for every time slot independently.



# 6.2 PCM data flow

The PCM data flow is shown in Figure 6.1. The input and output behavior has to be programmed with bitmap V\_ROUT in array register A\_SL\_CFG[SLOT]. Every time slots has its own configuration.



**Figure 6.1:** PCM data flow for transmit and receive time slots (see Figure 6.2 for additional setting of all PCM time slots between (A...(D))

The PCM output behavior is always setup from transmit slots.  $V_ROUT = '00'$  disables the PCM output, i.e. both output buffers are tristated and no data is transferred from the HFC-channel to the PCM module within this time slot. Any other value of  $V_ROUT$  enables the data transmission from the HFC-channel:

- $V_ROUT = '10'$  enables the STIO1 output buffer.
- $V_ROUT = '11'$  enables the STIO2 output buffer.
- Finally, V\_ROUT = '01' disables both output buffers but enables the data transmission from the HFC-channel. This setting in connection with the corresponding setting of the PCM input data path is used to loop data internally without influencing the PCM bus.





**Figure 6.2:** Global setting for all PCM time slots to set up an internal PCM loop (detail of Figure 6.1), normally used for test loop setup

PCM input data selects one of three data sources:

- $V_ROUT = '10'$  receives data from STIO2.
- $V\_ROUT = '11'$  receives data from STIO1.
- $V_ROUT = '01'$  is used for an internal data loop.

The data transfer to the receive HFC-channel can be disabled with  $V_ROUT = '00'$ .

A corresponding transmit/receive pair of PCM time slots is typically programmed with the same value for V\_ROUT in both directions. Table 6.3 summarizes these settings.

**Table 6.3:** *PCM* data flow programming with the same value of V\_ROUT in corresponding transmit and receive time slots

| V_ROUT | Data transmission from / to the HFC-channel *1 | STIO1<br>I/O path <sup>*2</sup> | STIO2<br>I/O path <sup>*2</sup> | Description                 |
|--------|------------------------------------------------|---------------------------------|---------------------------------|-----------------------------|
| '00'   | disabled                                       | tristated                       | tristated                       | PCM time slot not used      |
| '01'   | enabled                                        | tristated                       | tristated                       | internal data loop          |
| '10'   | enabled                                        | output                          | input                           | bidirectional data transfer |
| '11'   | enabled                                        | input                           | output                          | bidirectional data transfer |

\*1: PCM data flow configuration of a receive time slot

\*2: PCM data flow configuration of a transmit time slot

Figure 6.1 shows the PCM data flow which can be programmed for each PCM time slot individually. Global settings to the PCM data flow are available between  $(A \dots (D))$  as shown in Figure 6.2. When V\_PCM\_LOOP = '1' in register R\_PCM\_MD1, the PCM data is looped internally.

Please note, that it is not allowed to set  $V\_PCM\_OD = '1'$  in register  $R\_PCM\_MD1$  when an internal PCM loop is activated with either  $V\_ROUT = '01'$  in register  $A\_SL\_CFG$  or  $V\_PCM\_LOOP = '1'$  in register  $R\_PCM\_MD1$ .



# 6.3 PCM initialization

After hardware, global software or PCM reset the PCM interface starts an initialization sequence to set all A\_SL\_CFG registers of the PCM time slots to the reset value 0. This is even done if no valid C4IO and F0IO signals exist, which might occur in PCM slave mode. C4IO and F0IO input signals are ignored during PCM initialization.

The initialization process is indicated with  $V\_PCM\_INIT = '1'$  in register  $R\_STATUS$ . This bit changes to '0' when the initialization sequence is finished.

# 6.4 PCM timing

#### 6.4.1 Mode selection

The PCM interface of XHFC-1SU can operate either in slave mode or master mode. Slave mode is the default selection after XHFC-1SU reset.

To configure XHFC-1SU as PCM bus master, bit V\_PCM\_MD in register R\_PCM\_MD0 must be set to '1'. C4IO and F0IO signals are generated from XHFC-1SU in this case and both pins have output characteristic.

Slave mode is selected with V\_PCM\_MD = '0'. C4IO and F0IO are input pins in slave mode. External clocks must be connected to F0IO and also to either C4IO (when V\_C2I\_EN = '0' in register R\_PCM\_MD2) or C2IO (when V\_C2I\_EN = '1') in PCM slave mode because these signals are used from the ST/U<sub>p</sub> interface and the flow controller as well (see Figure 6.5 on page 221, signal C4I is required).

#### 6.4.2 Master mode

Figure 6.3 shows the timing diagram for PCM master mode. The timing characteristics are specified in Table 6.4. STIO1 is shown as data output and STIO2 as data input of XHFC-1SU. However, both pins can change their I/O characteristic with every PCM time slot.

The F0IO pulse is one C4IO pulse long with the default value  $V_F0_LEN = '0'$  in register R\_PCM\_MD0. F0IO starts one C4IO clock earlier if bit  $V_F0_LEN = '1'$ . These two pulse length are shown in Figure 6.3. The F0IO pulse can also be lengthened to indicate the start of a multiframe or superframe (see Section 6.6.4 on page 230).

#### 6.4.3 Slave mode

Figure 6.4 shows the timing diagram for PCM slave mode. The timing characteristics are specified in Table 6.5. STIO1 is shown as data output and STIO2 as data input of XHFC-1SU. However, both pins can change their I/O characteristic with every PCM time slot.

The F0IO pulse is expected to be one C4IO pulse long with the default value  $V_F0_LEN = '0'$  in register R\_PCM\_MD0. F0IO is expected to start one C4IO clock earlier if bit  $V_F0_LEN = '1'$ .

If the ST/U<sub>p</sub> interface is synchronized from C4IO in NT/LT mode, the frequency stability must be at least  $\pm 10^{-4}$ .

Cologne Chip



STIO1 is shown as data output and STIO2 as data input. However, both pins can change their I/O characteristic with every PCM time slot.


**Table 6.4:** Symbols of PCM timing for master mode in Figure 6.3 (All values with 50 pF load. Larger load capacitance will increase output delays.)

| Symbol                 | min / ns                                | typ / ns | max / ns                                | Characteristic                                                                        |
|------------------------|-----------------------------------------|----------|-----------------------------------------|---------------------------------------------------------------------------------------|
| t <sub>C</sub>         |                                         |          |                                         | Basic C4IO pulse width (not shown in the timing diagram)                              |
|                        |                                         | 122.070  |                                         | 4.096 MHz C4IO clock for 2 MB/s                                                       |
|                        |                                         | 61.035   |                                         | 8.192 MHz C4IO clock for 4 MB/s                                                       |
|                        |                                         | 30.518   |                                         | 16.384 MHz C4IO clock for 8 MB/s                                                      |
| t <sub>adj</sub>       |                                         | 20.345   |                                         | Adjust time is half a period of 24.576 MHz<br>clock (not shown in the timing diagram) |
| $t_{\rm C4H}$          | $t_{\rm C}-6-t_{\rm adj}$               |          | $t_{\rm C}+6$                           | C4IO high width for 2 MBit/s and 4 MBit/s                                             |
|                        | $4/3 \cdot t_{\rm C} - 6 - t_{\rm adj}$ |          | $4/3 \cdot t_{\rm C} + 6$               | C4IO high width for 8 MBit/s                                                          |
| t <sub>C4L</sub>       | $t_{\rm C} - 6$                         |          | $t_{\rm C} + 6 + t_{\rm adj}$           | C4IO low width for 2 MBit/s and 4 MBit/s                                              |
|                        | $2/3 \cdot t_{\rm C} - 6$               |          | $2/3 \cdot t_{\rm C} + 6 + t_{\rm adj}$ | C4IO low width for 8 MBit/s                                                           |
| t <sub>C4P</sub>       | $2 \cdot t_{\rm C} - 6 - t_{\rm adj}$   |          | $2 \cdot t_{\rm C} + 6 + t_{\rm adj}$   | C4IO clock period                                                                     |
| t <sub>C2H</sub>       | $2 \cdot t_{\rm C} - 6 - t_{\rm adj}$   |          | $2 \cdot t_{\rm C} + 6 + t_{\rm adj}$   | C2IO output high width                                                                |
| t <sub>C2L</sub>       | $2 \cdot t_{\rm C} - 6 - t_{\rm adj}$   |          | $2 \cdot t_{\rm C} + 6 + t_{\rm adj}$   | C2IO output low width                                                                 |
| t <sub>C2P</sub>       | $4 \cdot t_{\rm C} - 6 - t_{\rm adj}$   |          | $4 \cdot t_{\rm C} + 6 + t_{\rm adj}$   | C2IO output clock period                                                              |
| $t_{\rm F0}$           | 124994                                  | 125000   | 125006                                  | F0IO cycle time without adjustment                                                    |
|                        | $124994 - t_{adj}$                      |          | $125006 + t_{adj}$                      | 1 half clock adjustment                                                               |
|                        | $124994 - 2 \cdot t_{\rm adj}$          |          | $125006 + 2 \cdot t_{\rm adj}$          | 2 half clocks adjustment                                                              |
|                        | $124994 - 3 \cdot t_{\rm adj}$          |          | $125006 + 3 \cdot t_{\rm adj}$          | 3 half clocks adjustment                                                              |
|                        | $124994 - 4 \cdot t_{\rm adj}$          |          | $125006 + 4 \cdot t_{\rm adj}$          | 4 half clocks adjustment                                                              |
| t <sub>D</sub>         | 3                                       | 5        | 8                                       | C4IO                                                                                  |
| <i>t</i> <sub>CF</sub> | 0.5                                     |          | 8                                       | C4IO                                                                                  |
| t <sub>STiS</sub>      | 10                                      |          |                                         | Data valid to C4IO ∟ setup time                                                       |
| t <sub>STiH</sub>      | 10                                      |          |                                         | Data valid to C4IO $\square$ hold time                                                |
| $t_{\rm SToD}$         | 2                                       |          | 10                                      | STIO output delay from C4IO $\Box$                                                    |



**Data Sheet** 

June 2012



| Symbol              | min / ns | typ / ns            | max / ns | Characteristic                                           |
|---------------------|----------|---------------------|----------|----------------------------------------------------------|
| t <sub>C</sub>      |          |                     |          | Basic C4IO pulse width (not shown in the timing diagram) |
|                     |          | 122.070             |          | 4.096 MHz C4IO clock for 2 MB/s                          |
|                     |          | 61.035              |          | 8.192 MHz C4IO clock for 4 MB/s                          |
|                     |          | 30.518              |          | 16.384 MHz C4IO clock for 8 MB/s                         |
| $t_{\rm C4H}$       | 20       | $t_C$               |          | C4IO high width                                          |
| $t_{\rm C4L}$       | 20       | $t_C$               |          | C4IO low width                                           |
| $t_{\rm C4P}$       |          | $2 \cdot t_{\rm C}$ |          | C4IO clock period                                        |
| t <sub>C2H</sub>    |          | $2 \cdot t_C$       |          | C2IO output high width                                   |
| t <sub>C2L</sub>    |          | $2 \cdot t_C$       |          | C2IO output low width                                    |
| t <sub>C2P</sub>    |          | $4 \cdot t_C$       |          | C2IO output clock period                                 |
| $t_{\rm F0}$        |          | 125000              |          | F0IO cycle time                                          |
| t <sub>D</sub>      | 3        | 5                   | 8        | C4IO  L to C2IO  L delay                                 |
| t <sub>CFS</sub>    | 15       | $t_C$               |          | F0IO _ to C4IO _ setup time                              |
| t <sub>CFHmin</sub> | 15       | $t_C$               |          | F0IO T to C4IO hold time                                 |
| t <sub>CFHmax</sub> | 15       | $t_C$               | 100000   | F0IO high time after start of frame                      |
| t <sub>CFD</sub>    | 15       | $t_C$               |          | C4IO                                                     |
| t <sub>STiS</sub>   | 10       |                     |          | Data valid to C4IO                                       |
| t <sub>STiH</sub>   | 10       |                     |          | Data valid to C4IO $\ \ \ $ hold time                    |
| t <sub>SToD</sub>   | 2        |                     | 10       | STIO output delay from C4IO L                            |

**Table 6.5:** Symbols of PCM timing for slave mode in Figure 6.4 (All values with 50 pF load. Larger load capacitance will increase output delays.)



# 6.5 PCM clock synchronization

### 6.5.1 Overview

The PCM clock synchronization is shown in Figure 6.5. It is associated with the line interface clock synchronization which is shown in Figures 5.5 (page 167) and 5.13 (page 183) and with the MSS controller (shown in Figure 6.10 on page 228).

### 6.5.2 Manual or automatic synchronization source selection

The line interface in TE mode can be chosen as synchronization source with an appropriate value in bitmap V\_SYNC\_SEL of register R\_SU\_SYNC. Alternatively, an automatic selection can be enabled with V\_MAN\_SYNC = '0' in the same register (reset default). The actual synchronization source can be read from V\_RD\_SYNC\_SRC in register R\_BERT\_STA.

### 6.5.3 PLL programming for FOIO generation

C4IO is adjusted from the PCM DPLL (see Figure 6.5) during the last PCM time slot to synchronize the PCM interface with the  $ST/U_p$  interface.<sup>1</sup> The maximum number of edge adjustments during one 125 µs cycle can be configured in the range 1..4 by the bitmap value V\_PLL\_ADJ in register R\_PCM\_MD1. This automatic adjustment is enabled with V\_PLL\_MAN = '0' in register R\_PCM\_MD2.

 $V\_PLL\_MAN = '1'$  switches into manual adjustment mode. In this case, the adjustment direction is specified in  $V\_PLL\_ICR$  of register  $R\_PCM\_MD2$ . The number of edge adjustments which is specified in  $V\_PLL\_ADJ$  is carried out within the last PCM time slot every 125 µs. This manual adjustment does not stop before  $V\_PLL\_MAN$  is reset to automatic mode. By default, the C4IO clock is adjusted four times for one half clock cycle. This can be reduced to one adjustment of a half clock cycle (see  $R\_PCM\_MD1$  register). This is useful if a non XHFC series ISDN controller is connected as slave in NT mode to the PCM bus. The synchronization source can be selected by the  $R\_PCM\_MD2$  register settings.

### 6.5.4 Manual PLL adjustment

In normal operation mode, the synchronization input signal is passed from the V\_SYNC\_SRC controlled multiplexer to the PCM DPLL as shown in Figure 6.5. For this V\_PLL\_MAN has to be '0' in register R\_PCM\_MD2 .

The PLL output frequency can manually be adjusted if no synchronization source is available. This software controlled PLL adjustment is enabled with  $V_PLL_MAN = '1'$ . The V\_SYNC\_SRC controlled multiplexer must feed a 8 kHz signal in any case.

The time of the signal edges can be increased or reduced in the last time slot of the PCM frame.  $V_PLL_ICR = '0'$  results in a frequency reduction while  $V_PLL_ICR = '1'$  leads to a frequency increase. The number of adjusted edges is specified in the range 1..4 with bitmap  $V_PLL_ADJ$  in register  $R_PCM_MD1$ .

<sup>&</sup>lt;sup>1</sup>C4IO adjustment is only in operation when the PCM DPLL receives both 8 kHz reference clocks.





**Figure 6.5:** PCM clock synchronization (For details on the Universal ISDN Port see Figures 5.5 and 5.13, for details on the MSS controller see Figure 6.10)



 $V\_PLL\_MAN$  must be set back to '0' to stop the frequency regulation of the synchronization input signal.

## 6.5.5 C2IO signal

The C2IO signal (pin 18) can either be configured to input or output characteristic.

C2IO is used as an output signal when  $V_C2O_EN = '1'$  and  $V_C2I_EN = '0'$  in register R\_PCM\_MD2.

C2IO output signal is derived from C4IO by a frequency divider. In fact, there is an additional building block (not shown in Figure 6.5) which ensures a specific phase relation at the start of a frame. According to the timing diagrams in Figures 6.3 and 6.4, C2IO has its rising edge at the start of a frame. From this follows that C4IO has a falling edge with every edge of C2IO.

### 6.5.6 **SYNC\_O** and **FSC\_RX** synchronization signals

The 'frame synchronization detection' blocks shown in Figures 5.5 (page 167) and 5.13 (page 183) deliver a 8 kHz frame clock FSC\_RX which can be routed to the SYNC\_O synchronization output pin. FSC\_RX signal is available when a frame synchonization is detected (INFO 2 or INFO 4) and it does not depend on the state machine's condition.

The normal FSC\_RX pulse is high for one bit length. This is  $5.208 \,\mu s$  in S/T interface mode or  $2.604 \,\mu s$  in  $U_p$  interface mode. For S/T multiframe <sup>2</sup> synchronization or  $U_p$  superframe <sup>3</sup> synchronization, the start of every multiframe or superframe is indicated with a lengthened pulse with 7.5 bit width. This is 39  $\mu s$  every 40th pulse in S/T interface mode or 19.5  $\mu s$  every 8th pulse in  $U_p$  interface mode.

The rising edges of FSC\_RX have a distance of 125  $\mu$ s and are adjusted once every 250  $\mu$ s with  $\pm$ 163 ns. The rising edge is stable as long as the chosen TE port receives valid INFO 2 or INFO 4 even if the S/T or U<sub>p</sub> state machine is forced into a deactivated state F0, F2, F3, F4, F5, G0, G12, or G2. FSC\_RX is low otherwise.

During XHFC-1SU reset, SYNC\_O pin drives an active low signal.

### 6.5.7 Synchronous 512 kHz output signal

SYNC\_O frequency can either be 8kHz, which is mostly used, or 512kHz. The 512kHz clock is synchronous to the frame clock as it is generated from the DPLL as shown in Figure 6.5.

When XHFC-1SU operates in PCM slave mode, which means that F0IO is used as clock input, SYNC\_O should not issue 512 kHz. This would lead to a closed loop with the internal DPLL and an external PCM master PLL. A closed loop with two PLLs might be instable and can lose the nominal frequency.

### 6.5.8 Application examples for XHFC-1SU synchronization schemes

Flexible synchronization schemes can be implemented with the clock pins SYNC\_I and SYNC\_O of XHFC-1SU. Some important application examples are shown in this section.

 $<sup>^{2}</sup>$ A complete S/T multiframe takes 20 S/T frames with 250  $\mu$ s each. Therefore, a multiframe has a length of 5 ms in total.

 $<sup>{}^{3}</sup>$ A complete U<sub>p</sub> superframe takes 4 U<sub>p</sub> frames with 250 µs each. Therefore, a superframe has a length of 1 ms in total.



# **Important** !

As ISDN is based on a synchronous network, all devices must be synchronized to one synchronizing source. This is the central office (for S/T) or PBX (for  $U_p$ ), typically.

When multiple XHFC-1SU are used within a system, all  $ST/U_p$  and PCM clocks must be synchronized to a single synchronization source. When an ST interface operates in TE mode and is connected to the central office, the synchronization source is obtained from the central office. A  $U_p$  interface in TE mode is typically synchronized to a PBX clock.

### 6.5.8.1 An existing system with internal PCM bus has to be expanded by an ISDN interface

When an existing system has to be expanded by an ISDN interface, there are two solutions as shown in Figures 6.6 and 6.7.



Figure 6.6: Expanding an existing system with an ISDN port (XHFC-1SU as PCM slave)

The existing system can keep the PCM master when there is a synchronization input (Figure 6.6). This must be connected to pin SYNC\_O of XHFC-1SU to synchronize the whole system to the clock derived from the received ISDN signal.

SYNC\_O is either derived from the central office or the DPLL of XHFC-1SU is free-running. In both cases, XHFC-1SU is the synchronization source for the whole system.

When there is no synchronization input available at the existing system, XHFC-1SU must operate as PCM master and all other PCM devices in the system must be PCM slaves (Figure 6.7). Again, XHFC-1SU is the synchronization source for the whole system.





Figure 6.7: Expanding an existing system with an ISDN port (XHFC-1SU as PCM master)

### 6.5.8.2 Application with multiple XHFC-1SU

Multiple XHFC-1SU can be interconnected to build up anapplication with a large number of ISDN ports. The SYNC\_O / SYNC\_I pins must be connected to a daisy chain. Two solutions are shown in Figures 6.8 and 6.9, depending on the PCM master requirements.

Figure 6.8 shows an example where any XHFC-1SU can be in TE mode. The synchronization signals are daisy chained. The last XHFC-1SU must be in PCM master mode. This assures that the F0IO/C4IO connections feed the synchronized clock to all devices.

Figure 6.9 shows an example where any XHFC-1SU can be in TE mode again. Now, the SYNC\_O/SYNC\_I daisy chain is looped back so that the loop is closed. For this reason, the F0IO/C4IO connections are optional due to the application needs. An arbitrary XHFC-1SU can be in PCM master mode.

Nevertheless, it is recommended to interconnect all devices with the F0IO/C4IO clocks for more flexible application capability.





Figure 6.8: Multiple XHFC-1SU synchronized with an open loop of SYNC\_O/SYNC\_I





Figure 6.9: Multiple XHFC-1SU synchronized with an closed loop of SYNC\_O/SYNC\_I



# 6.6 Multiframe/superframe synchronization to the PCM interface

### 6.6.1 Overview

The multiframes (S/T) or superframes (U<sub>p</sub>) of the ST/U<sub>p</sub> interface can be synchronized to the PCM interface. Furthermore, the transmit/receive ping pong is synchronized in U<sub>p</sub> mode. Figure 6.10 shows the block diagram of the MSS controller (multiframe/superframe synchronization controller). The controller consists of four parts which are explained from Sections 6.6.2 to 6.6.5.

The basic concept of the MSS controller can be described as follows:

- An internal synchronization pulse is generated and delivered to the PCM interface for F0IO pulse width modification as well as to the line interface to force the 'start of multi-frame / superframe' in transmit direction.
- The internal synchronization pulse is generated from a frame counter which can be synchronized to an external synchronization pulse.

### 6.6.2 Frame counter

The frame counter is the central unit of the MSS controller. The counter is incremented with every F0IO input pulse and operates as a ring counter in the range 0...39.

A counter reset is initiated with a detected synchronization input signal. The frame counter is synchronized to the synchronization source with the first counter reset signal. From now on, the frame counter value is used

- to generate a modified F0IO pulse (if enabled) and
- to synchronize the multiframe/superframe transmission with the MSS\_SYNC\_O signal (if enabled and if the line interface operates in NT/LT mode, see Figure 5.5 on page 167 and Figure 5.13 on page 183)

to the external synchronization source.

The synchronization pulse detection can be configured with several parameters. This is explained in Section 6.6.3.

It is also possible to disable the synchronization pulse detection. There are no counter reset signals in this case. The frame counter is free-running without a synchronization input signal. However, synchronization pulses MSS\_SYNC and the modified F0IO output are generated to synchronize the multiframe / superframe transmission with the PCM interface. The chip operates as a synchronization source for the 'start of multiframe / superframe' condition in this case.

# 6.6.3 Synchronization input signal

The MSS controller can synchronize the multiframe / superframe transmission to an external synchronization signal. This functionality must be enabled with  $V_MSS_SRC_EN = '1'$  in register  $R_MSS0$ . Any detected synchronization pulse leads to a frame counter reset.





Figure 6.10: Multiframe/superframe synchronization to the PCM interface



The synchronization signal is obtained either from the F0IO, SYNC\_I, STIO1 or MSS\_SYNC\_I signal. This can be selected with bitmap V\_MSS\_SRC in register R\_MSS0. The source signal can be delayed by a multiple of C4IO clocks to adjust the incoming signal characteristics to the detection function. For this, V\_MSS\_DLY in register R\_MSS1 can be set to a value in the range 0..15 C4IO clocks.

It is possible to use an active '1' or active '0' signal for synchronization. Only the change of the signal compared with the value in the previous PCM frame generates the synchronization signal.

After a synchronization pulse has reset the frame counter, the detection window is closed and the next synchronization pulse cannot be generated until the frame counter reaches the value 39 (V\_MSS\_SRC\_GRD = '0' in register R\_MSS0) or 7 (V\_MSS\_SRC\_GRD = '1'). The detection window is opened as soon as the selected counter value has been reached. This procedure avoids an oversynchronization. V\_MSS\_SRC\_GRD = '1' is recommended when line interface operates in S/T mode. The value V\_MSS\_SRC\_GRD = '1' is recommended when the line interface operates in U<sub>p</sub> mode.

The frame counter is synchronized to the synchronization input signal when the following conditions are fulfilled at the same time:

- 1. The synchronization detection is enabled, i.e.  $V_MSS_SRC_EN = '1'$ .
- 2. The detection windows is open, i.e. Q = '1'.
- 3. The programmable delay is passed.
- 4. The selected input signal has changed from the previous frame.

The delay time  $t_{\text{DLY}}$  is specified in Figure 6.11 and Table 6.6. Its maximum value is  $t_{\text{DLY,max}} = 16 \cdot t_{\text{C4P}}$ .

If the synchronization pulse is received on the data input line STIO1, it can be any bit within the first PCM time slot. V\_MSS\_DLY must have an even value in this case to ensure that the *change detection* time matches with the bit cells. V\_MSS\_DLY = 0 selects the first bit of the time slot 0 while V\_MSS\_DLY = 14 selects the last bit.



Figure 6.11: Timing specification of the SYNC\_IN change detection



| Symbol                  | min / ns | max / ns | Characteristic                                               |  |
|-------------------------|----------|----------|--------------------------------------------------------------|--|
| t <sub>C4P</sub>        |          |          | C4IO clock period (depends on the selected PCM data rate)    |  |
| t <sub>C2P</sub>        |          |          | C2IO clock period                                            |  |
| <i>t</i> <sub>DLY</sub> |          |          | Programmable synchronization pulse delay from start of frame |  |
|                         |          |          | $t_{\text{DLY}} = (V\_MSS\_DLY + 1) \cdot t_{C4P}$           |  |
| t <sub>SS</sub>         | 10       |          | Synchronization pulse valid to F_SYNC 	☐ setup time          |  |
| t <sub>SH</sub>         | 10       |          | Synchronization pulse valid to $F_SYNC \supset$ hold time    |  |

 Table 6.6:
 Symbols of the SYNC\_IN change detection timing specification in Figure 6.11

### 6.6.4 Synchronization output signal (FOIO pulse modification)

The start of a multiframe or superframe is indicated by a FOIO pulse which has a different length than usual.

In principle, the length of the F0IO pulse is arbitrary. The F0IO signal is used for PCM frame synchronization only on the first falling edge of C4IO. The F0IO high time has a typical length of one C4IO pulse (V\_F0\_LEN = '0') or two C4IO pulses (V\_F0\_LEN = '1') as described in Section 6.4.2.

The F0IO high time can be lengthen by another C4IO pulse width to indicate the multi-frame/superframe synchronization signal. This must be enabled with V\_MSS\_MOD = '1' in register R\_MSS0. The repetition rate of the synchronization pulse is once every 40th PCM frame if V\_MSS\_MOD\_REP = '0' in register R\_MSS0. V\_MSS\_MOD\_REP = '1' selects a repetition rate of once every 8th PCM frame.

Figure 6.12 shows all different FOIO pulses in PCM master mode. Table 6.7 summarizes the bit values which must be set to achieve these pulses.



Figure 6.12: F0IO pulse modification



| Pulse          | V_F0_LEN<br>in register<br>R_PCM_MD0 | V_MSS_MOD<br>in register<br>R_MSS0 | Description                                                                                                                                                                           |
|----------------|--------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F0IO_normal    | '0'                                  | '0'                                | normal F0IO pulse                                                                                                                                                                     |
| F0IO_long      | '1'                                  | ,0,                                | F0IO starts one C4IO period earlier (early leading edge)                                                                                                                              |
| F0IO_sync      | ,0,                                  | '1'                                | F0IO pulse is lengthened by one C4IO pulse every 8th or 40th frame, F0IO_normal otherwise (delayed trailing edge)                                                                     |
| F0IO_sync_long | '1'                                  | '1'                                | F0IO starts one C4IO period earlier and is lengthened<br>by one C4IO pulse every 8th or 40th frame, F0IO_long<br>otherwise (combined early leading edge and delayed<br>trailing edge) |

 Table 6.7: Selection of the FOIO pulse characteristic (see also Figure 6.12)

### 6.6.5 Line interface synchronization

The signal MSS\_SYNC\_O for the multiframe/superframe synchronization is delivered to the ST/U<sub>p</sub> interface. It must be enabled with V\_MSS\_OUT\_EN = '1' in register R\_MSS0. V\_MSS\_OUT\_EN = '0' leads to an unsynchronized transmission of the multiframe/superframe structure.

The repetition rate can be specified to be either every 40th or 8th PCM frame with bit V\_MSS\_OUT\_REP in register R\_MSS0. Only the line interface in  $U_p$  mode can be feed with a 8 PCM frame repetition rate. The repetition rate of once every 40 PCM frames must be chosen in S/T mode. This is a suitable selection for a line interface in  $U_p$  mode as well.

As there is a delay between FOIO and the line interface output, it is possible to adjust the line interface synchronization with a signed offset of -4..+3 FOIO pulses. This can also be used to fulfill requirements which might occur with a special application where the chip is connected to another ISDN device.



# 6.7 External CODECs

Up to two external CODECs can be connected to the PCM interface. XHFC-1SU has two CODEC enable signals  $F1_0$  and  $F1_1$ . An external CODEC has to be assigned to a PCM time slot via bitmaps V\_SL\_SEL1 and V\_SL\_SEL0 in registers R\_SL\_SEL1 and R\_SL\_SEL0.

The shape signals can be programmed. The last bit determines the inactive level by which non-inverted and inverted shape signals can be programmed. Every external CODEC can choose one of the two shape signals with bits V\_SH\_SEL1 and V\_SH\_SEL0 in registers R\_SL\_SEL1 and R\_SL\_SEL0.



Figure 6.13: Example for two CODEC enable signal shapes

Figure 6.13 shows an example with two external CODECs. Time slot 0 starts with the F0IO pulse. In this example – assuming that PCM30 is configured –  $F1_0$  enables the first CODEC on time slot 0 and shape bytes on R\_SH0L and R\_SH0H with the following register settings.

| Register setup:                    |                                 |
|------------------------------------|---------------------------------|
| $R\_PCM\_MD0: V\_PCM\_IDX = 0$     | (R_SL_SEL0 register accessible) |
| $R\_SL\_SEL0 : V\_SL\_SEL0 = 0x1F$ | (time slot #0)                  |
| $: V_SH_SEL0 = 0$                  | (shape bytes R_SH0L and R_SH0H) |



The second CODEC on time slot 1 and shape bytes on R\_SH1L and R\_SH1H must be configured as shown below.

| Register setup:                        |                                 |
|----------------------------------------|---------------------------------|
| $R_PCM_MD0 : V_PCM_IDX = 1$            | (R_SL_SEL1 register accessible) |
| $R\_SL\_SEL1  : \ V\_SL\_SEL1 \ = \ 0$ | (time slot #1)                  |
| : $V\_SH\_SEL1 = 1$                    | (shape bytes R_SH1L and R_SH1H) |

The shown shape signals have to be programmed in reverse bit order by the following register settings.

| Register setup:                                                                                                          |                                                              |
|--------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| $\label{eq:rescaled} \textbf{R}\_\textbf{PCM}\_\textbf{MD0} : \ \textbf{V}\_\textbf{PCM}\_\textbf{IDX} = \ \textbf{0xC}$ | (R_SH0L register accessible)                                 |
| $R\_SHOL : V\_SHOL = 0xF8$                                                                                               | $(0xF8 = '1111\ 1000' \xrightarrow{reverse} '0001\ 1111')$   |
| $\label{eq:rescaled} \texttt{R\_PCM\_MD0} : \ \texttt{V\_PCM\_IDX} = \ \texttt{0xD}$                                     | (R_SH0H register accessible)                                 |
| $R\_SH0H : V\_SH0H = 0x03$                                                                                               | $(0x03 = '0000\ 0011' \xrightarrow{reverse} '1100\ 0000')$   |
| $R\_PCM\_MD0 : V\_PCM\_IDX = 0xE$                                                                                        | (R_SH1L register accessible)                                 |
| $R\_SH1L : V\_SH1L = 0x1F$                                                                                               | $(0x1F = '0001 \ 1111' \xrightarrow{reverse} '1111 \ 1000')$ |
| $R\_PCM\_MD0 : V\_PCM\_IDX = 0xF$                                                                                        | (R_SH1H register accessible)                                 |
| $R\_SH1H : V\_SH1H = 0xF0$                                                                                               | $(0xF0 = '1111\ 0000' \xrightarrow{reverse} '0000\ 1111')$   |



# 6.8 GCI/IOM-2 mode

### 6.8.1 Overview

XHFC-1SU is equipped with a simple GCI controller<sup>4</sup> (also known as IOM<sup>TM</sup>-2)<sup>5</sup> to support interconnection to U-chips, external CODECs or DSPs.

The IOM<sup>TM</sup>-2 bus is an industrial standard for interconnecting telecommunication microchips considering the requirements of analog applications as well. It has been defined from an international manufacturers group<sup>6</sup>. The GCI<sup>7</sup> functionality has been implemented in respect to the IOM<sup>TM</sup>-2 specification [7].

The interconnection between XHFC-1SU and a GCI device uses four wires, typically:

- C4IO: Double bit rate clock
- F0IO: 8 kHz frame signal
- STIO1: Data from XHFC-1SU to the GCI device (can be swapped with STIO2)
- STIO2: Data from the GCI device to XHFC-1SU (can be swapped with STIO1)

### 6.8.2 GCI frame structure

The GCI frame has a length of 4 bytes and is located at PCM time slots S...S + 3 with  $S = 4 \cdot V\_GCI\_SL$ . GCI uses these PCM time slots in a special way, all other PCM time slots are accessible as usual.

V\_GCI\_SL must be in the range 0..7 for PCM30, 0..15 for PCM64 or 0..31 for PCM128.

The binary organization of the GCI frame is shown in Figure 6.14. The first two time slots are used for B1- and B2-channel data. The third time slot is occupied by the monitor channel and the last time slot contains D-channel data, command/indication bits and the handshake bits MR and MX.

Figure 6.14 shows the GCI frame from the GCI master's point of view. To distinguish between the handshake bits of the GCI master (transmitter) and the GCI slave (receiver), the handshake bits are indexed like  $MX_{TX}$  or  $MX_{BX}$  in this document partially.

The PCM slot assigner must be used to allocate any HFC-channel to the first two bytes of the CGI frame. These are B-channels, typically. When the GCI device also carries D-channel data in the GCI time slot #3, the belonging D-channel must be assigned as well. Please note, that these assignments are not automatically done by the GCI controller. Only monitor channel, C/I-channel and handshake bits are automatically assigned and handled from the GCI controller.

<sup>&</sup>lt;sup>4</sup>GCI = General Circuit Interface

 $<sup>^{5}</sup>$ IOM<sup>TM</sup>-2= ISDN Oriented Modular revision 2, trademark of Infineon Technologies AG

<sup>&</sup>lt;sup>6</sup>Alcatel (France), Siemens (Germany), Italtel (Italy) and Plessey (UK)

 $<sup>^7 \</sup>text{The term}$  GCI is always used in this document and includes IOM  $^{\text{TM}}\text{-}2$  functionality as well.





 Table 6.8: Legend of figure 6.14

| Name | Description                                                                                          |
|------|------------------------------------------------------------------------------------------------------|
| B1   | B1-channel data                                                                                      |
| B2   | B2-channel data                                                                                      |
| М    | Monitor channel data                                                                                 |
| D    | D-channel data                                                                                       |
| C/I  | Command/indication bits for controlling activation/deactivation and for additional control functions |
| MR   | Handshake bit for the monitor channel ( $MR_{RX}$ on STIO1 output and $MR_{TX}$ on STIO2 input)      |
| MX   | Handshake bit for the monitor channel ( $MX_{TX}$ on STIO1 output and $MX_{RX}$ on STIO2 input)      |

### 6.8.3 GCI register programming

#### 6.8.3.1 Enable CGI functionality

The GCI functionality is disabled after XHFC-1SU reset and all time slots of the PCM bus can be assigned to an arbitrary HFC-channel. GCI functionality must be enabled with  $V\_GCI\_EN = '1'$  in register  $R\_GCI\_CFG0$ .

When CGI functionality is not used, received data on time slots  $4 \cdot V\_GCI\_SL+2$  and  $4 \cdot V\_GCI\_SL+3$  are extracted to registers R\_MON\_RX and R\_CI\_RX nevertheless. For this reason, the interrupt mask bits V\_CI\_IRQMSK and V\_MON\_RX\_IRQMSK in register R\_MISC\_IRQMSK should not be set to '1' to avoid senseless interrupts.



### 6.8.3.2 Monitor channel

Monitor data for the transmit direction must be written into register R\_MON\_TX. When the next monitor byte can be written, V\_MON\_TXR in register R\_GCI\_STA changes to '1'. Then the next monitor byte can be written into R\_MON\_TX. A write access to R\_MON\_TX resets V\_MON\_TXR to '0'. Before the last monitor byte of a command is written into R\_MON\_TX, the 'end of command' flag V\_MON\_END = '1' has to be set in register R\_GCI\_CFG0.

Furthermore, an interrupt occurs when V\_MON\_TXR changes to '1' and when the mask bit V\_MON\_TX\_IRQMSK in register R\_MISC\_IRQMSK is set to '1'. The interrupt event V\_MON\_TX\_IRQ = '1' in register R\_MISC\_IRQ is set even if the interrupt mask has the value '0'.

If there are no further monitor bytes to be send, the idle pattern 0xFF is transmitted.

A received monitor byte is indicated with  $V_MON_RXR = '1'$  in register  $R_GCI_STA$  and can be read from register  $R_MON_RX$ .

XHFC-1SU can accept either every received monitor byte at once, or after it has been received twice (so-called *double last look criterion*). This can be configured with bit V\_MON\_DLL in register R\_GCI\_CFG0. When *double last look criterion* is enabled, the GCI controller waits until a monitor byte has been received twice in two consecutive GCI frames.

The monitor bytes are located in GCI time slot 2 as shown in Figure 6.14. Transmitting and receiving monitor bytes is coordinated by the GCI controller of XHFC-1SU. This procedure is described in detail in Section 6.8.4.

### 6.8.3.3 Command/indication bits (C/I-channel)

The C/I-channel is used to interchange status information between XHFC-1SU and the connected GCI device. C/I-bits are transmitted continuously in every GCI frame until a new command/indication pattern is present.

Command/indication is used to transmit a command from the GCI master to the connected GCI slave and to receive status information (indication) in opposite direction.

XHFC-1SU transmits the command that is written into bitmap V\_GCI\_C of register R\_CI\_TX. When this value is changed, the new command is transmitted in the next GCI time slot 3.

Received indication bits can be read from V\_GCI\_I. Any change of the indication bits can trigger an interrupt when the interrupt mask bit V\_CI\_IRQMSK is set to '1' in register R\_MISC\_IRQMSK. The interrupt event V\_CI\_IRQ = '1' in register R\_MISC\_IRQ is set even if the interrupt mask has the value '0'.

The GCI controller does not interpret the C/I-bits. Indication bits must be processed from the host processor.

GCI devices that do not operate on D-channel data, can expand the C/I-channel from 4 bit to 6 bit. XHFC-1SU can be configured to transmit and receive 4 bit (V\_MON\_CI6 = '0' in register V\_MON\_CI6) as well as 6 bit (V\_MON\_CI6 = '1') C/I-channel length.

#### 6.8.3.4 Examples for GCI frame embedding in the PCM data structure

Figure 6.15 shows a typical application where XHFC-1SU is both PCM master and GCI master (most application cases, standard configuration). This means:



- XHFC-1SU feeds PCM clocks C4IO and F0IO
- GCI frame output on STIO1
- GCI frame input on STIO2

The programming procedure for this application example is shown in Table 6.9. Please note that not mentioned bitmap values of the GCI relevant registers remain in their reset state.

GCI time slot 2 does not need to be programmed because the monitor byte is automatically assigned to this time slotwhen GCI is enabled. C/I-channel and handshake bits MX and MR are also automatically assigned to their time slot.



Figure 6.15: GCI application example 1 (XHFC-1SU is PCM master and GCI master)

The second application example shown in Figure 6.16 has only one difference to the first example: XHFC-1SU is configured to PCM slave mode. This means that the PCM clocks are generated from a PCM device in master mode. So the programming procedure is equal to Table 6.9 except that "set PCM to master" has to be changed to "set PCM to slave" ( $V\_PCM\_MD = '0'$ ).

The last application example 3 shows XHFC-1SU operating in GCI slave mode. XHFC-1SU is PCM slave and GCI slave which means:

- GCI master feeds PCM clocks C4IO and F0IO
- GCI frame input on STIO1
- GCI frame output on STIO2

The programming procedure is shown in Figure 6.17. GCI slave mode is configured with the shown settings for V\_GCI\_SWAP\_TXHS, V\_GCI\_SWAP\_RXHS and V\_GCI\_SWAP\_STIO in register R\_GCI\_CFG0. Again, not mentioned bitmap values of the GCI relevant registers remain in their reset state.

Please note that register programming must be handled by the host processor connected to the XHFC-1SU microprocessor interface even if XHFC-1SU operates as GCI slave. This includes the monitor data handling as well as the C/I processing.



| Register            | Bit       | Value      | Function                                                                      |  |
|---------------------|-----------|------------|-------------------------------------------------------------------------------|--|
| R_GCI_CFG1 V_GCI_SL |           | x          | Select PCM time slot group for the GCI frame (PCM time slots $4x 4x + 3$ )    |  |
| R_PCM_MD0 V_PCM_MD  |           | '1'        | set PCM to master                                                             |  |
| R_SLOT              | V_SL_NUM  | 4 <i>x</i> | select first GCI time slot $4x$                                               |  |
| R_SLOT              | V_SL_DIR  | '0'        | select transmit data direction                                                |  |
| A_SL_CFG            | V_ROUT    | '10'       | set STIO1 to output characteristic                                            |  |
| A_SL_CFG            | V_CH_SDIR | '0'        | assign transmit HFC-channel                                                   |  |
| A_SL_CFG            | V_CH_SNUM | <i>Y</i> 1 | assign HFC-channel $y_1$ to the selected time slot<br>(normally B1-channel)   |  |
| R_SLOT              | V_SL_DIR  | '1'        | select receive data direction                                                 |  |
| A_SL_CFG            | V_ROUT    | '10'       | set STIO2 to input characteristic                                             |  |
| A_SL_CFG            | V_CH_SDIR | '1'        | assign receive HFC-channel                                                    |  |
| A_SL_CFG            | V_CH_SNUM | $z_1$      | assign HFC-channel $z_1$ to the selected time slot<br>(normally $z_1 = y_1$ ) |  |
| R_SLOT              | V_SL_NUM  | 4x + 1     | select second GCI time slot $4x + 1$                                          |  |
| R_SLOT              | V_SL_DIR  | '0'        | select transmit data direction                                                |  |
| A_SL_CFG            | V_ROUT    | '10'       | set STIO1 to output characteristic                                            |  |
| A_SL_CFG            | V_CH_SDIR | '0'        | assign transmit HFC-channel                                                   |  |
| A_SL_CFG            | V_CH_SNUM | У2         | assign HFC-channel $y_2$ to the selected time slot<br>(normally B2-channel)   |  |
| R_SLOT              | V_SL_DIR  | '1'        | select receive data direction                                                 |  |
| A_SL_CFG            | V_ROUT    | '10'       | set STIO2 to input characteristic                                             |  |
| A_SL_CFG            | V_CH_SDIR | '1'        | assign receive HFC-channel                                                    |  |
| A_SL_CFG            | V_CH_SNUM | Z2         | assign HFC-channel $z_2$ to the selected time slot<br>(normally $z_2 = y_2$ ) |  |
| R_SLOT              | V_SL_NUM  | 4x + 3     | select fourth GCI time slot $4x + 3$                                          |  |
| R_SLOT              | V_SL_DIR  | '0'        | select transmit data direction                                                |  |
| A_SL_CFG            | V_ROUT    | '10'       | set STIO1 to output characteristic                                            |  |
| A_SL_CFG            | V_CH_SDIR | '0'        | assign transmit HFC-channel                                                   |  |
| A_SL_CFG            | V_CH_SNUM | УD         | assign HFC-channel $y_D$ to the selected time slot (normally D-channel)       |  |
| R_SLOT              | V_SL_DIR  | '1'        | select receive data direction                                                 |  |
| A_SL_CFG            | V_ROUT    | '10'       | D' set STIO2 to input characteristic                                          |  |
| A_SL_CFG            | V_CH_SDIR | '1'        | assign receive HFC-channel                                                    |  |
| A_SL_CFG            | V_CH_SNUM | ZD         | assign HFC-channel $z_D$ to the selected time slot<br>(normally $z_D = y_D$ ) |  |
| R_GCI_CFG0          | V_GCI_EN  | '1'        | enable GCI function                                                           |  |

**Table 6.9:** Programming procedure for application example 1 according to Figure 6.15 (XHFC-1SU is PCM master and GCI master)





Figure 6.16: GCI application example 2 (XHFC-1SU is PCM slave and GCI master)



Figure 6.17: GCI application example 3 (XHFC-1SU is PCM slave and GCI slave)



Register Bit Value Function R\_GCI\_CFG1 V\_GCI\_SL Select PCM time slot group for GCI frame x х '0' R\_PCM\_MD0 V\_PCM\_MD set PCM to slave 4xselect first GCI time slot 4xR\_SLOT V\_SL\_NUM **R\_SLOT** V\_SL\_DIR '0' select transmit data direction A\_SL\_CFG V\_ROUT '11' set STIO1 to input characteristic A\_SL\_CFG V\_CH\_SDIR '0' assign transmit HFC-channel A\_SL\_CFG V\_CH\_SNUM assign HFC-channel  $y_1$  to the selected time slot  $y_1$ (normally B1-channel) '1' R\_SLOT V\_SL\_DIR select receive data direction A\_SL\_CFG V\_ROUT '11' set STIO2 to output characteristic '1' assign receive HFC-channel A\_SL\_CFG V\_CH\_SDIR A\_SL\_CFG assign HFC-channel  $z_1$  to the selected time slot V\_CH\_SNUM  $Z_1$ (normally  $z_1 = y_1$ ) **R\_SLOT** V\_SL\_NUM 4x + 1select second GCI time slot 4x + 1R\_SLOT V\_SL\_DIR '0' select transmit data direction A\_SL\_CFG V\_ROUT '11' set STIO1 to input characteristic A\_SL\_CFG '0' assign transmit HFC-channel V\_CH\_SDIR A\_SL\_CFG assign HFC-channel  $y_2$  to the selected time slot V\_CH\_SNUM  $y_2$ (normally B2-channel) '1' R\_SLOT V\_SL\_DIR select receive data direction set STIO2 to output characteristic '11' A\_SL\_CFG V\_ROUT '1' A\_SL\_CFG V\_CH\_SDIR assign receive HFC-channel A\_SL\_CFG V\_CH\_SNUM assign HFC-channel  $z_2$  to the selected time slot  $z_2$ (normally  $z_2 = y_2$ ) **R\_SLOT** 4x + 3V\_SL\_NUM select fourth GCI time slot 4x + 3'0' **R\_SLOT** V\_SL\_DIR select transmit data direction A\_SL\_CFG V\_ROUT '11' set STIO1 to input characteristic '0' assign transmit HFC-channel A\_SL\_CFG V\_CH\_SDIR A\_SL\_CFG V\_CH\_SNUM assign HFC-channel  $y_D$  to the selected time slot УD (normally D-channel) '1' **R\_SLOT** V\_SL\_DIR select receive data direction A\_SL\_CFG V\_ROUT '11' set STIO2 to output characteristic A\_SL\_CFG '1' V\_CH\_SDIR assign receive HFC-channel assign HFC-channel  $z_D$  to the selected time slot A\_SL\_CFG V\_CH\_SNUM  $z_{\rm D}$ (normally  $z_{\rm D} = y_{\rm D}$ ) R\_GCI\_CFG0 V\_GCI\_SWAP\_TXHS '1' swap handshake bits  $MR_{TX}$  and  $MX_{TX}$  for GCI transmit direction '1' R\_GCI\_CFG0 V\_GCI\_SWAP\_RXHS swap handshake bits MR<sub>RX</sub> and MX<sub>RX</sub> for GCI receive direction R\_GCI\_CFG0 '1' V\_GCI\_SWAP\_STIO swap STIO1 and STIO2 for monitor channel and C/I '**1**' enable GCI function R\_GCI\_CFG0 V\_GCI\_EN

**Table 6.10:** Programming procedure for application example 3 according to Figure 6.17 (XHFC-1SU is PCM slave and GCI slave)



# 6.8.4 GCI protocol

### 6.8.4.1 XHFC-1SU transmit procedure

Monitor bytes are transmitted and received under the control of the handshake bits  $MX_{TX}$  and  $MR_{TX}$ . The handshake bits are automatically handled by the GCI controller. Figure 6.18 shows the transmit procedure of two monitor bytes.



omitted, if the receiver sends acknowledge immediately

omitted, if V\_MON\_SLOW = 0 (high transmission speed)



- Beginning with idle state, no monitor byte is pending,  $MX_{TX}$  and  $MR_{TX}$  are both '1'. The monitor byte has the value 0xFF in this state.
- **2** A write access to register **R\_MON\_TX** starts the transmit sequence.



The first monitor byte is transmitted within the next GCI time slot 2 and  $MX_{TX}$  is set to '0'. This monitor byte will be transmitted repeatedly in every time slot 2 until the GCI device acknowledges the byte with  $MR_{TX} = '0'$ .

As the GCI controller has latched the monitor byte, V\_MON\_TXR is set to '1'. This means that the host processor can write the next monitor byte into register R\_MON\_TX.

3 The receiver latches the first monitor byte. This can take an arbitrary number of 125 μs cycles. An acknowledge is send when the receiver is ready for the next byte.

**4** The transmitter gets acknowledge with  $MR_{TX} = '0'$ .

• XHFC-1SU answers to the acknowledge signal with  $MX_{TX} = '1'$  for one cycle when a new monitor byte has been written into register R\_MON\_TX. MX<sub>TX</sub> is set to '0' afterwards to keep the monitor channel active. The second monitor byte is transmitted at the same time as  $MX_{TX} = '1'$  and is stable until a receiver acknowledge is recognized.

**(b)** The receiver latches the second monitor byte. This can take an arbitrary number of  $125 \,\mu s$  cycles. An acknowledge signal MR<sub>TX</sub> = '1' is send for one cycle when the receiver is ready for the next byte.

**\textcircled{O}** The transmitter receives acknowledge with MR<sub>TX</sub> = '1' for one cycle.

③ The procedure shown with the second monitor byte (⑤..⑦) can be repeated until the whole message has been send. The last monitor byte has to be marked with V\_MON\_END = '1'. The marking must be written before the last monitor byte is stored in register R\_MON\_TX. Then the transmitter terminates the transmission with continuously MX<sub>TX</sub> = '1'. Idle pattern 0xFF is send. The monitor channel of the transmitter is in inactive state.

**9** When the receiver reads  $MX_{TX} = '1'$  for two cycles, its monitor channel goes to inactive state with  $MR_{TX} = '1'$ . The monitor channel is in idle state now.

Table 6.11 summarizes the rules for the handshake signals  $MX_{TX}$  and  $MR_{TX}$  when XHFC-1SU transmits a monitor byte sequence.

| MX <sub>TX</sub> | MR <sub>TX</sub> | Monitor channel state                                                 |
|------------------|------------------|-----------------------------------------------------------------------|
| '1'              | '1'              | Idle                                                                  |
| '0'              | '0'              | Transmitter and receiver are both active                              |
| ·0·              | '1' (once)       | Acknowledge of the 2 <sup>nd</sup> and following monitor bytes        |
| '0'              | '1' (repeated)   | Transmitter waits for acknowledge to the 1 <sup>st</sup> monitor byte |
| '1' (once)       | '0'              | Transmitter answers to the acknowledge                                |
| '1' (repeated)   | '0'              | Transmitter terminates the transmission                               |

**Table 6.11:** Rules for the handshake signals  $MX_{TX}$  and  $MR_{TX}$  when XHFC-1SU transmits a monitor byte sequence

#### 6.8.4.2 XHFC-1SU receive procedure

The monitor channel is full duplex and operates similar in the opposite direction. XHFC-1SU recognizes idle state with the specified handshake signals and accepts every idle pattern.

Figure 6.19 shows the receive procedure of two monitor bytes with double last look criterion enabled.





omitted, if the receiver sends acknowledge immediately

Figure 6.19: GCI protocol for monitor bytes receiving



- The monitor channel is idle when  $MX_{RX} = '1'$  and  $MR_{RX} = '1'$ . Any received data pattern is ignored.
- **2** The GCI transmitter sends the first monitor byte with  $MX_{RX} = '0'$ .

**③** The first monitor byte is received when  $MX_{RX} = '0'$ . When the same byte is received again (double last look enabled), it is latched and V\_MON\_RXR is set to '1'. After R\_MON\_RX has been read, acknowledge is send in the next 125 µs cycle with MR<sub>RX</sub> = '0'.

- **4** The transmitter receives acknowledge with  $MR_{RX} = '0'$ .
- **6** Answer  $MX_{RX} = '1'$  for one cycle and send the next monitor byte.
- The next monitor byte is received when MX<sub>RX</sub> = '1' for one cycle. When the same byte is received again (double last look enabled), it is latched and V\_MON\_RXR is set to '1'. After R\_MON\_RX has been read, acknowledge is send in the next 125 µs cycle with MR<sub>RX</sub> = '1'.
- **7** The transmitter receives acknowledge with with  $MR_{RX} = '1'$  for one cycle.
- The procedure shown with the second monitor byte (1.10) can be repeated until the whole message has been send.

Assumed that the GCI master finished the message transmission,  $MX_{RX}$  is set to '1' and remains in this state.

**9** When XHFC-1SU receives  $MX_{RX} = '1'$  twice, the monitor channel returns to idle state with  $MR_{RX} = '1'$ . The received byte is no valid monitor byte because  $MX_{RX}$  did not return to '0' after one cycle.

The rules for the handshake signals  $MX_{RX}$  and  $MR_{RX}$  when XHFC-1SU receives a monitor byte sequence are summarized in Table 6.12.

**Table 6.12:** Rules for the handshake signals  $MX_{RX}$  and  $MR_{RX}$  when XHFC-1SU receives a monitor byte sequence

| MX <sub>RX</sub> | MR <sub>RX</sub> | Monitor channel state                                          |
|------------------|------------------|----------------------------------------------------------------|
| '1'              | '1'              | Idle                                                           |
| '0'              | '0'              | Transmitter and receiver are both active                       |
| '0'              | '1' (once)       | Receive the 1 <sup>st</sup> monitor byte, not yet acknowledged |
| '0'              | '1' (repeated)   | Receiver terminates the transmission                           |
| '1' (once)       | ,0,              | Receiver answers to the acknowledge                            |
| '1' (repeated)   | '0'              | Impossible                                                     |

#### 6.8.4.3 Receiver abort

The receiver can abort the transmission if data cannot be used or is missing. This is done by MR = '1' for at least 2 cycles. The monitor channel returns to idle state in this case.

When XHFC-1SU operates as GCI master, it can receive an abort message from the GCI slave. This is reported with  $V\_GCI\_ABO = '1'$  in register  $R\_GCI\_STA$ . This bit is reset to '0' with a write access to register  $R\_MON\_TX$ . It is recommended to check  $V\_GCI\_ABO$  every time before writing a new monitor byte.

XHFC-1SU never aborts any message when it is receiver of the monitor channel.



# 6.9 Register description

# 6.9.1 Write only registers

| R_               | SLOT                                     |                                     |                                                                                | (w)                                              | (Reset group: H, 0, 2)                                                                                        | 0x10                          |  |  |
|------------------|------------------------------------------|-------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------|-------------------------------|--|--|
| PO               | PCM time slot selection                  |                                     |                                                                                |                                                  |                                                                                                               |                               |  |  |
| Th<br>reg<br>reg | iis register<br>gister mus<br>gister R_P | is used to<br>t specify t<br>CM_MD1 | select a PCM time slot<br>he desired slot number<br>, either 32, 64 or 128 tim | . Before a PC<br>and data dire<br>me slots are a | M slot array register can be accesse<br>ection. Depending on the V_PCM_<br>available for each data direction. | ed, this index<br>DR value in |  |  |
|                  | Bits                                     | Reset<br>value                      | Name                                                                           | De                                               | scription                                                                                                     |                               |  |  |
|                  | 0                                        | 0                                   | V_SL_DIR                                                                       | PC<br>'0' :<br>'1' :                             | <b>M time slot data direction</b><br>= transmit PCM data<br>= receive PCM data                                |                               |  |  |
|                  | 71                                       | 0x00                                | V_SL_NUM                                                                       | РС                                               | M time slot number                                                                                            |                               |  |  |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)



| R  | _PCM_MC  | 00             |           | (w) | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x14                     |
|----|----------|----------------|-----------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| PO | CM mode, | register (     | )         |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                          |
|    | Bits     | Reset<br>value | Name      |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                          |
|    | 0        | 0              | V_PCM_MD  |     | PCM bus mode<br>'0' = slave (pins C4IO and F0IO are inputs)<br>'1' = master (pins C4IO and F0IO are outputs<br>If no external C4IO and F0IO signal is provi<br>this bit must be set for operation.                                                                                                                                                                                                                                                                                                                                                                                                          | s)<br>ded                |
|    | 1        | 0              | V_C4_POL  |     | Polarity of C4IO clock<br>'0' = pin F0IO is sampled on negative clock<br>transition of C4IO<br>'1' = pin F0IO is sampled on positive clock<br>transition of C4IO                                                                                                                                                                                                                                                                                                                                                                                                                                            |                          |
|    | 2        | 0              | V_F0_NEG  |     | Polarity of FOIO signal<br>'0' = positive pulse<br>'1' = negative pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                          |
|    | 3        | 0              | V_F0_LEN  |     | <b>Duration of F0IO signal</b><br>'0' = active for one C4IO clock (244 ns at 4 M<br>'1' = active for two C4IO clocks (488 ns at 4<br>early leading edge)<br>The specified signal duration is generated in<br>master mode and it is expected in PCM slav<br>mode.                                                                                                                                                                                                                                                                                                                                            | MHz)<br>MHz,<br>PCM<br>e |
|    | 74       | 0              | V_PCM_IDX |     | Index value to select the register at addres<br>At address 15 a so-called multi-register is<br>accessible.<br>0 = R_SL_SEL0 register accessible<br>1 = R_SL_SEL1 register accessible<br>2 = not used<br>3 = not used<br>4 = not used<br>5 = not used<br>6 = not used<br>7 = R_SL_SEL7 register accessible<br>8 = R_MSS0 register accessible<br>9 = R_PCM_MD1 register accessible<br>0xA = R_PCM_MD2 register accessible<br>0xB = R_MSS1 register accessible<br>0xC = R_SH0L register accessible<br>0xD = R_SH0L register accessible<br>0xF = R_SH1L register accessible<br>0xF = R_SH1H register accessible | ss <b>15</b>             |



| R_ | _SL_SEL                                                                               | 0              |                         | (w)                               | (Reset group: H, 0, 2)                                                                                                                      | 0x15                         |  |  |
|----|---------------------------------------------------------------------------------------|----------------|-------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--|--|
| Sl | Slot selection register for pin F1_0                                                  |                |                         |                                   |                                                                                                                                             |                              |  |  |
| Th | This multi-register is selected with bitmap $V_PCM_IDX = 0$ in register $R_PCM_MD0$ . |                |                         |                                   |                                                                                                                                             |                              |  |  |
| No | ote: By se                                                                            | tting all 8    | bits to '1' pin F1_0 is | disabled.                         |                                                                                                                                             |                              |  |  |
|    | Bits                                                                                  | Reset<br>value | Name                    | De                                | scription                                                                                                                                   |                              |  |  |
|    | 60                                                                                    | 0x7F           | V_SL_SEL0               | PC<br>The<br>F1.<br>ma            | M time slot selection<br>e selected slot number is V_SL_SEL<br>_0. Slot number 0 is selected with th<br>ximum slot number of the selected F | 0 +1 for<br>ne<br>PCM speed. |  |  |
|    | 7                                                                                     | 1              | V_SH_SEL0               | Sha<br>'0' :<br>R_<br>'1' :<br>R_ | ape selection<br>= use shape 0 set by registers R_SH<br>SH0H<br>= use shape 1 set by registers R_SH<br>SH1H                                 | 0L and<br>1L and             |  |  |

# Important !

For selecting slot 0, the value that has to be written into bitmaps V\_SL\_SEL0 and V\_SL\_SEL1 of registers R\_SL\_SEL0 and R\_SL\_SEL1 depends on the PCM data rate:

| PCM data rate | Value |
|---------------|-------|
| PCM30         | 0x1F  |
| PCM64         | 0x3F  |
| PCM128        | 0x7F  |

Please note that time slot 0 for PCM128 can only be used with  $V\_SH\_SEL0 = '0'$  and  $V\_SH\_SEL1 = '0'$  (SHAPE 0) in registers  $R\_SL\_SEL0$  and  $R\_SL\_SEL1$ .



| R        | _SL_SEL                           | .1             |                                           | (w)                          | (Reset group: H, 0, 2)                                                                                                                       | 0x15                          |
|----------|-----------------------------------|----------------|-------------------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| SI<br>Tł | <b>ot selectio</b><br>nis multi-r | on register    | r for pin F1_1<br>selected with bitmap V_ | _PCM_IDX =                   | 1 in register R_PCM_MD0.                                                                                                                     |                               |
| N        | ote: By se                        | etting all 8   | bits to '1' pin F1_1 is d                 | lisabled.                    |                                                                                                                                              |                               |
|          | Bits                              | Reset<br>value | Name                                      | De                           | scription                                                                                                                                    |                               |
|          | 60                                | 0x7F           | V_SL_SEL1                                 | PC<br>Th<br>F1<br>ma         | CM time slot selection<br>e selected slot number is V_SL_SEL<br>_1. Slot number 0 is selected with th<br>ximum slot number of the selected P | .1 +1 for<br>ie<br>PCM speed. |
|          | 7                                 | 1              | V_SH_SEL1                                 | Sh<br>'0'<br>R_<br>'1'<br>R_ | ape selection<br>= use shape 0 set by registers R_SH<br>SH0H<br>= use shape 1 set by registers R_SH<br>SH1H                                  | 0L and<br>1L and              |

| R                                       | _SL_SEL                   | 7                        |                                           | (w)                   | (Reset group: H, 0, 2)                                                                                                                    | 0x15                                      |  |  |
|-----------------------------------------|---------------------------|--------------------------|-------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|--|
| Slot selection register for signal F1_7 |                           |                          |                                           |                       |                                                                                                                                           |                                           |  |  |
| Tł                                      | is multi-r                | egister is s             | elected with bitmap V_                    | PCM_IDX =             | 7 in register R_PCM_MD0.                                                                                                                  |                                           |  |  |
| Tł<br>Uı                                | ne F1_7 si<br>niversal IS | gnal is on<br>DN Port is | ly internally available.<br>s in NT mode. | It can be u           | sed to shift the synchronization sig                                                                                                      | nal when the                              |  |  |
|                                         | Bits                      | Reset<br>value           | Name                                      | De                    | escription                                                                                                                                |                                           |  |  |
|                                         | 60                        | 0x7F                     | V_SL_SEL7                                 | PC<br>Th<br>the<br>ma | CM time slot selection<br>e selected slot number is V_SL_SE<br>e F1_7 signal. Slot number 0 is sele<br>eximum slot number of the selected | EL7 +1 for<br>cted with the<br>PCM speed. |  |  |
|                                         | 7                         | 0                        | (reserved)                                | М                     | ust be '0'.                                                                                                                               |                                           |  |  |



| R_ | R_MSS0                                                     |                |                               |  | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                              | 0x15                               |  |
|----|------------------------------------------------------------|----------------|-------------------------------|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|--|
| PO | PCM multiframe/superframe synchronization mode, register 0 |                |                               |  |                                                                                                                                                                                                                                                                                                     |                                    |  |
| Th | is multi-re                                                | egister is s   | DX = 8 in register R_PCM_MD0. |  |                                                                                                                                                                                                                                                                                                     |                                    |  |
|    | Bits                                                       | Reset<br>value | Name                          |  | Description                                                                                                                                                                                                                                                                                         |                                    |  |
|    | 0                                                          | 0              | V_MSS_MOD                     |  | <b>F0IO pulse modification</b><br>The F0IO pulse duration can be changed to<br>generate the multiframe / superframe<br>synchronization signal.<br>'0' = normal operation<br>'1' = F0IO pulse is lengthened by one C4I0<br>to indicate the start of the multiframe / sup<br>(delayed trailing edge)  | o<br>O clock<br>erframe            |  |
|    | 1                                                          | 0              | V_MSS_MOD_REP                 |  | <b>F0IO modification repetition rate</b><br>The repetition rate of the modified F0IO sibe selected.<br>'0' = once every 40 PCM frames<br>'1' = once every 8 PCM frames                                                                                                                              | ignal can                          |  |
|    | 2                                                          | 0              | V_MSS_SRC_EN                  |  | Enable external multiframe / superfram<br>synchronization signal<br>'0' = disabled<br>'1' = enabled                                                                                                                                                                                                 | e                                  |  |
|    | 3                                                          | 0              | V_MSS_SRC_GRD                 |  | <b>Synchronization guard count</b><br>The multiframe/superframe synchronization signal is detected not before 7 or 39 PCM<br>'0' = not before 39 PCM frames<br>'1' = not before 7 PCM frames                                                                                                        | ion<br>frames.                     |  |
|    | 4                                                          | 0              | V_MSS_OUT_EN                  |  | Enable line interface synchronization signal is disabled<br>'0' = the synchronization signal is disabled<br>'1' = the synchronization signal is passed to<br>interface                                                                                                                              | <b>gnal for</b><br>l<br>o the line |  |
|    | 5                                                          | 0              | V_MSS_OUT_REP                 |  | Repetition rate of the line interface<br>synchronization signal for the<br>multiframe / superframe<br>The line interface synchronization signal i<br>generated either every 8th or 40th PCM fra<br>'0' = every 40th PCM frame<br>'1' = every 8th PCM frame (can only be us<br>pure Up environments) | s<br>ame.<br>æd in                 |  |

(continued on next page)



(continued from previous page)

| Bits Res | set Name<br>ue | Description                                                                                                                                                                                                          |
|----------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 76 0     | V_MSS_SRC      | Multiframe/superframe synchronization<br>source<br>One of the following signals can be chosen as<br>synchronization source.<br>'00' = pin F0IO<br>'01' = SYNC_I<br>'10' = STIO1<br>'11' = internal signal MSS_SYNC_I |



| R                                                                                     | _PCM_M               | D1             |            | (w) | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x15                                                                                                       |  |
|---------------------------------------------------------------------------------------|----------------------|----------------|------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|
| PO                                                                                    | PCM mode, register 1 |                |            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                            |  |
| This multi-register is selected with bitmap $V_PCM_IDX = 9$ in register $R_PCM_MD0$ . |                      |                |            |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                            |  |
|                                                                                       | Bits                 | Reset<br>value | Name       |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                            |  |
|                                                                                       | 0                    | 0              | (reserved) |     | Must be '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                            |  |
|                                                                                       | 1                    | 0              | V_PCM_OD   |     | Characteristic of the PCM output lines<br>'0' = STIO1 and STIO2 have push/pull<br>characteristic<br>'1' = STIO1 and STIO2 have open drain<br>characteristic (pull up resistor required)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                            |  |
|                                                                                       | 32                   | 0              | V_PLL_ADJ  |     | <b>DPLL adjust speed</b><br>'00' = C4IO clock is adjusted in the last time<br>the PCM frame 4 times by one clock cycle of<br>PCM clock $f_{PCM}$ (81.4 ns all 125 µs, 651 pp<br>'01' = C4IO clock is adjusted in the last time<br>the PCM frame 3 times by one clock cycle of<br>PCM clock $f_{PCM}$ (61.0 ns all 125 µs, 489 pp<br>'10' = C4IO clock is adjusted in the last time<br>the PCM frame twice by one clock cycle of<br>PCM clock $f_{PCM}$ (40.7 ns all 125 µs, 326 pp<br>'11' = C4IO clock is adjusted in the last time<br>the PCM frame once by one clock cycle of the PCM frame once by one clock cycle of the PCM frame once by one clock cycle of the PCM clock $f_{PCM}$ (20.3 ns all 125 µs, 163 pp | e slot of<br>of the<br>m)<br>e slot of<br>of the<br>m)<br>e slot of<br>the<br>m)<br>e slot of<br>che<br>m) |  |
|                                                                                       | 54                   | 0              | V_PCM_DR   |     | PCM data rate<br>'00' = 2 MBit/s (C4IO is $4.096$ MHz, 32 time<br>'01' = 4 MBit/s (C4IO is $8.192$ MHz, 64 time<br>'10' = 8 MBit/s (C4IO is $16.384$ MHz, 128 ti<br>slots)<br>'11' = 0.75 MBit/s (C4IO is $1.536$ MHz, 12 t<br>slots)<br>Every time slot exists in transmit and receiv<br>direction.                                                                                                                                                                                                                                                                                                                                                                                                                   | e slots)<br>e slots)<br>me<br>ime<br>e data                                                                |  |
|                                                                                       | 6                    | 0              | V_PCM_LOOP |     | <ul> <li>PCM test loop</li> <li>When this bit is set, the PCM output data is to the PCM input data internally for all PCM slots.</li> <li>Note: When this bit is set (internal PCM loot is not allowed to set bit V_PCM_OD in regint R_PCM_MD1 as well.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                     | looped<br>A time<br>op), it<br>ister                                                                       |  |

(continued on next page)



(continued from previous page)

| Bits | Reset<br>value | Name       | Description                                                                                                                                 |
|------|----------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | 0              | V_PCM_SMPL | PCM receive sample point<br>'0' = sample point at middle of PCM bit cell<br>(normal operation)<br>'1' = sample point at 3/4 of PCM bit cell |


| R_ | PCM_ME      | )2             | ( <b>w</b> )               | (Reset group: H, 0, 2) <b>0x15</b>                                                                                                                                                                                                                                                                                                                                                                            |
|----|-------------|----------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC | CM mode,    | register 2     | 2                          |                                                                                                                                                                                                                                                                                                                                                                                                               |
| Th | is multi-re | gister is s    | elected with bitmap V_PCM_ | $IDX = 0xA$ in register R_PCM_MD0.                                                                                                                                                                                                                                                                                                                                                                            |
|    | Bits        | Reset<br>value | Name                       | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|    | 0           | 0              | (reserved)                 | Must be '0'.                                                                                                                                                                                                                                                                                                                                                                                                  |
|    | 1           | 0              | V_SYNC_OUT1                | <ul> <li>SYNC_O output signal selection</li> <li>V_SYNC_OUT2 is also used for synchronization selection.</li> <li>'0' = SYNC_O signal is either SYNC_I or the received synchronization pulse FSC_RX (see register R_SU_SYNC for synchronization source selection)</li> <li>'1' = SYNC_O signal is either 512 kHz from the PLL or the received multiframe / superframe synchronization pulse</li> </ul>        |
|    | 2           | 0              | V_SYNC_SRC                 | PCM PLL synchronization source selection<br>'0' = line interface (see R_SU_SYNC for further<br>synchronization configuration)<br>'1' = SYNC_I input (8 kHz)                                                                                                                                                                                                                                                   |
|    | 3           | 0              | V_SYNC_OUT2                | <ul> <li>SYNC_O output signal selection</li> <li>V_SYNC_OUT1 is also used for synchronization selection.</li> <li>'0' = SYNC_O signal is either the received synchronization pulse FSC_RX (see register</li> <li>R_SU_SYNC for synchronization source selection) or 512 kHz from the PLL</li> <li>'1' = SYNC_O signal is either SYNC_I or the received multiframe/superframe synchronization pulse</li> </ul> |
|    | 4           | 0              | V_C2O_EN                   | Enable C2IO output signal<br>'0' = C2IO output is disabled<br>'1' = C2IO output is enabled when also V_C2I_EN<br>= '0'                                                                                                                                                                                                                                                                                        |
|    | 5           | 0              | V_C2I_EN                   | Single Clock on C2IO is used as PCM clock<br>(master and slave mode)<br>'0' = PCM data controller gets C4IO input clock<br>'1' = PCM data controller gets C2IO input clock                                                                                                                                                                                                                                    |
|    | 6           | 0              | V_PLL_ICR                  | Increase PCM frame time<br>This bit is only valid if V_PLL_MAN is set.<br>'0' = PCM frame time is reduced as selected by<br>bitmap V_PLL_ADJ in register R_PCM_MD1<br>'1' = PCM frame time is increased as selected by<br>bitmap V_PLL_ADJ in register R_PCM_MD1                                                                                                                                              |

(continued on next page)



(continued from previous page)

| Bits R | leset Na<br>alue Na | me      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 0    | V                   | PLL_MAN | Manual PLL adjustment<br>'0' = PCM PLL is automatically adjusted to the<br>SYNC_I signal or to the line interface<br>synchronization pulse (depending on<br>V_SYNC_OUT2 setting)<br>'1' = PCM PLL is manually adjusted according to<br>V_PLL_ICR. This can be used to make<br>synchronization by software if no synchronization<br>source is available.<br>Note: Manual PLL adjustment is automatically<br>disabled when a synchronization pulse is available. |



| R_ | _MSS1                                                      |                |                           | (w)                                                                                                | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                                                                                                     | 0x15                                                                     |  |  |  |
|----|------------------------------------------------------------|----------------|---------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--|--|--|
| PC | PCM multiframe/superframe synchronization mode, register 1 |                |                           |                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                            |                                                                          |  |  |  |
| Th | is multi-re                                                | egister is so  | elected with bitmap $V_F$ | PCM_IDX =                                                                                          | = 0xB in register R_PCM_MD0.                                                                                                                                                                                                                                                                                                                                               |                                                                          |  |  |  |
|    | Bits                                                       | Reset<br>value | Name                      | D                                                                                                  | escription                                                                                                                                                                                                                                                                                                                                                                 |                                                                          |  |  |  |
|    | 20                                                         | 0              | V_MSS_OFFS                | S:<br>Ti<br>cc<br>sf<br>bc<br>'0<br>'0<br>'0<br>'0<br>'0<br>'0<br>'0<br>'0<br>'1<br>'1<br>'1<br>'1 | ynchronization source offset<br>he offset between the synchronizatio<br>punter and the generated synchroniz.<br>becified in number of PCM frames. The<br>chosen in the range -4+3.<br>00' = no offset<br>01' = 1 PCM frame<br>10' = 2 PCM frames<br>11' = 3 PCM frames<br>00' = -4 PCM frames<br>10' = -2 PCM frames<br>10' = -1 PCM frames                                | on frame<br>ation signal is<br>The value can                             |  |  |  |
|    | 3                                                          | 0              | V_MS_SSYNC1               | M<br>90<br>90<br>91<br>11<br>11<br>10<br>N<br>V                                                    | <b>Aultiframe / superframe single syncluse</b><br>' = a repetitive synchronization signation and the synchronization signation of the synchronization signation of the synchronization synce of the multiframe / superframe synce put signal is directly used (this is not generate a single MSS_SYNC_O pote: When this bit is set to '1', usual _MS_SSYNC2 has to be set. | chronization<br>al is<br>hronization<br>ormally used<br>ulse)<br>ly also |  |  |  |
|    | 74                                                         | 0              | V_MSS_DLY                 | M<br>T<br>al<br>bi<br>cl<br>0<br>1<br><br>1                                                        | Aultiframe / superframe delay<br>the position of multiframe / superframe<br>ways related to the regular F0IO sig<br>tmap specifies the delay in number of<br>ock pulses.<br>= 1 C4IO pulse delay<br>= 2 C4IO pulses delay<br>5 = 16 C4IO pulses delay                                                                                                                      | ne data is<br>nal. This<br>of C4IO                                       |  |  |  |



| R_ | _SH0L                              |                |                     | (w)         | (Reset group: H, 0, 2)                                  | 0x15 |  |  |  |
|----|------------------------------------|----------------|---------------------|-------------|---------------------------------------------------------|------|--|--|--|
| C  | CODEC enable signal F1_0, low byte |                |                     |             |                                                         |      |  |  |  |
| Tł | nis multi-re                       | egister is s   | elected with bitmap | V_PCM_IDX = | • 0xC in register R_PCM_MD0.                            |      |  |  |  |
|    | Bits                               | Reset<br>value | Name                | D           | escription                                              |      |  |  |  |
|    | 70                                 | 0x00           | V_SH0L              | SI<br>Ev    | ape bits 70<br>very bit is used for 1/2 C4IO clock cycl | e.   |  |  |  |

| CODEC enable signal F1_0, high byte         This multi-register is selected with bitmap V_PCM_IDX = 0xD in register R_PCM_MD0.         Bits       Reset value       Name       Description | R.      | _SH0H                                                                                                                     |                |        | (w)               | (Reset group: H, 0, 2)                                                                                                    | 0x15   |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------|----------------|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------|--------|--|--|
| Bits Reset value Name Description                                                                                                                                                          | C<br>Tł | CODEC enable signal F1_0, high byte<br>This multi-register is selected with bitmap V_PCM_IDX = 0xD in register R_PCM_MD0. |                |        |                   |                                                                                                                           |        |  |  |
|                                                                                                                                                                                            |         | Bits                                                                                                                      | Reset<br>value | Name   | D                 | escription                                                                                                                |        |  |  |
| 70       0x00       V_SHOH       Shape bits 158         Every bit is used for 1/2 C4IO clock cycle.       Bit 7 of V_SHOH defines the value for the rest of the period.                    |         | 70                                                                                                                        | 0x00           | V_SH0H | S<br>E<br>B<br>th | hape bits 158<br>very bit is used for 1/2 C4IO clock cycle.<br>it 7 of V_SH0H defines the value for the re-<br>ne period. | est of |  |  |

| R_       | _SH1L    |                |                                                             | (w)         | (Reset group: H, 0, 2)                                   | 0x15 |
|----------|----------|----------------|-------------------------------------------------------------|-------------|----------------------------------------------------------|------|
| CO<br>Th | ODEC ena | able signa     | <b>I F1_1, low byte</b><br>elected with bitmap <sup>v</sup> | V_PCM_IDX = | 0xE in register R_PCM_MD0.                               |      |
|          | Bits     | Reset<br>value | Name                                                        | De          | scription                                                |      |
|          | 70       | 0x00           | V_SH1L                                                      | Sha<br>Eve  | ape bits 70<br>ery bit is used for 1/2 C4IO clock cycle. |      |



| R_                                                                                                                               | _SH1H |                |        | (w)                   | (Reset group: H, 0, 2)                                                                                        | 0x15              |  |
|----------------------------------------------------------------------------------------------------------------------------------|-------|----------------|--------|-----------------------|---------------------------------------------------------------------------------------------------------------|-------------------|--|
| <b>CODEC enable signal F1_1, high byte</b><br>This multi-register is selected with bitmap V_PCM_IDX = 0xF in register R_PCM_MD0. |       |                |        |                       |                                                                                                               |                   |  |
|                                                                                                                                  | Bits  | Reset<br>value | Name   | De                    | escription                                                                                                    |                   |  |
|                                                                                                                                  | 70    | 0x00           | V_SH1H | Sh<br>Ev<br>Bi<br>the | ape bits 158<br>ery bit is used for 1/2 C4IO clock cycl<br>t 7 of V_SH1H defines the value for the<br>period. | le.<br>ne rest of |  |



| R_ | _SU_SYN     | С              |                        | (w)     | (Reset group: H, 0, 3)                                                                                                                                                                                                                                                                                                                                                                                        | 0x17                                                                                          |
|----|-------------|----------------|------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| ST | /Up synch   | nronizatio     | n source               |         |                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                               |
| Th | is register | selects the    | synchronization source | for the | internal or external PCM clock PLL.                                                                                                                                                                                                                                                                                                                                                                           |                                                                                               |
|    | Bits        | Reset<br>value | Name                   |         | Description                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                               |
|    | 20          | 0              | V_SYNC_SEL             |         | Synchronization source selection<br>The line interface or the SYNC_I input so<br>be selected as synchronization source. The<br>interface can be used as synchronization<br>only if it is in TE mode.<br>'000' = source is the line interface<br>'001''011' = not allowed<br>'100' = source is SYNC_I signal<br>'101''111' = not allowed                                                                       | signal can<br>The line<br>n source                                                            |
|    | 3           | 0              | V_MAN_SYNC             |         | Automatically synchronization source<br>'0' = automatic synchronization source s<br>When the TE is synchronized to the inco-<br>signal (e.g. state F6 or F7), it is chosen a<br>synchronization source and V_SYNC_S<br>ignored.<br>'1' = manual synchronization source sele<br>V_SYNC_SEL is used for synchronizat<br>The current synchronization source can<br>from V_RD_SYNC_SRC in register<br>R_BERT_STA. | e selection<br>belection.<br>coming S/T<br>as<br>SEL is<br>section.<br>ion source.<br>be read |
|    | 4           | 0              | V_AUTO_SYNCI           |         | Enable SYNC_I as synchronization signadition to the line interface synchronization signal pulse FSC_RX, SYNC_I can be taken for synchronization.<br>'0' = SYNC_I is not used for synchronizit' i = SYNC_I is automatically used for synchronization if no FSC_RX pulse is                                                                                                                                     | gnal<br>nization<br>or<br>ation<br>detected                                                   |
|    | 75          | 0              | (reserved)             |         | Must be '000'.                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                               |



| R | _CI_TX   |                |              | (w) | (Reset group: H, 0, 2)                                                                                                                                                                                            | 0x28                                             |
|---|----------|----------------|--------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|
| C | I-channe | l of the G     | CI interface |     |                                                                                                                                                                                                                   |                                                  |
|   | Bits     | Reset<br>value | Name         |     | Description                                                                                                                                                                                                       |                                                  |
|   | 50       | 0              | V_GCI_C      |     | <b>Command bits of the C/I-channel</b><br>These bits are continously send in the C<br>C/I-channel length can either be 4 bit or<br>according to V_MON_CI6 setting. Bits<br>ignored when the C/I-channel length is | C/I-channel.<br>r 6 bit<br>5 [5,4] are<br>4 bit. |
|   | 76       | 0              | (reserved)   |     | Must be '00'.                                                                                                                                                                                                     |                                                  |



| R_ | _GCI_CF    | GO             | (                   | (w) | (Reset group: H, 0, 2) 0                                                                                                                                                                                                                                                                                                                                            | )x29                 |
|----|------------|----------------|---------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| G  | CI interfa | ce configu     | iration, register 0 |     |                                                                                                                                                                                                                                                                                                                                                                     |                      |
|    | Bits       | Reset<br>value | Name                |     | Description                                                                                                                                                                                                                                                                                                                                                         |                      |
|    | 0          | 0              | V_MON_END           |     | <b>End of command flag for the monitor chann</b><br>The transmitted monitor command ends after th<br>next monitor byte.                                                                                                                                                                                                                                             | <b>el</b><br>he      |
|    | 1          | 0              | V_MON_SLOW          |     | <b>Transmission speed of the monitor channel</b><br>'0' = the next monitor byte is sent immediately<br>after the receive handshake bit gets high<br>'1' = the next monitor byte is sent after a<br>high-to-low transition of the receive handshake                                                                                                                  | bit                  |
|    | 2          | 0              | V_MON_DLL           |     | Enable <i>double last look criterion</i><br>'0' = a received monitor byte is accepted at once<br>'1' = a monitor byte is accepted only if it is<br>received twice                                                                                                                                                                                                   | e                    |
|    | 3          | 0              | V_MON_CI6           |     | <b>Expand C/I-channel width to 6 bits</b><br>'0' = 4 bit C/I-channel<br>'1' = 6 bit C/I-channel (no D-channel transmiss                                                                                                                                                                                                                                             | ion)                 |
|    | 4          | 0              | V_GCI_SWAP_TXHS     |     | Swap handshake bits for transmitted monitod<br>bytes<br>'0' = normal operation (XHFC-1SU is GCI mast<br>'1' = handshake bits $MR_{TX}$ and $MX_{TX}$ are<br>swapped (XHFC-1SU is GCI slave)<br>Note: This bit must be set when XHFC-1SU<br>operates in GCI slave mode. Bits<br>V_GCI_SWAP_RXHS and V_GCI_SWAP_ST<br>in this register must also be set in this case. | or<br>ter)<br>TIO    |
|    | 5          | 0              | V_GCI_SWAP_RXHS     |     | Swap handshake bits for received monitor by<br>'0' = normal operation (XHFC-1SU is GCI mast<br>'1' = handshake bits $MR_{RX}$ and $MX_{RX}$ are swap<br>(XHFC-1SU is GCI slave)<br>Note: This bit must be set when XHFC-1SU<br>operates in GCI slave mode. Bits<br>V_GCI_SWAP_TXHS and V_GCI_SWAP_ST<br>in this register must also be set in this case.             | ytes<br>ter)<br>pped |

(continued on next page)



(continued from previous page)

| Bits | Reset<br>value | Name            | Description                                                                                                                                                                                                                                                                                                                                                                  |
|------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6    | 0              | V_GCI_SWAP_STIO | Swap STIO pins for monitpor bytes and<br>C/I-channel<br>'0' = normal operation (XHFC-1SU is GCI master)<br>'1' = swap STIO1 and STIO2 for monitor bytes and<br>C/I-channel (XHFC-1SU is GCI slave)<br>Note: This bit must be set when XHFC-1SU<br>operates in GCI slave mode. Bits<br>V_GCI_SWAP_TXHS and V_GCI_SWAP_RXHS<br>in this register must also be set in this case. |
| 7    | 0              | V_GCI_EN        | Enable GCI interface function<br>When this bit is set to '1', monitor bytes are<br>transmitted and received on GCI time slot 2,<br>C/I-channel and handshake bits are mapped to GCI<br>time slot 3 and I/O direction of the pins STIO1 and<br>STIO2 is configured according to bit<br>V_GCI_SWAP_STIO. GCI time slots are chosen<br>according to the R_GCI_CFG1 selection.   |



| R_ | _GCI_CF    | G1             |                     | (w) | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0x2A                                                                                               |
|----|------------|----------------|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| G  | CI interfa | ce configu     | iration, register 1 |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                    |
|    | Bits       | Reset<br>value | Name                |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                    |
|    | 40         | 0              | V_GCI_SL            |     | Slot group of the GCI interface<br>The GCI interface allocates four PCM time<br>$4 \cdot V\_GCI\_SL4 \cdot V\_GCI\_SL+3$ . Monitor I<br>C/I-channel and handshake bits are automating<br>mapped to their dedicated position. B1-, B2<br>D-channels must be assigned according to the<br>needs with normal PCM slot assigner<br>programming (registers R\_SLOT and<br>A\_SL\_CFG).<br>0 = time slots  03<br>1 = time slots  2831<br>8 = time slots  3235 (normally not used, of<br>PCM64 and PCM128)<br><br>16 = time slots  3235 (normally not used, for PCM128)<br><br>31 = time slots  124127 (normally not used<br>for PCM128)<br>Note: Normally, GCI requires PCM30 data<br>which results in valid bitmap values $07$ . W<br>PCM64 or PCM128 is used with GCI<br>functionality, $015$ or $031$ can be chosen | slots<br>bytes,<br>tically<br>2- and<br>he GCI<br>nly for<br>only<br>d, only<br>rate<br>When<br>n. |
|    | 75         | 0              | (reserved)          |     | Must be '000'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                    |

| R | _MON_T    | K              |          | (w) | (Reset group: H, 0, 2)              | 0x2B |
|---|-----------|----------------|----------|-----|-------------------------------------|------|
| Μ | onitor da | ta byte        |          |     |                                     |      |
|   | Bits      | Reset<br>value | Name     |     | Description                         |      |
|   | 70        | 0              | V_MON_TX |     | Monitor data byte to be transmitted |      |



### 6.9.2 Read only registers

| R_F0_CNTL |           |                |           | ( <b>r</b> ) | (Reset group: H, 0, 1)                                                                                       | 0x18                       |
|-----------|-----------|----------------|-----------|--------------|--------------------------------------------------------------------------------------------------------------|----------------------------|
| FO        | )IO pulse | counter, lo    | ow byte   |              |                                                                                                              |                            |
|           | Bits      | Reset<br>value | Name      | ]            | Description                                                                                                  |                            |
|           | 70        | 0x00           | V_F0_CNTL |              | Low byte (bits 70) of the 125 µs tir<br>This register should be read first to late<br>of register R_F0_CNTH. | ne counter<br>ch the value |

| F0IO pulse counter, high byte                                                                                                                     |                      |
|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|                                                                                                                                                   |                      |
| Bits Reset value Name Description                                                                                                                 |                      |
| 70       0x00       V_F0_CNTH       High byte (bits 158) of the 125 µs time control of the low byte should be read first (see register R_F0_CNTL) | o <b>unter</b><br>Pr |

| R_SL_  | XAN            |          | ( <b>r</b> )                            | (Reset group: –)                                                                                                                                                                                                                        | 0x1D                                                    |
|--------|----------------|----------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| Number | r of PCM tim   | e slots  |                                         |                                                                                                                                                                                                                                         |                                                         |
| Bits   | Reset<br>value | Name     | De                                      | scription                                                                                                                                                                                                                               |                                                         |
| 7(     | )              | V_SL_MAX | Nu<br>PC<br>Ma<br>V_<br>63<br>Sla<br>po | <b>Imber of last PCM time slot</b><br>M time slots are numbered 0V_<br>aster mode: Four values are possibl<br>PCM_DR setting in register R_PC<br>, 127 or 11)<br>we mode: Any value in the range 0<br>ssible due to PCM master configur | SL_MAX.<br>le due to<br>CM_MD1 (31,<br>)127 is<br>ation |



| R | _CI_RX    |                |             | ( <b>r</b> )                                           | (Reset group: –)                                                                                                                                                                                  | 0x28                                 |
|---|-----------|----------------|-------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|
| C | I-channel | of the GC      | I interface |                                                        |                                                                                                                                                                                                   |                                      |
|   | Bits      | Reset<br>value | Name        | Descr                                                  | iption                                                                                                                                                                                            |                                      |
|   | 50        |                | V_GCI_I     | Indica<br>These<br>C/I-ch<br>C/I-ch<br>accord<br>alway | ation bits of the C/I-channel<br>bits are continously received in the<br>nannel.<br>nannel length can either be 4 bit or<br>ling to V_MON_CI6 setting. Bits<br>s '00' when the C/I-channel length | e<br>6 bit<br>[5,4] are<br>is 4 bit. |
|   | 76        |                | (reserved)  |                                                        |                                                                                                                                                                                                   |                                      |



| R_GCI_STA                            |      |                |            | ( <b>r</b> ) | (Reset group: H, 0, 2)                                                                                                                                                     | 0x29               |
|--------------------------------------|------|----------------|------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Status register of the GCI interface |      |                |            |              |                                                                                                                                                                            |                    |
|                                      | Bits | Reset<br>value | Name       |              | Description                                                                                                                                                                |                    |
|                                      | 0    | 0              | V_MON_RXR  |              | Monitor receiver ready<br>A monitor byte has been received and can be<br>from register R_MON_RX.                                                                           | read               |
|                                      | 1    | 1              | V_MON_TXR  |              | <b>Monitor transmitter ready</b><br>A monitor byte has been send and the next by<br>can be written into register R_MON_TX.                                                 | yte                |
|                                      | 2    | 1              | V_GCI_MX   |              | <b>Status of MX handshake bit</b><br>This bit shows the current status of the MX <sub>RN</sub> handshake bit (normally not used, for test pur only).                       | r<br>poses         |
|                                      | 3    |                | V_GCI_MR   |              | <b>Status of MR handshake bit</b><br>This bit shows the current status of the MR <sub>RX</sub> handshake bit (normally not used, for test pur only).                       | rposes             |
|                                      | 4    | 0              | V_GCI_RX   |              | Receiving monitor byte<br>'0' = monitor byte transmission from GCI dev<br>XHFC-1SU is idle<br>'1' = monitor byte transmission from GCI dev<br>XHFC-1SU is currently active | vice to<br>vice to |
|                                      | 5    | 0              | V_GCI_ABO  |              | Receiver abort<br>'0' = normal operation<br>'1' = receiver aborted the monitor byte transm                                                                                 | nission            |
|                                      | 76   |                | (reserved) |              |                                                                                                                                                                            |                    |

| R | _MON_R    | Х              |          | ( <b>r</b> ) | (Reset group: –)        | 0x2A |
|---|-----------|----------------|----------|--------------|-------------------------|------|
| Μ | onitor da | ıta byte       |          |              |                         |      |
|   | Bits      | Reset<br>value | Name     | Desc         | ription                 |      |
|   | 70        |                | V_MON_RX | Rece         | eived monitor data byte |      |



### 6.9.3 Read/write register

| A_SL_CFG [SLOT] |                                                                                                                                  |                |            | w)                                                                                                                                     | (Reset group: H, 0, 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0xD0                                                 |  |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|
| Н               | HFC-channel assignment for the selected PCM time slot and PCM output buffer configuration                                        |                |            |                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                      |  |  |  |
| W<br>bu         | With this register a HFC-channel can be assigned to the selected PCM time slot. Additionally, the PCM buffers can be configured. |                |            |                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                      |  |  |  |
| В               | Before writing this array register the PCM time slot must be selected by register R_SLOT.                                        |                |            |                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                      |  |  |  |
|                 | Bits                                                                                                                             | Reset<br>value | Name       | Desc                                                                                                                                   | ription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                      |  |  |  |
|                 | 0                                                                                                                                | 0              | V_CH_SDIR  | HFC<br>'0' = ]<br>'1' = ]                                                                                                              | <b>-channel data direction</b><br>HFC-channel for transmit data<br>HFC-channel for receive data                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                      |  |  |  |
|                 | 41                                                                                                                               | 0x00           | V_CH_SNUM  | <b>HFC</b> (01                                                                                                                         | -channel number<br>5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                      |  |  |  |
|                 | 5                                                                                                                                |                | (reserved) | Must                                                                                                                                   | be '0' when written.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                      |  |  |  |
|                 | 76                                                                                                                               | 0              | V_ROUT     | PCM<br>For tr<br>'00' =<br>disab<br>'10' =<br>'11' =<br>For ra<br>'00' =<br>input<br>'01' =<br>'10' =<br>'11' =<br>Note<br>PCM<br>V_PC | output buffer configuration<br>ansmit time slots:<br>data transmission from HFC-chan<br>led, output buffers disabled<br>loop PCM data internally, output l<br>led<br>output buffer for STIO1 enabled<br>output buffer for STIO2 enabled<br>eceive time slots:<br>data transmission to HFC-channel<br>data is ignored<br>loop PCM data internally<br>receive data from STIO2<br>receive data from STIO1<br>: When this bitmap is set to '01' (in<br>loop), it is not allowed to set bit<br>CM_OD in register R_PCM_MD1 | nel<br>buffers<br>I disabled,<br>iternal<br>as well. |  |  |  |

(See Section 2.2.3.2 on page 45 for details on Read\* access.)



# Chapter 7

# Pulse width modulation (PWM) outputs

Table 7.1: Overview of the XHFC-1SU PWM registers

| Address | Name      | Page |
|---------|-----------|------|
| 0x1E    | R_PWM_CFG | 269  |
| 0x38    | R_PWM0    | 269  |
| 0x39    | R_PWM1    | 270  |
| 0x46    | R_PWM_MD  | 270  |



## 7.1 Overview

XHFC-1SU has two PWM output lines PWM0 and PWM1 with programmable output characteristic.

The output lines can be configured as open drain, open source and push/pull by setting V\_PWM0\_MD respectively V\_PWM1\_MD in register R\_PWM\_MD.

## 7.2 Standard PWM usage

The duty cycle of the output signals can be set in registers  $R_PWM0$  and  $R_PWM1$ . The register value defines the number of clock periods where the output signal is high during the cycle time

$$T = 256 \cdot \frac{2^{3 \cdot \text{V}} - \text{PWM}_{\text{FRQ}}}{f_{\text{SYS}}}$$

The variable duty cycle

$$\frac{t_{\text{high}}}{t_{\text{low}}} = \frac{i}{256 - i} , i = \text{value of } \text{R}_{\text{PWM0}} \text{ or } \text{R}_{\text{PWM1}}$$

of the PWM output pins can be set from 1:255 to 255:1. The register value 0 generates an output signal which is permanently low. The duty cycle 1:1 is achieved with i = 128.

There are always *i* pulses within the period *T*. Each pulse-width is a multiple  $1/f_{SYS}$ . Due to the setup values, different pulse-width might occur. Pulses with longer or shorter width than the mostly appearing width are distributed through the whole period.

The ouput signal of the PWM unit can be used for analog settings by using an external RC filter which generates a voltage that can be adapted by changing the PWM register value.

## 7.3 Alternative PWM usage

The PWM output lines can be programmed to generate a 16 kHz signal. This signal can be used as analog metering pulse for POTS interfaces. Each PWM output line can be switched to 16 kHz signal by setting V\_PWM0\_16KHZ or V\_PWM1\_16KHZ in register R\_PWM\_CFG. In this case the output characteristic is also determined by the R\_PWM\_MD register settings.



## 7.4 Register description

| R_ | _PWM_C | FG             |              | (w)                   | (Reset group: H, 0)                                                                                                                                                                                                                                                  | 0x1E      |
|----|--------|----------------|--------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
|    |        |                |              |                       |                                                                                                                                                                                                                                                                      |           |
|    | Bits   | Reset<br>value | Name         | ]                     | Description                                                                                                                                                                                                                                                          |           |
|    | 30     | 0              | (reserved)   | ]                     | Must be '0000'.                                                                                                                                                                                                                                                      |           |
|    | 4      | 0              | V_PWM0_16KHZ | 1                     | <b>16 kHz signal on PWM0</b><br>'0' = normal PWM output due to the <b>R_PWM</b><br>register setting<br>'1' = 16 kHz output on <b>PWM0</b>                                                                                                                            | 0         |
|    | 5      | 0              | V_PWM1_16KHZ | -<br>-<br>-<br>-<br>- | <b>16 kHz signal on PWM1</b><br>'0' = normal PWM output due to the R_PWM<br>register setting<br>'1' = 16 kHz output on PWM1                                                                                                                                          | 1         |
|    | 76     | 0              | V_PWM_FRQ    | ,<br>,<br>,<br>,<br>, | The PWM frequency is derived from the syste<br>clock $f_{SYS}$ and can be reduced with this bitma<br>'00' = PWM frequency is $f_{SYS}$<br>'01' = PWM frequency is $f_{SYS} / 8$<br>'10' = PWM frequency is $f_{SYS} / 64$<br>'11' = PWM frequency is $f_{SYS} / 512$ | em<br>.p. |

| R_PWM0    |                |             | (w)                                                             | (Reset group: H, 0)                                                                                                                                                                                                          | 0x38                                   |
|-----------|----------------|-------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| Modulator | register fo    | or pin PWM0 |                                                                 |                                                                                                                                                                                                                              |                                        |
| Bits      | Reset<br>value | Name        | De                                                              | scription                                                                                                                                                                                                                    |                                        |
| 70        | 0x00           | V_PWM0      | <b>PV</b><br>Th<br>wh<br>25<br>0x<br>0x<br>0x<br>0x<br>0x<br>0x | WM duty cycle<br>e value specifies the number of clock<br>ere the output signal of PWM0 is hig<br>6 clock periods cycle, e.g.<br>00 = no pulse, always low<br>30 = 1/1 duty cycle<br>FF = 1 clock period low after 255 cloch | c periods<br>h during a<br>ock periods |



| R | _PWM1    |                |             | (w)                                                       | (Reset group: H, 0)                                                                                                                                                                                                           | 0x39                     |
|---|----------|----------------|-------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Μ | odulator | register fo    | or pin PWM1 |                                                           |                                                                                                                                                                                                                               |                          |
|   | Bits     | Reset<br>value | Name        | Dese                                                      | cription                                                                                                                                                                                                                      |                          |
|   | 70       | 0x00           | V_PWM1      | PW:<br>The<br>256<br>0x00<br>0x80<br>0x80<br>0xFF<br>high | M duty cycle<br>value specifies the number of clock per<br>re the output signal of PWM1 is high du<br>clock periods cycle, e.g.<br>0 = no pulse, always low<br>0 = 1/1 duty cycle<br>F = 1 clock period low after 255 clock p | iods<br>ring a<br>eriods |

| R_                       | _PWM_M | D              | (          | (w) | (Reset group: H, 0) <b>0</b>                                                                                                                                                | x46 |
|--------------------------|--------|----------------|------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| PWM output mode register |        |                | egister    |     |                                                                                                                                                                             |     |
|                          | Bits   | Reset<br>value | Name       |     | Description                                                                                                                                                                 |     |
|                          | 0      | 0              | (reserved) |     | Must be '0'.                                                                                                                                                                |     |
|                          | 1      | 0              | V_WAK_EN   |     | Enable WAKEUP pin<br>'0' = disable WAKEUP pin<br>'1' = enable WAKEUP pin                                                                                                    |     |
|                          | 32     | 0              | (reserved) |     | Must be '00'.                                                                                                                                                               |     |
|                          | 54     | 0              | V_PWM0_MD  |     | Output buffer configuration for pin PWM0<br>'00' = PWM output tristate (disable)<br>'01' = PWM push / pull output<br>'10' = PWM push to 0 only<br>'11' = PWM pull to 1 only |     |
|                          | 76     | 0              | V_PWM1_MD  |     | Output buffer configuration for pin PWM1<br>'00' = PWM output tristate (disable)<br>'01' = PWM push/pull output<br>'10' = PWM push to 0 only<br>'11' = PWM pull to 1 only   |     |



# Chapter 8

# **Bit Error Rate Test (BERT)**

Table 8.1: Overview of the XHFC-1SU BERT registers

| Write only | registers:   | Read only registers: |         |            |      |
|------------|--------------|----------------------|---------|------------|------|
| Address    | Name         | Page                 | Address | Name       | Page |
| 0x1B       | R_BERT_WD_MD | 276                  | 0x17    | R_BERT_STA | 277  |
|            |              |                      | 0x1A    | R_BERT_ECL | 277  |
|            |              |                      | 0x1B    | R_BERT_ECH | 278  |



## **8.1 BERT functionality**

*Bit Error Rate Test* (BERT) is a very important test for communication lines. The bit error rate should be as low as possible. Increasing bit error rate is an early indication of a malfunction of components or the communication wire link itself.

XHFC-1SU includes a high performance pseudo random bit generator (PRBG) and a pseudo random bit receiver with automatic synchronization capability. The error rate can be checked by the also implemented Bit Error counter (BERT counter).

Please note !

Transparent mode must be selected for Bit Error Rate Test.

## 8.2 BERT transmitter

The PRBG can be set to a variety of different pseudo random bit patterns. Continous '0', continous '1' or pseudo random bit patterns with one of 6 selectable sequence length's from  $2^9 - 1$  bit to  $2^{23} - 1$  bit can be configured with bitmap V\_PAT\_SEQ in register R\_BERT\_WD\_MD. All bit sequences are defined in the ITU-T O.150 [11] and O.151 [10] specifications.

The BERT patterns are passed through the HFC-channel assigner if V\_BERT\_EN = '1' in register A\_FIFO\_CTRL[FIFO]. For this reason, either a FIFO-to-ST/U<sub>p</sub> or a FIFO-to-PCM configuration must be selected. Furthermore, the allocated FIFO must be enabled to switch on the data path.

BERT patterns are generated if at least one FIFO has its bit V\_BERT\_EN set to '1'. When more than one transmit FIFO are using BERT patterns, all these patterns are generated from the same pseudo random generator. They are distributed to the FIFOs in the order of the FIFO processing sequence (see Section 3.2.3 on page 78).

Subchannel processing can be used together with the *Bit Error Rate Test*. Then the number of bits taken from the PRBG is V\_BIT\_CNT.

## Please note !

To test a connection and the error detection capability of the BERT error counter, a BERT error can be generated on the receiver side of an ST/U<sub>p</sub> link. Setting bit V\_BERT\_ERR in register R\_BERT\_WD\_MD generates one wrong BERT bit in the outgoing data stream. V\_BERT\_ERR is automatically cleared afterwards.

## 8.3 BERT receiver

The BERT receiver has an automatic synchonization capability. When the incoming bit stream is synchronized with the PRBG, bit V\_BERT\_SYNC in register R\_BERT\_STA is set to '1'.

A 16 bit BERT error counter is available in registers R\_BERT\_ECL and R\_BERT\_ECH. The low





Figure 8.1: BERT transmitter block diagram





Figure 8.2: BERT receiver block diagram



byte R\_BERT\_ECL should be read first to latch the high byte. Then the high byte can be read from register R\_BERT\_ECH. A read access to the low byte R\_BERT\_ECL clears the 16 bit counter.

The BERT procedure should first wait for the synchronization state. After this, the BERT error counter should be cleared by reading register  $R\_BERT\_ECL$ .

Received BERT data is passed through the HFC-channel assigner if  $V\_BERT\_EN = '1'$  in register A\_FIFO\_CTRL[FIFO]. For this reason, either a FIFO-to-ST/U<sub>p</sub> or a FIFO-to-PCM configuration must be selected. Furthermore, the allocated FIFO must be enabled to switch on the data path. Received BERT data is stored in the FIFO but it needs not to be read out. Received BERT data is collected from all FIFOs which have  $V\_BERT\_EN = '1'$  in the order of the FIFO processing sequence (see Section 3.2.3 on page 78).

Subchannel processing can be used together with the *Bit Error Rate Test*. Then V\_BIT\_CNT bits taken passed to the BERT receiver.

Inverted BERT data is automatically detected and can be checked with V\_BERT\_INV\_DATA in register R\_BERT\_STA.

The automatic synchronization works only if the bit error rate is less than  $4 \cdot 10^{-2}$ . Synchronization state will not be achieved with a higher error rate. It is lost when many bit errors occur during a short time period. In this case, the re-synchronization starts automatically and a high bit error counter value indicates that a re-synchronization might has happened.



## 8.4 Register description

## 8.4.1 Write only registers

| R_ | _BERT_W     | /D_MD          |                        | (w) | (Reset group: H, 0) <b>0x1</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 3 |
|----|-------------|----------------|------------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Bi | t error rat | te test (BH    | ERT) and watchdog mode | e   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |
|    | Bits        | Reset<br>value | Name                   |     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |
|    | 20          | 0              | V_PAT_SEQ              |     | Continuous '0' / '1' or pseudo random pattern<br>sequence for BERT<br>'000' = continuous '0' pattern<br>'001' = continuous '1' pattern<br>'010' = sequence length $2^9 - 1$ bits<br>'011' = sequence length $2^{10} - 1$ bits<br>'100' = sequence length $2^{15} - 1$ bits<br>'101' = sequence length $2^{20} - 1$ bits<br>'101' = sequence length $2^{20} - 1$ bits<br>'110' = sequence length $2^{20} - 1$ bits, but maximal<br>14 bits are zero<br>'111' = pseudo random pattern seq. $2^{23} - 1$<br>Note: These sequences are defined in ITU-T<br>O.150 and O.151 specifications. |   |
|    | 3           | 0              | V_BERT_ERR             |     | <b>BERT error</b><br>Generates one error bit in the BERT data stream<br>'0' = no error generation<br>'1' = generates one error bit<br>This bit is automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                                               |   |
|    | 4           | 0              | (reserved)             |     | Must be '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
|    | 5           | 0              | V_AUTO_WD_RES          |     | Automatic watchdog timer reset<br>'0' = watchdog is only reset by V_WD_RES<br>'1' = watchdog is reset after every access to the<br>chip                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
|    | 6           | 0              | V_WD_EN                |     | Watchdog timer enable<br>'0' = watchdog timer is disabled<br>'1' = watchdog timer is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
|    | 7           | 0              | V_WD_RES               |     | Watchdog timer reset<br>'0' = no action<br>'1' = manual watchdog timer reset<br>This bit is automatically cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |



## 8.4.2 Read only registers

| R_ | _BERT_S    | БТА            |                 | ( <b>r</b> ) | (Reset group: H, 0, 1) <b>0x17</b>                                                                                                                                                                                                                                                            |
|----|------------|----------------|-----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bi | t error ra | nte test sta   | tus             |              |                                                                                                                                                                                                                                                                                               |
|    | Bits       | Reset<br>value | Name            |              | Description                                                                                                                                                                                                                                                                                   |
|    | 20         | 0              | V_RD_SYNC_SRC   |              | Synchronization source selection<br>Reports whether the line interface or the SYNC_I<br>signal is used as synchronization source. The line<br>interface can be either in S/T or Up mode.<br>'000' = line interface<br>'001''011' = not used<br>'100' = SYNC_I signal<br>'101''111' = not used |
|    | 3          |                | (reserved)      |              |                                                                                                                                                                                                                                                                                               |
|    | 4          | 0              | V_BERT_SYNC     |              | <b>BERT synchronization status</b><br>'0' = BERT not synchronized to input data<br>'1' = BERT synchronized to input data                                                                                                                                                                      |
|    | 5          | 0              | V_BERT_INV_DATA |              | <b>BERT data inversion</b><br>'0' = BERT receives normal data<br>'1' = BERT receives inverted data                                                                                                                                                                                            |
|    | 76         |                | (reserved)      |              |                                                                                                                                                                                                                                                                                               |

| R | _BERT_E  | ECL            |            | ( <b>r</b> )     | (Reset group: H, 0, 1)                                                                                                                                               | 0x1A                        |
|---|----------|----------------|------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| B | ERT erro | r counter,     | , low byte |                  |                                                                                                                                                                      |                             |
|   | Bits     | Reset<br>value | Name       | I                | Description                                                                                                                                                          |                             |
|   | 70       | 0x00           | V_BERT_ECL | l<br>C<br>I<br>t | Bits 70 of the BERT error counter<br>This register should be read first to late<br>of register R_BERT_ECH.<br>Note: The BERT counter is cleared aft<br>his register. | ch the value<br>ter reading |



| R_BERT_ECH                    |      |                |            | ( <b>r</b> ) | (Reset group: H, 0, 1)                                                                                           | 0x1B  |
|-------------------------------|------|----------------|------------|--------------|------------------------------------------------------------------------------------------------------------------|-------|
| BERT error counter, high byte |      |                | high byte  |              |                                                                                                                  |       |
|                               | Bits | Reset<br>value | Name       |              | Description                                                                                                      |       |
|                               | 70   | 0x00           | V_BERT_ECH |              | <b>Bits 158 of the BERT error counter</b><br><b>Note:</b> Low byte should be read first (see reg<br>R_BERT_ECL). | ister |



**Chapter 9** 

# Clock, PLL, reset, interrupt, timer and watchdog

 Table 9.1: Overview of clock, PLL, reset, timer and watchdog registers

| Write only | registers:    |      | Read only | registers:     | Read/write registers: |         |         |      |
|------------|---------------|------|-----------|----------------|-----------------------|---------|---------|------|
| Address    | Name          | Page | Address   | Name           | Page                  | Address | Name    | Page |
| 0x00       | R_CIRM        | 297  | 0x10      | R_IRQ_OVIEW    | 304                   | 0x51    | R_PLL_P | 313  |
| 0x02       | R_CLK_CFG     | 299  | 0x11      | R_MISC_IRQ     | 306                   | 0x52    | R_PLL_N | 313  |
| 0x11       | R_MISC_IRQMSK | 300  | 0x12      | R_SU_IRQ       | 307                   | 0x53    | R_PLL_S | 313  |
| 0x12       | R_SU_IRQMSK   | 300  | 0x1C      | R_STATUS       | 308                   |         |         |      |
| 0x13       | R_IRQ_CTRL    | 301  | 0x20      | R_FIFO_BL0_IRQ | 309                   |         |         |      |
| 0x1A       | R_TI_WD       | 302  | 0x21      | R_FIFO_BL1_IRQ | 310                   |         |         |      |
| 0x50       | R_PLL_CTRL    | 303  | 0x22      | R_FIFO_BL2_IRQ | 311                   |         |         |      |
|            |               |      | 0x23      | R_FIFO_BL3_IRQ | 312                   |         |         |      |
|            |               |      | 0x50      | R_PLL_STA      | 312                   |         |         |      |



### 9.1 Clock

#### 9.1.1 Clock output

XHFC-1SU supplies a programmable clock output which can be used for source of clocking for any external device. Even a CPU or MCU supervising the whole system in which XHFC-1SU is used can be clocked. The left part of Figure 9.1 shows the block diagram of CLK\_OUT generation.

After reset, the clock output frequency

 $f(\mathsf{CLK\_OUT}) = \frac{1}{8}f(\mathsf{OSC\_OUT})$ 

is available at pin CLK\_OUT.

Two clock sources are available for  $f_{SRC}$ . V\_CLK\_F1 = '0' in register R\_CLK\_CFG selects the clock oscillator. Alternatively, pin F1\_1 is used as clock source when V\_CLK\_F1 = '1'.

The clock output frequency depends on the programming bits as follows:

$$f(\mathsf{CLK\_OUT}) = \begin{cases} f_{\mathsf{SRC}} & ; \quad \mathsf{V\_CLKO\_HI} = `1` \text{ and } \mathsf{V\_CLKO\_PLL} = `0` \\ \frac{1}{8}f_{\mathsf{SRC}} & ; \quad \mathsf{V\_CLKO\_HI} = `0` \text{ and } \mathsf{V\_CLKO\_PLL} = `0` \\ f_{\mathsf{out}} & ; \quad \mathsf{V\_CLKO\_PLL} = `1` \end{cases}$$

V\_CLKO\_OFF must be '0' to enable the tristate type driver of pin CLK\_OUT.

## Please note !

All setup bits shown in Figure 9.1 are implemented in a way that there are no glitches on the clocks when register bits change.

#### 9.1.2 Clock distribution

XHFC-1SU uses several internal clock frequencies. They are generated as shown in the right part of Figure 9.1.

The system clock  $f_{SYS}$  is derived either from the OSC\_OUT clock or from the internal PLL output clock. When the oscillator frequency is either 24.576 MHz or 49.152 MHz, V\_CLK\_PLL should be left in its reset state '0'. With any other oscillator frequency the internal PLL must be used to generate the required XHFC-1SU clock  $f_{SYS}$  and V\_CLK\_PLL must be set to '1' in register R\_CLK\_CFG.

Both the line interface clock  $f_{SU}$  and the PCM clock  $f_{PCM}$  must be set up to achieve 12.288 MHz and 49.152 MHz respectively. This is done with bit V\_SU\_CLK in register R\_CTRL and bitmap V\_PCM\_CLK in register R\_CLK\_CFG.

The internal clocks  $f_{SYS}$ ,  $f_{SU}$  and  $f_{PCM}$  can be switched off with V\_CLK\_OFF = '1' in register R\_CIRM. Any write access to the host processor interface or a high level at pin WAKEUP restarts the clock distribution.





Figure 9.1: CLK\_OUT generation and clock distribution



## Please note !

The timing specification of the processor interface is based on  $t_{SYS} = 1/f_{SYS}$ . This must be taken into account if a lower oscillator frequency is used.

Before the PLL is programmed and has reached its locked state, the host processor might wait beween XHFC-1SU accesses.

#### 9.1.3 Clock oscillator circuitry

There are different ways to provide the internal clocks of XHFC-1SU. This section describes the Pierce oscillator circuitry, gives a hint to 3rd overtone oscillator and the usage of crystal oscillator circuitries.

#### 9.1.3.1 Frequency accuracy

ISDN applications need an exact clock frequency. By the ISDN specification a precision of  $\pm 100$  ppm is minimum requirement for passing the ISDN type approval. In respect to temperature dependence and ageing behavior a crystal with  $\pm 50$  ppm is recommended.

#### 9.1.3.2 Pierce oscillator

A typical clock oscillator circuitry using a 24.576 MHz crystal is shown in Figure 9.2. This Pierce oscillator is very popular for clock generation and is widely known from literature.



Figure 9.2: Standard XHFC-1SU quartz circuitry

The feedback resistor R1 determines the DC operation point and is typically in the range  $100 k\Omega ... 10 M\Omega$  for CMOS inverters.

The capacitive load  $C_L$  of the crystal is given in its data sheet. C1 and C2 should be chosen to fulfill

$$C_{\rm L} = \frac{\rm C1 \cdot C2}{\rm C1 + C2} + C_{\rm S}$$

where  $C_S$  is the stray capacitance. It is given by the input and output capacitances of the inverter and the shunt capacitance between the crystal terminals. Typically, C1 and C2 are chosen to be equal.



Finally, the resistor R2 is chosen to be roughly equal to the capacitive reactance of C2 at the frequency of oscillation.

$$\mathrm{R2} \sim \frac{1}{2\pi f_{\mathrm{Q1}}\cdot\mathrm{C2}}$$

The minimum value of R2 depends on the recommended power consumption of the crystal. A too small value may damage the crystal or shorten the lifetime. When R2 is too large, the oscillation might not start. As XHFC-1SU has a bufffered inverter between pins OSC\_IN and OSC\_OUT the value of R2 can be increased. A factor of about 2..3, e.g., is well.

The circuitry shown in Figure 9.2 is based on a crystal with  $C_L = 12 \text{ pF}$  and a stray capacitance of  $C_S = 6 \text{ pF}$ . This leads to

$$C1 = C2 = 2 \cdot (C_L - C_S) = 12 \, pF$$

and

$${\sf R2} = (1..3) \cdot \frac{1}{2\pi f_{{\sf Q1}} \cdot {\sf C2}} = (1..3) \cdot 540\,\Omega \sim 680\,\Omega \ .$$

## Please note !

The here shown dimensioning of the oscillator circuitry is only an example and depends on the used crystal as well as on the particular board design. In general it is recommanded to check oscillation build-up, power consumption of the crystal and the so-called safety factor within the particular design.

The specified drive level should not be put to the extreme to avoid early crystal ageing. Typically, within a good dimensioned circuitry, a low load capacitance  $C_L$  is a condition for a low drive level.

#### 9.1.3.3 3rd overtone oscillator

A different oscillator frequency with double frequency 49.152 MHz can be used alternatively. For this a 3rd overtone crystal or a clock oscillator can be used.

#### 9.1.3.4 Crystal oscillator circuitry

It is possible to feed the OSC\_IN input of XHFC-1SU with a standard 3.3 V crystal oscillator. The input switching level is close to  $V_{DD}/2$  (CMOS level) and XHFC-1SU can accept at least a duty cycle of 45% high/55% low to 55% high/45% low.

#### 9.1.3.5 Several XHFC-1SU with a single oscillator circuitry

When several XHFC-1SU are used within an application, only one oscillator circuitry is required. Pin CLK\_OUT can be used to distribute the clock to all XHFC-1SU as shown in Figure 9.3.



| Register setup:                      |                                                 |
|--------------------------------------|-------------------------------------------------|
| $R\_CLK\_CFG \ : \ V\_CLK\_F1 \ = 0$ | oscillator input OSC_IN is used                 |
| : V_CLKO_HI = 1                      | high frequency, no divider                      |
| : V_CLKO_PLL = $0$                   | divider output clock or PLL input clock is used |
| : V_CLKO_OFF = $0$                   | clock output pin CLK_OUT is enabled             |



Figure 9.3: Clock distribution with only one quartz circuitry



## 9.2 Phase locked loop (PLL)

#### 9.2.1 Overview

Depending on the external clock source connected to pin OSC\_IN, the internal PLL shown in Figure 9.1 is either required for internal clock generation or it is available for other application needs.

- When a telecommunication quartz with either 24.576 MHz or 49.152 MHz is used, the PLL is not required for  $f_{SYS}$  generation. In this case, the PLL is not occupied from XHFC-1SU and it can be used for any other application needs.
- When any other clock frequency is feed in pin OSC\_IN, the PLL is required for  $f_{SYS}$  generation.  $f_{SU}$  and  $f_{PCM}$  are derived from  $f_{SYS}$  as shown in Figure 9.1.

The internal PLL is a fully digital implementation even though it is commonly seen to be an analog function. This is realized with the new DIGICC<sup>TM</sup> technology introduced by Cologne Chip<sup>1</sup>.

#### **Technical features:**

- Oscillator frequency range  $54 \text{ MHz} \le f_{\text{OSC}} \le 108 \text{ MHz}$
- Programmable loop multiplication  $5 \le N \le 255$
- Programmable predivider *P* and post-scaler *S* with range 1..256 each
- Deterministic clock-to-clock jitter typical 120 ps
- $f_{\text{out}}$  duty cycle  $40\% \dots 60\%$
- No external loop filter or capacity needed
- Very short lock time (worst case 2000 periods of  $f_{ref}$ )

#### 9.2.2 PLL structure

The PLL consists of a predivider, the PLL circuitry and a post-scaler. This structure is shown in Figure 9.4.

The PLL loop with input frequency  $f_{ref}$  and output frequency  $f_{PLL}$  has the ratio

$$\frac{f_{\rm PLL}}{f_{\rm ref}} = N$$

with  $N = V\_PLL\_N = 5..255$  (0..4 are not allowed).

The overall frequency ratio

$$\frac{f_{\rm out}}{f_{\rm in}} = \frac{N}{P \cdot S}$$

can be adjusted with the predivider and the post-scaler. Both dividers operate in the range 1..256.

<sup>&</sup>lt;sup>1</sup>Detailed information about the DIGICC<sup>TM</sup> technology and the here used PLL is documented in [1, 2]. It is *not necessary* to read these documents in order to understand this data sheet.





Figure 9.4: PLL block diagram

An additional divider with  $M = V\_PLL\_M + 1 = 1..4$  has effect only inside the PLL circuitry. As the PLL output frequency  $f_{PLL}$  is used for internal PLL clock signal, the power consumption can be reduced with lower

$$f_{\rm PLL} = \frac{f_{\rm osc}}{M}$$

frequency.

#### 9.2.3 PLL operation

The PLL is disabled after reset and the input frequency  $f_{in}$  is directly feed to the output, i.e.  $f_{out} = f_{in}$ . A '0' to '1' transition of bit V\_PLL\_NRES in register R\_PLL\_CTRL starts the PLL beginning with the lowest oscillator frequency. V\_PLL\_LOCK is '1' when the PLL is locked.

The PLL can be switched into standby mode without loss of current settings with V\_PLL\_FREEZE = '1' in register R\_PLL\_CTRL. Then  $f_{out} = 0$  until V\_PLL\_NRES returns to '0' again. Re-activation takes only few  $f_{ref}$  periods. V\_PLL\_LOCK returns '0' in standby mode.

#### 9.2.4 Supply noise requirements for PLL locking

It is very important to consider that power supply noise of XHFC-1SU has strong influence on the PLL locking. Therefore, if the PLL's output clock needs high accuracy, power supply noise of XHFC-1SU must be very low. Typically it is recommended, that supply noise does not exceeds 10mV peak-to-peak in this case.

If the PLL output frequency is used to clock devices with low frequency accuracy requirements, power noise does not matter because the long term frequency deviation is always less than 100 ppm. This means, PLL jitter might be poor, but the PLL output frequency is accurate, of course.

Please see electrical characteristics in chapter 11 for more details.



#### 9.2.5 PLL configuration

The PLL has four parameters P, M, N and S to be specified. Tables 9.2 and 9.3 show examples for PLL configuration settings. The parameter tuple (P,M,N,S) is given for often used frequencies. Approximate solutions have additional information about the  $f_{out}$  offset in parts per million and absolute value.

If other parameter sets are required, they can be calculated with the formulars given in section 9.2.2. Alternatively, the Cologne Chip support team will help you choosing suitable parameter sets for your application.

## Please note !

The ISDN specification provides a clock precision of at least  $\pm 100$  ppm. PLL output offset must be added to the crystal precision. This must be taken into account when a PLL configuration setup is chosen from the examples in Tables 9.2 and 9.3.



|                       | f <sub>out</sub> (MHz)    |                                |                            |                            |
|-----------------------|---------------------------|--------------------------------|----------------------------|----------------------------|
| f <sub>in</sub> (MHz) | 7.68                      | 12.288                         | 24.576                     | 49.152                     |
| 1.8432                | (1,2,25,6)                | (1,2,20,3)                     | (1,1,40,3)                 | (3,2,80,1)                 |
|                       | exact                     | exact                          | exact                      | exact                      |
| 3.579545              | (5, 1, 118, 11)           | (37,4,254,2)                   | (37,4,254,1)               | (15,2,206,1)               |
|                       | <b>-33 ppm</b> , -249 Hz  | <b>-119 ppm</b> , -1454 Hz     | <b>-119 ppm</b> , -2908 Hz | <b>+145 ppm</b> , +7085 Hz |
| 6                     | (5,2,32,5)                | (13,1,213,8)                   | (13, 1, 213, 4)            | (13,1,213,2)               |
|                       | exact                     | <b>+38 ppm</b> , +462 Hz       | <b>+38 ppm</b> , +924 Hz   | <b>+38 ppm</b> , +1847 Hz  |
| 7.68                  | (1,2,5,5)                 | (1,1,8,5)                      | (5,4,16,1)                 | (5,2,32,1)                 |
|                       | exact                     | exact                          | exact                      | exact                      |
| 10.7                  | (41,2,206,7)              | (31, 1, 178, 5)                | (16, 1, 147, 4)            | (16, 1, 147, 2)            |
|                       | <b>+19 ppm</b> , +140 Hz  | <b>-22 ppm</b> , -259 Hz       | <b>+23 ppm</b> , +563 Hz   | <b>+23 ppm</b> , +1125 Hz  |
| 12                    | (5,2,16,5)                | (25,1,128,5)                   | (26, 1, 213, 4)            | (26, 1, 213, 2)            |
|                       | exact                     | exact                          | <b>+38 ppm</b> , +924 Hz   | <b>+38 ppm</b> , +1847 Hz  |
| 12.288                | (1,1,5,8)                 | (1,1,5,5)                      | (1,1,6,3)                  | (1,1,8,2)                  |
|                       | exact                     | exact                          | exact                      | exact                      |
| 14.31818              | (53,2,199,7)              | (67,4,115,2)                   | (67, 4, 115, 1)            | (67,2,230,1)               |
|                       | + <b>14 ppm</b> , +102 Hz | <b>-1 ppm</b> , -10 Hz         | <b>-1 ppm</b> , -20 Hz     | <b>-1 ppm</b> , -39 Hz     |
| 16                    | (5,2,12,5)                | (25,1,96,5)                    | (125,4,192,1)              | (83,2,255,1)               |
|                       | exact                     | exact                          | exact                      | <b>+95 ppm</b> , +4627 Hz  |
| 24.576                | (2,1,5,8)                 | (2,1,5,5)                      | (2,1,6,3)                  | (2,1,8,2)                  |
|                       | exact                     | exact                          | exact                      | exact                      |
| 25                    | (125,2,192,5)             | (59,4,58,2)                    | (59,4,58,1)                | (59,2,116,1)               |
|                       | exact                     | <b>+12 ppm</b> , +136 Hz       | <b>+12 ppm</b> , +272 Hz   | + <b>12 ppm</b> , +543 Hz  |
| 32.768                | (8,1,15,8)                | (2,1,6,8)                      | (2,1,6,4)                  | (2,1,6,2)                  |
|                       | exact                     | exact                          | exact                      | exact                      |
| 33                    | (25,1,64,11)              | (61, 1, 159, 7)                | (111, 1, 248, 3)           | (143,2,213,1)              |
|                       | exact                     | <b>+5 ppm</b> , <b>+</b> 57 Hz | +24 ppm, +577 Hz           | <b>+38 ppm</b> , +1847 Hz  |
| 48                    | (5,1,8,10)                | (25,1,32,5)                    | (125,4,64,1)               | (125,2,128,1)              |
|                       | exact                     | exact                          | exact                      | exact                      |
| 49.152                | (4,1,5,8)                 | (3,1,6,8)                      | (3,1,6,4)                  | (3,1,6,2)                  |
|                       | exact                     | exact                          | exact                      | exact                      |
| 66                    | (25, 1, 32, 11)           | (122, 1, 159, 7)               | (205, 1, 229, 3)           | (143, 1, 213, 2)           |
|                       | exact                     | +5 ppm, +57 Hz                 | <b>-16 ppm</b> , -391 Hz   | +38 ppm, +1847 Hz          |

**Table 9.2:** *PLL* setup examples (P, M, N, S) with ISDN related frequencies for  $\mathbf{f}_{out}$ , (approximations have additional information about  $f_{out}$  offset)


| f <sub>out</sub> (MHz) | f <sub>in</sub> (MHz)<br>7.68 | 12.288                    | 24.576                     | 49.152                    |
|------------------------|-------------------------------|---------------------------|----------------------------|---------------------------|
| 1.8432                 | (1,2,6,25)                    | (1,1,6,40)                | (2,1,6,40)                 | (4,1,6,40)                |
|                        | exact                         | exact                     | exact                      | exact                     |
| 3.579545               | (59,4,110,4)                  | (10, 1, 67, 23)           | (20, 1, 67, 23)            | (40, 1, 67, 23)           |
|                        | + <b>33 ppm</b> , +117 Hz     | +1 ppm, +3 Hz             | +1 ppm, +3 Hz              | <b>+1 ppm</b> , +3 Hz     |
| 6                      | (2,1,25,16)                   | (16,1,125,16)             | (32, 1, 125, 16)           | (64, 1, 125, 16)          |
|                        | exact                         | exact                     | exact                      | exact                     |
| 7.68                   | (1,2,5,5)                     | (1,1,5,8)                 | (2,1,5,8)                  | (4,1,5,8)                 |
|                        | exact                         | exact                     | exact                      | exact                     |
| 10.7                   | (89,4,248,2)                  | (89,4,155,2)              | (89, 2, 155, 4)            | (89, 1, 155, 8)           |
|                        | +22 ppm, +225 Hz              | <b>+22 ppm</b> , +225 Hz  | <b>+22 ppm</b> , +225 Hz   | +22 ppm, +225 Hz          |
| 12                     | (2,1,25,8)                    | (16,1,125,8)              | (32, 1, 125, 8)            | (64, 1, 125, 8)           |
|                        | exact                         | exact                     | exact                      | exact                     |
| 12.288                 | (1,1,8,5)                     | (1,1,5,5)                 | (2,1,5,5)                  | (3,1,6,8)                 |
|                        | exact                         | exact                     | exact                      | exact                     |
| 14.31818               | (59,4,110,1)                  | (23, 1, 134, 5)           | (23, 1, 67, 5)             | (46, 1, 67, 5)            |
|                        | <b>+33 ppm</b> , +465 Hz      | +1 ppm, +12 Hz            | +1 ppm, +12 Hz             | +1 ppm, +12 Hz            |
| 16                     | (2,1,25,6)                    | (16,1,125,6)              | (32,1,125,6)               | (64, 1, 125, 6)           |
|                        | exact                         | exact                     | exact                      | exact                     |
| 24.576                 | (5,4,16,1)                    | (1,1,6,3)                 | (2,1,6,3)                  | (3,1,6,4)                 |
|                        | exact                         | exact                     | exact                      | exact                     |
| 25                     | (47,4,153,1)                  | (29,4,59,1)               | (29,2,59,2)                | (29, 1, 59, 4)            |
|                        | <b>+35 ppm</b> , +852 Hz      | <b>-12 ppm</b> , -276 Hz  | <b>-12 ppm</b> , -276 Hz   | <b>-12 ppm</b> , -276 Hz  |
| 32.768                 | (5,1,64,3)                    | (1,1,8,3)                 | (2,1,8,3)                  | (3,1,6,3)                 |
|                        | exact                         | exact                     | exact                      | exact                     |
| 33                     | (37, 3, 159, 1)               | (89,3,239,1)              | (89, 1, 239, 2)            | (71, 1, 143, 3)           |
|                        | <b>+99 ppm</b> , +3244 Hz     | <b>-58 ppm</b> , -1888 Hz | <b>-58 ppm</b> , -1888 Hz  | <b>-38 ppm</b> , -1240 Hz |
| 48                     | (2,1,25,2)                    | (16,1,125,2)              | (32, 1, 125, 2)            | (64, 1, 125, 2)           |
|                        | exact                         | exact                     | exact                      | exact                     |
| 49.152                 | (5,2,32,1)                    | (1,1,8,2)                 | (2,1,8,2)                  | (3,1,6,2)                 |
|                        | exact                         | exact                     | exact                      | exact                     |
| 66                     | (27, 1, 232, 1)               | (35, 1, 188, 1)           | (89, 1, 239, 1)            | (178, 1, 239, 1)          |
|                        | -135 ppm, -8889 Hz            | +63 ppm, +4115 Hz         | - <b>58 ppm</b> , -3776 Hz | <b>-58 ppm</b> , -3776 Hz |

**Table 9.3:** *PLL* setup examples (P, M, N, S) with ISDN related frequencies for  $\mathbf{f}_{in}$ , (approximations have additional information about  $f_{out}$  offset)



## 9.3 Reset

XHFC-1SU has a level sensitive reset input at pin 15 with active low level. The pins MODE0 and MODE1 must already be stable during reset. The reset pulse must not be shorter than 10 ns.

After reset XHFC-1SU enters an initialization sequence. Its duration depends on the number of FIFOs and has a maximum length of  $40 \,\mu s$  with  $f_{SYS} = 24.576 \,\text{MHz}$ . When the initialization process is finished, bit V\_BUSY in register R\_STATUS changes from '1' to '0'.

PCM initialization takes 149 µs with  $f_{PCM} = 49.152 \text{ MHz}$ . V\_PCM\_INIT in register R\_STATUS has the value '1' during PCM reset phase. It changes to '0' when the PCM initialization has finished.

XHFC-1SU has 4 different software resets which means that the registers are assigned to so-called reset groups.

The FIFO registers, PCM registers and  $ST/U_p$  registers belong to reset groups 1..3 and can be reset independently with the bits of register R\_CIRM which are listed in Table 9.4.

A global software reset puts all registers of reset group 0 back to their default value and implies reset groups 1..3 as well. It is very similar to the hardware reset, except a few registers which have only hardware reset (see register list from page 21).

The reset bits must be set and cleared by software.

A hardware reset implies all reset groups 0..3, of course.

| Reset name              | Reset group | Register bit | Description                                                                                                                                                                                                |
|-------------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Hardware reset          | Н           | _            | Hardware reset initiated by /RES input pin. The hardware reset implies reset of all registers of reset groups $03$ as well.                                                                                |
| Global Software reset   | 0           | V_SRES       | The global software reset, which is similar to the hardware reset, restores the default values to the most registers. The global software reset implies reset of all registers of reset groups 13 as well. |
| HFC reset               | 1           | V_HFC_RES    | Reset for all FIFO registers of XHFC-1SU.                                                                                                                                                                  |
| PCM reset               | 2           | V_PCM_RES    | Reset for all PCM registers of XHFC-1SU.                                                                                                                                                                   |
| ST/U <sub>p</sub> reset | 3           | V_SU_RES     | Reset for all $ST/U_p$ registers of XHFC-1SU.                                                                                                                                                              |

| Table 9.4. Anro-150 lesel gloups | Table | 9.4: | XHFC-1SU reset groups |
|----------------------------------|-------|------|-----------------------|
|----------------------------------|-------|------|-----------------------|

Information about the allocation of the registers to the different reset groups can be found in the register list on pages 22 and 24. Some registers are allocated to more than one reset group, some have only hardware reset, and some have no default value at all.



## 9.4 Interrupt

## 9.4.1 Common features

XHFC-1SU is equipped with a maskable interrupt engine. A big variety of interrupt sources can be enabled and disabled. All interrupt events are reported on reading the interrupt status registers independently of masking the interrupts or not. Reading an interrupt status register resets the bits. Interrupt bits which are set during the read access are reported at the next read access of the interrupt status register.

Mask bits are used to enable or disable signal generation on the interrupt pin /INT. Every interrupt bit can be masked individually.

Pin 14 is the interrupt output line. After reset, all interrupts are disabled. The interrupt line must be enabled with V\_GLOB\_IRQ\_EN set to '1' in register R\_IRQ\_CTRL. The polarity of the interrupt signal can be changed from *active low* to *active high* with bitmap V\_IRQ\_POL in the same register. Please note, that the interrupt line cannot be shared with active high polarity.



Figure 9.5: Interrupt output

## 9.4.2 ST/U<sub>p</sub> interface interrupt

The line interface can have its own interrupt capability to indicate a state change condition. The interrupt mask has to be programmed in register R\_SU\_IRQMSK.

When an ST/ $U_p$  interface interrupt occured, the register R\_SU\_IRQ contains the state change condition even if the interrupt is disabled.

## 9.4.3 FIFO interrupt

FIFO interrupts can be enabled to indicate the status for every FIFO individually.

The interrupt status of all 32 FIFOs can be read from registers R\_FIFO\_BL0\_IRQ





**Figure 9.6:** *ST*/*U*<sub>*p*</sub> *interface interrupt* 

..R\_FIFO\_BL3\_IRQ. All FIFOs are organized in four blocks with 8 FIFOs each. Every block has an overview bit V\_FIFO\_BL0\_IRQ..V\_FIFO\_BL3\_IRQ in register R\_IRQ\_OVIEW.

FIFO interrupt status bits in registers  $R_FIFO_BL0_IRQ...R_FIFO_BL3_IRQ$  are only set, when  $V_FIFO_IRQ_EN = '1'$  in register  $R_IRQ_CTRL$  as shown in Figure 9.7.



**Figure 9.7:** *Enable FIFO interrupt condition with* V\_*FIFO\_IRQ\_EN* 

- **FIFO in transparent mode** (V\_HDLC\_TRP = '1'): An interrupt occurs due to the setting of V\_FIFO\_IRQ in register A\_CON\_HDLC.
- **HDLC mode without mixed interrupt mode** (V\_HDLC\_TRP = '0' and V\_MIX\_IRQ = '0'): An interrupt occurs at *end of frame* condition (which leads to a frame counter increment) or after a FIFO underrun condition.
- HDLC mode and mixed interrupt mode (V\_HDLC\_TRP = '0' and V\_MIX\_IRQ = '1'):

An interrupt occurs both at *end of frame* condition (which leads to a frame counter increment) or after a FIFO underrun condition and due to the setting of  $V_FIFO_IRQ$  in register A\_CON\_HDLC.





Figure 9.8: FIFO interrupt

## 9.4.4 Miscelleanous interrupts

Seven miscelleanous interrupts are available to report important XHFC-1SU status. Figure 9.9 shows the block diagram of these interrupt capabilities.

An overview bit V\_MISC\_IRQ can be read from register R\_IRQ\_OVIEW.

## 9.4.4.1 Line interface frequency slip interrupt

The frame synchronization signal FSC can either be the F0IO or the AF0 signal. The actual selection can be read from bit V\_SU\_AF0 in register R\_SU\_STA. Any change of the selection causes an interrupt event when V\_SLIP\_IRQMSK in register R\_MISC\_IRQMSK is set to '1'.

The interrupt condition is shown in V\_SLIP\_IRQ of register R\_MISC\_IRQ even if the mask bit is not set.

Data might be corrupted when a frequency slip occurs. For this reason it is recommended to store the  $V_SU_AF0$  value by the application software to detect any frequency slips.

## 9.4.4.2 Timer interrupt

XHFC-1SU includes a timer with interrupt capability. The timer counts F0IO pulses, i.e. it is incremented every  $125 \,\mu s$ .





Figure 9.9: Miscelleanous interrupts

A timer event is indicated with  $V_TI_IRQ = '1'$  in register R\_MISC\_IRQ. This event generates an interrupt if the mask bit  $V_TI_IRQMSK$  is set to '1' in register R\_MISC\_IRQMSK.

A timer event is generated every  $2^{V\_EV\_TS} \cdot 250 \mu s$  where  $V\_EV\_TS = 0..15$  in register R\_TI\_WD. 16 timer event frequencies are available in the range 250 µs . . 8.192 s.

#### 9.4.4.3 Processing / non-processing interrupt

XHFC-1SU changes every 125 µs from non-processing into processing state. When it returns to non-processing state, this event can be reported with an interrupt.

Bit V\_PROC\_IRQMSK in register R\_MISC\_IRQMSK must be set to '1' to enable this interrupt capability. In case of an interrupt, bit V\_PROC\_IRQ in register R\_MISC\_IRQ has the value '1'.

This interrupt occurs once in every 125 µs cycle but the distance between two consecutive interrupts changes due to the load of the internal processing machine.

## 9.4.4.4 Command/indication interrupt (GCI interface)

This interrupt occurs when the received indication bits of the C/I-channel have changed.

#### 9.4.4.5 Wakeup interrupt

The wakeup pin can be enabled with V\_WAK\_EN = '1' in register R\_PWM\_MD as shown in Figure 9.10. A high level is stored in V\_WAK\_IRQ of register R\_MISC\_IRQ. This bit generates an interrupt if the mask bit V\_WAK\_IRQMSK = '1' in register R\_MISC\_IRQMSK.

The wakeup pin can also be used as common external interrupt input, or as general purpose input

Cologne Chip

configurable with or without interrupt capability.



Figure 9.10: Wakeup interrupt

#### 9.4.4.6 Interrupt for GCI monitor byte transmission

The interrupt bit V\_MON\_TX\_IRQ in register R\_MISC\_IRQ is set to '1' when the next monitor byte can be written into register R\_MON\_TX.

The interrupt status is reported in V\_MON\_TX\_IRQ of register R\_MISC\_IRQ even when the mask bit V\_MON\_TX\_IRQMSK in register R\_MISC\_IRQMSK is not set.

## 9.4.4.7 Interrupt after GCI monitor byte received

After a monitor byte has been received and stored in register R\_MON\_RX, an interrupt can be generated.

The interrupt status is reported in V\_MON\_RX\_IRQ of register R\_MISC\_IRQ even when the mask bit V\_MON\_RX\_IRQMSK in register R\_MISC\_IRQMSK is not set.



## 9.5 Watchdog reset

The parallel processor interface of XHFC-1SU includes a watchdog functionality.

A watchdog event generates a low signal at pin /WD. The watchdog timer can either be reset manually or automatically.

- Manual watchdog reset is selected with V\_AUTO\_WD\_RES = '0' in register R\_BERT\_WD\_MD. Then, writing V\_WD\_RES = '1' in register R\_BERT\_WD\_MD resets the watchdog timer. This bit is automatically cleared afterwards.
- V\_AUTO\_WD\_RES = '1' must be set to switch on the automatically watchdog reset. In this case every access to the chip clears the watchdog timer.

The watchdog counter is incremented every 2 ms. An event occurs after  $2^{V_WD_TS} \cdot 2 \text{ ms}$  where  $V_WD_TS = 0..15$  in register  $R_TI_WD$ . This leads to a watchdog event frequency from 2 ms to 65 536 s.



## 9.6 Register description

## 9.6.1 Write only registers

| R_       | CIRM                         |                |                          | (w)                                                                     | (Reset group: H)                                                                                                                                                                                                                                                                                                                    | 0x00                                                                             |  |  |
|----------|------------------------------|----------------|--------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--|--|
| In       | Interrupt and reset register |                |                          |                                                                         |                                                                                                                                                                                                                                                                                                                                     |                                                                                  |  |  |
| Al<br>is | l reset bits<br>pending.     | s in this re   | gister must be cleared b | oy software. I                                                          | t is not allowed to write any registe                                                                                                                                                                                                                                                                                               | er while reset                                                                   |  |  |
|          | Bits                         | Reset<br>value | Name                     | Des                                                                     | scription                                                                                                                                                                                                                                                                                                                           |                                                                                  |  |  |
|          | 0                            | 0              | V_CLK_OFF                | Gle<br>'0' =<br>ena<br>'1' =<br>Thi<br>or v                             | <b>bal clock enable / disable</b><br>= all internal clocks ( $f_{SYS}$ , $f_{SU}$ and<br>bled<br>= all internal clocks are disabled<br>s bit is reset at every write access to<br>with a wake-up signal on pin WAKE                                                                                                                 | <i>f<sub>PCM</sub></i> ) are<br>о XHFC-1SU<br>EUP.                               |  |  |
|          | 1                            | 0              | V_WAIT_PROC              | Add<br>The<br>regi<br>not<br>'0' =<br>'1' =<br>Thi<br>with              | ditional /WAIT signal after write a<br>e wait signal gets low with every ac<br>ister when a preceding write access<br>yet completed.<br>= normal /WAIT signal<br>= additional /WAIT signal<br>s bit should be set if timing problem<br>h fast processors.                                                                           | access<br>cess to a<br>is internally<br>ms occur                                 |  |  |
|          | 2                            | 0              | V_WAIT_REG               | Ada<br>pha<br>The<br>reg<br>FIF<br>inte<br>'0' =<br>'1' =<br>Thi<br>not | ditional /WAIT signal during inter<br>se<br>e wait signal gets low with every ac<br>ister if a preceding change FIFO, in<br>O or reset FIFO operation has active<br>rnal busy phase.<br>= normal /WAIT signal<br>= additional /WAIT signal during bu<br>s bit can be set when busy polling of<br>busy) is not used by the software. | <b>nal busy</b><br>cess to a<br>norement<br>vated an<br>asy phase<br>(wait until |  |  |
|          | 3                            | 0              | V_SRES                   | Glo<br>Thi<br>thei<br>reg<br>add<br>acti<br>'0' =<br>'1' =              | <b>abal software reset (reset group 0</b><br>s reset sets alls registers of reset gr<br>r default value. It includes also the<br>isters of reset groups 13. The sel<br>ress (CIP) remains unchanged. The<br>ve until the bit is cleared.<br>= deactivate reset<br>= activate reset                                                  | )<br>oup 0 to<br>reset of all<br>ected I/O<br>e reset is                         |  |  |

(continued on next page)



(continued from previous page)

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                  |
|------|----------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | 0              | V_HFC_RES  | <ul> <li>HFC reset (reset group 1)</li> <li>Sets all FIFO and HDLC registers to their initial values. The reset is active until the bit is cleared.</li> <li>'0' = deactivate reset</li> <li>'1' = activate reset</li> </ul> |
|      |                |            |                                                                                                                                                                                                                              |
| 5    | 0              | V_PCM_RES  | <ul> <li>PCM reset (reset group 2)</li> <li>Sets all PCM registers to their initial values. The reset is active until the bit is cleared.</li> <li>'0' = deactivate reset</li> <li>'1' = activate reset</li> </ul>           |
| ~    | _              |            |                                                                                                                                                                                                                              |
| 6    | 0              | V_SU_RES   | Line interface reset (reset group 3)<br>Sets all line interface registers to their initial<br>values. The reset is active until the bit is cleared.<br>'0' = deactivate reset<br>'1' = activate reset                        |
| 7    | 0              |            |                                                                                                                                                                                                                              |
| /    | 0              | (reserved) | Must be '0'.                                                                                                                                                                                                                 |



| R_ | _CLK_CF    | G              |            | (w) (Reset group: H) <b>0x02</b>                                                                                                                                                                                                                                                                                                                           |
|----|------------|----------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cl | ock config | guration r     | register   |                                                                                                                                                                                                                                                                                                                                                            |
|    | Bits       | Reset<br>value | Name       | Description                                                                                                                                                                                                                                                                                                                                                |
|    | 0          | 0              | V_CLK_PLL  | Clock source selection<br>'0' = CLK_OUT clock is derived from oscillator<br>input OSC_IN<br>'1' = CLK_OUT clock is derived from PLL output                                                                                                                                                                                                                 |
|    | 1          | 0              | V_CLKO_HI  | High/low frequency selection for clock output<br>When CLK_OUT clock is derived from oscillator<br>input OSC_IN or F1_1 alternatively, the signal can<br>either directly be passed to the CLK_OUT pin<br>(high frequency) or the frequency can be divided<br>by 8 (low frequency).<br>'0' = low frequency, divider by 8<br>'1' = high frequency, no divider |
|    | 2          | 0              | V_CLKO_PLL | Source selection for clock output<br>'0' = either OSC_IN or F1_1 signal is passed to<br>CLK_OUT<br>'1' = PLL output clock is passed to CLK_OUT                                                                                                                                                                                                             |
|    | 43         | 0              | (reserved) | Must be '00'.                                                                                                                                                                                                                                                                                                                                              |
|    | 5          | 0              | V_PCM_CLK  | Clock of the PCM module<br>'0' = $f_{PCM} = 2 \cdot f_{SYS}$<br>'1' = $f_{PCM} = f_{SYS}$<br>PCM clock must be set up to 49.152 MHz.                                                                                                                                                                                                                       |
|    | 6          | 0              | V_CLKO_OFF | Clock output enable / disable<br>'0' = clock output pin CLK_OUT is enabled<br>'1' = clock output pin CLK_OUT is disabled<br>(tristate)                                                                                                                                                                                                                     |
|    | 7          | 0              | V_CLK_F1   | <b>Pin selection for PLL input frequency</b><br>The selected pin is used for PLL input frequency<br>as well as for CLK_OUT signal.<br>'0' = oscillator input OSC_IN is used<br>'1' = F1_1 input pin is used                                                                                                                                                |



| R_               | _MISC_IR                                                                                                                                                                                                                                            | QMSK           | ( w             | ) (Reset group: H) <b>0x11</b>                                             |  |  |  |  |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------|--|--|--|--|
| Mi               | Miscellaneous interrupt mask register                                                                                                                                                                                                               |                |                 |                                                                            |  |  |  |  |
| An<br>'0'<br>cai | Any miscellaneous interrupt can be enabled with bit value '1' individually.<br>'0' means that the interrupt is not used for generating a signal on the interrupt pin 14. The interrupt status<br>can be read from register R_MISC_IRQ nevertheless. |                |                 |                                                                            |  |  |  |  |
|                  | Bits                                                                                                                                                                                                                                                | Reset<br>value | Name            | Description                                                                |  |  |  |  |
|                  | 0                                                                                                                                                                                                                                                   | 0              | V_SLIP_IRQMSK   | Interrupt mask of the line interface frequency slip                        |  |  |  |  |
|                  | 1                                                                                                                                                                                                                                                   | 0              | V_TI_IRQMSK     | Timer interrupt mask                                                       |  |  |  |  |
|                  | 2                                                                                                                                                                                                                                                   | 0              | V_PROC_IRQMSK   | Processing / non-processing transition interrupt<br>mask<br>(every 125 µs) |  |  |  |  |
|                  | 3                                                                                                                                                                                                                                                   | 0              | (reserved)      | Must be '0'.                                                               |  |  |  |  |
|                  | 4                                                                                                                                                                                                                                                   | 0              | V_CI_IRQMSK     | Command / indication interrupt mask                                        |  |  |  |  |
|                  | 5                                                                                                                                                                                                                                                   | 0              | V_WAK_IRQMSK    | Wakeup interrupt mask                                                      |  |  |  |  |
|                  | 6                                                                                                                                                                                                                                                   | 0              | V_MON_TX_IRQMSK | Transmit monitor byte interrupt mask                                       |  |  |  |  |
|                  | 7                                                                                                                                                                                                                                                   | 0              | V_MON_RX_IRQMSK | Receive monitor byte interrupt mask                                        |  |  |  |  |

| R_                                                                                                                                                                                                                                                     | _SU_IRQI    | MSK            | (                        | (w)                         | (Reset group: H, 0, 3)                                                                        | 0x12     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|--------------------------|-----------------------------|-----------------------------------------------------------------------------------------------|----------|
| <b>State change interrupt mask register of the line interface</b><br>The line interface interrupt can be enabled with bit value '1'.<br>'0' means that the interrupt is not used for generating a signal on the interrupt pin 14. The interrupt status |             |                |                          |                             |                                                                                               |          |
| ca                                                                                                                                                                                                                                                     | n be read f | from regis     | ter R_SU_IRQ nevertheles | ss.                         |                                                                                               |          |
|                                                                                                                                                                                                                                                        | Bits        | Reset<br>value | Name                     | Des                         | cription                                                                                      |          |
|                                                                                                                                                                                                                                                        |             |                |                          |                             |                                                                                               |          |
|                                                                                                                                                                                                                                                        | 0           | 0              | V_SU_IRQMSK              | <b>Int</b><br>'1' =<br>inte | errupt mask of the line interface<br>• V_SU_IRQ in register R_SU_IRQ is r<br>rrupt generation | used for |
|                                                                                                                                                                                                                                                        |             |                |                          |                             |                                                                                               |          |
|                                                                                                                                                                                                                                                        | 71          | 0              | (reserved)               | Mu                          | st be '0000000'.                                                                              |          |



| R_ | IRQ_CTI    | RL             | (             | w)                                                  | (Reset group: H, 0)                                                                                                                                                                                                                                                                         | )x13 |
|----|------------|----------------|---------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| In | terrupt co | ontrol reg     | ister         |                                                     |                                                                                                                                                                                                                                                                                             |      |
|    | Bits       | Reset<br>value | Name          | Ι                                                   | Description                                                                                                                                                                                                                                                                                 |      |
|    | 0          | 0              | V_FIFO_IRQ_EN | H<br>Y<br>C<br>C<br>C<br>I<br>I<br>I<br>I<br>V<br>A | FIFO interrupt<br>D' = all FIFO interrupts disabled<br>A' = all FIFO interrupts enabled<br>Note: This bit enables or disables the interrupt<br>apability of all FIFOs together. Each FIFO<br>Interrupt can be masked individually with<br>/_FIFO_IRQMSK setting in register<br>A_FIFO_CTRL. |      |
|    | 21         | 0              | (reserved)    | Ν                                                   | Aust be '00'.                                                                                                                                                                                                                                                                               |      |
|    | 3          | 0              | V_GLOB_IRQ_EN | (<br>]<br>;(                                        | Global interrupt signal enable<br>The interrupt line is pin 14.<br>D' = disable<br>1' = enable                                                                                                                                                                                              |      |
|    | 4          | 0              | V_IRQ_POL     | F<br>'(<br>'.                                       | <b>Polarity of interrupt signal</b><br>D' = active low signal<br>1' = active high signal                                                                                                                                                                                                    |      |
|    | 75         | 0              | (reserved)    | Ν                                                   | Aust be '000'.                                                                                                                                                                                                                                                                              |      |



| R  | _TI_WD    |                |                  | (w) (Reset group: H, 0)                                                                                                                                                                                                                                                                                 | 0x1A |
|----|-----------|----------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Ti | mer and v | watchdog       | control register |                                                                                                                                                                                                                                                                                                         |      |
|    | Bits      | Reset<br>value | Name             | Description                                                                                                                                                                                                                                                                                             |      |
|    | 30        | 0              | V_EV_TS          | <b>Timer event after</b> $2^n \cdot 250 \mu s$<br>$0 = 250 \mu s$<br>$1 = 500 \mu s$<br>2 = 1 m s<br>3 = 2 m s<br>4 = 4 m s<br>5 = 8 m s<br>6 = 16 m s<br>7 = 32 m s<br>8 = 64 m s<br>9 = 128 m s<br>0xA = 256 m s<br>0xB = 512 m s<br>0xC = 1.024 s<br>0xC = 2.048 s<br>0xE = 4.096 s<br>0xF = 8.192 s |      |
|    | 74        | 0              | V_WD_TS          | Watchdog event after $2^n \cdot 2 \text{ ms}$<br>0 = 2  ms<br>1 = 4  ms<br>2 = 8  ms<br>3 = 16  ms<br>4 = 32  ms<br>5 = 64  ms<br>6 = 128  ms<br>7 = 256  ms<br>8 = 512  ms<br>9 = 1.024  s<br>0xA = 2.048  s<br>0xB = 4.096  s<br>0xC = 8.192  s<br>0xD = 16.384  s<br>0xF = 65.536  s                 |      |



| R_ | _PLL_CTI | RL             |              | (w)                                                      | (Reset group: H)                                                                                                                                  | 0x50                                      |
|----|----------|----------------|--------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| PI | L contro | l register     |              |                                                          |                                                                                                                                                   |                                           |
|    | Bits     | Reset<br>value | Name         | Descri                                                   | iption                                                                                                                                            |                                           |
|    | 0        | 0              | V_PLL_NRES   | <b>PLL r</b><br>'0' = Pl<br>to PLL<br>'1' = Pl<br>PLL be | eset (active low)<br>LL reset, PLL disabled, input clo<br>c output<br>LL enabled, a '0' to '1' transition a<br>eginning with the lowest oscillato | ock is feed<br>starts the<br>or frequency |
|    | 1        | 0              | V_PLL_TST    | <b>PLL to</b><br>'0' = te<br>'1' = te                    | <b>est input</b><br>est state disabled, normal operations<br>est state enabled                                                                    | on                                        |
|    | 42       | 0              | (reserved)   | Must b                                                   | be '000'.                                                                                                                                         |                                           |
|    | 5        | 0              | V_PLL_FREEZE | <b>PLL</b> si<br>'0' = no<br>'1' = P!                    | <b>tandby mode</b><br>ormal PLL operation<br>LL is in standby mode, no output                                                                     | t clock                                   |
|    | 76       | 0              | V_PLL_M      | Oscilla<br>The os<br>V_PLL                               | ator divider programming valu<br>scillator output signal is divided b<br>M+1.                                                                     | e<br>by                                   |

Cologne Chip

## 9.6.2 Read only registers

| R         | _IRQ_OV                                                                                                                                                                                  | IEW            | ( r                            | ) (Reset group: H, 0, 1)                                                                                                                                                                                                                                      | 0x10                     |  |  |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|
| F         | FIFO interrupt overview register                                                                                                                                                         |                |                                |                                                                                                                                                                                                                                                               |                          |  |  |  |  |
| Tl        | This register gives an overview of all XHFC-1SU interrupt conditions.                                                                                                                    |                |                                |                                                                                                                                                                                                                                                               |                          |  |  |  |  |
| Ev<br>a : | Every bit value '1' indicates that an interrupt has occured. Interrupt conditions are only used for generating a signal on the interrupt pin 14 if the belonging mask bit is set to '1'. |                |                                |                                                                                                                                                                                                                                                               |                          |  |  |  |  |
| R         | eading this                                                                                                                                                                              | overview       | register does not clear any in | terrupt status bit.                                                                                                                                                                                                                                           |                          |  |  |  |  |
|           | Bits                                                                                                                                                                                     | Reset<br>value | Name                           | Description                                                                                                                                                                                                                                                   |                          |  |  |  |  |
|           | 0                                                                                                                                                                                        | 0              | V_FIFO_BL0_IRQ                 | Interrupt overview of FIFO block 0<br>FIFO block 0 consists of transmit FIFOs<br>receive FIFOs 03. The exact FIFO can<br>determined by reading register<br>R_FIFO_BL0_IRQ.<br>'0' = No FIFO interrupt occured<br>'1' = At least one FIFO interrupt is pending | 03 and<br>be             |  |  |  |  |
|           | 1                                                                                                                                                                                        | 0              | V_FIFO_BL1_IRQ                 | Interrupt overview of FIFO block 1<br>FIFO block 1 consists of transmit FIFOs<br>receive FIFOs 47. The exact FIFO can<br>determined by reading register<br>R_FIFO_BL1_IRQ.<br>'0' = No FIFO interrupt occured<br>'1' = At least one FIFO interrupt is pendin  | 47 and<br>be             |  |  |  |  |
|           | 2                                                                                                                                                                                        | 0              | V_FIFO_BL2_IRQ                 | Interrupt overview of FIFO block 2<br>FIFO block 2 consists of transmit FIFOs<br>and receive FIFOs 811. The exact FIFO<br>determined by reading register<br>R_FIFO_BL2_IRQ.<br>'0' = No FIFO interrupt occured<br>'1' = At least one FIFO interrupt is pendin | 811<br>O can be<br>ng.   |  |  |  |  |
|           | 3                                                                                                                                                                                        | 0              | V_FIFO_BL3_IRQ                 | Interrupt overview of FIFO block 3<br>FIFO block 3 consists of transmit FIFOs<br>and receive FIFOs 1215. The exact FII<br>determined by reading register<br>R_FIFO_BL3_IRQ.<br>'0' = No FIFO interrupt occured<br>'1' = At least one FIFO interrupt is pendin | 1215<br>FO can be<br>ng. |  |  |  |  |

(continued on next page)



Т

(continued from previous page)

| Bits | Reset<br>value | Name       | Description                                                                                                                                                                                                                                                                                                                                                                |
|------|----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4    | 0              | V_MISC_IRQ | Miscellaneous interrupt overview<br>All miscellaneous interrupts of register<br>R_MISC_IRQ are 'ored'.<br>'0' = No miscellaneous interrupt occured<br>'1' = At least one miscellaneous interrupt is<br>pending.<br>This bit has always the same value as<br>V_MISC_IRQSTA in register R_STATUS. Reading<br>register R_MISC_IRQ clears the miscellaneous<br>interrupt bits. |
| 5    | 0              | V_STUP_IRQ | Line interface interrupt status<br>'0' = No line interface interrupt occured<br>'1' = The line interface interrupt is pending.<br>Reading register R_SU_IRQ clears the line<br>interface interrupt bit.                                                                                                                                                                    |
| 76   |                | (reserved) |                                                                                                                                                                                                                                                                                                                                                                            |



| R_       | _MISC_IR                   | Q                       |                                                         | ( <b>r</b> )      | (Reset group: H, 0, 1)                                                                                                                                                                                                                                               | 0x11                          |
|----------|----------------------------|-------------------------|---------------------------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| Mi       | iscellaneo                 | us interru              | pt status register                                      |                   |                                                                                                                                                                                                                                                                      |                               |
| Th<br>ma | is register<br>isked by re | reports m<br>egister R_ | iscellaneous interrupt even<br>MISC_IRQMSK, i.e. they s | its. Re<br>show i | ading this register clears the bits. These bits a nterrupt conditions even if the interrupt is dis                                                                                                                                                                   | are not<br>abled.             |
|          | Bits                       | Reset<br>value          | Name                                                    |                   | Description                                                                                                                                                                                                                                                          |                               |
|          | 0                          | 0                       | V_SLIP_IRQ                                              |                   | Interrupt status of the line interface frequeslip<br>This interrupt occurs when the frame<br>synchronization pulse of the line interface sw<br>from F0IO to AF0 or reverse. The current FS<br>signal selection can be read from V_SU_AF0<br>register R_SU_STA.       | ency<br>vitches<br>SC<br>D in |
|          | 1                          | 0                       | V_TI_IRQ                                                |                   | <b>Timer interrupt status</b><br>'1' = timer elapsed                                                                                                                                                                                                                 |                               |
|          | 2                          | 0                       | V_PROC_IRQ                                              |                   | <b>Processing / non-processing transition inte</b><br>status<br>'1' = XHFC-1SU has changed from processing<br>non-processing phase (every 125 μs).<br><b>Note:</b> The current processing / non-processin<br>status can be read from V_PROC in register<br>R_STATUS. | <b>rrupt</b><br>g to          |
|          | 3                          |                         | (reserved)                                              |                   |                                                                                                                                                                                                                                                                      |                               |
|          | 4                          | 0                       | V_CI_IRQ                                                |                   | <b>Command / indication interrupt status</b><br>'1' = received indication bits changed                                                                                                                                                                               |                               |
|          | 5                          | 0                       | V_WAK_IRQ                                               |                   | Wakeup interrupt status<br>'1' = a wakeup signal at pin WAKEUP occure                                                                                                                                                                                                | d                             |
|          | 6                          | 0                       | V_MON_TX_IRQ                                            |                   | <b>Transmit monitor byte interrupt status</b><br>'1' = the next monitor byte can be written                                                                                                                                                                          |                               |
|          | 7                          | 0                       | V_MON_RX_IRQ                                            |                   | <b>Receive monitor byte interrupt status</b><br>'1' = monitor byte received                                                                                                                                                                                          |                               |

## **XHFC-1SU**



| R_       | _SU_IRQ                          |                                |                           | ( <b>r</b> )                        | (Reset group: H, 0)                                                                                                                                                                                            | 0x12                                      |
|----------|----------------------------------|--------------------------------|---------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| St<br>Tł | <b>ate chang</b><br>nis register | <b>e interru</b><br>reports st | pt status register of the | of the line inte<br>line interface. | erface                                                                                                                                                                                                         |                                           |
|          | Bits                             | Reset<br>value                 | Name                      |                                     | Description                                                                                                                                                                                                    |                                           |
|          | 0                                | 0                              | V_SU_IRQ                  |                                     | Interrupt status of line interface<br>'1' = a state change occured<br>Reading this register clears this bit. V_<br>not masked by register R_SU_IRQMS<br>shows a state change condition even if<br>is disabled. | _SU_IRQ is<br>K, i.e. it<br>the interrupt |
|          | 71                               |                                | (reserved)                |                                     |                                                                                                                                                                                                                |                                           |



| R_ | STATUS    |                |               | ( <b>r</b> ) | (Reset group: H, 0, 3) <b>0x1C</b>                                                                                                                                                                                                                                                                                                                                        |
|----|-----------|----------------|---------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Xŀ | IFC-1SU s | tatus regi     | ster          |              |                                                                                                                                                                                                                                                                                                                                                                           |
|    | Bits      | Reset<br>value | Name          |              | Description                                                                                                                                                                                                                                                                                                                                                               |
|    | 0         |                | V_BUSY        |              | BUSY / NOBUSY status<br>'0' = XHFC-1SU is not busy, all accesses are<br>allowed<br>'1' = XHFC-1SU is BUSY after initialising FIFO<br>reset, increment <i>F</i> -counter or change FIFO                                                                                                                                                                                    |
|    | 1         |                | V_PROC        |              | <ul> <li>Processing / non-processing status</li> <li>'0' = XHFC-1SU has finished the processing phase during the 125 μs cycle</li> <li>'1' = XHFC-1SU is in processing phase (once every 125 μs cycle)</li> <li>Note: The processing / non-processing transition can be notified with an interrupt (see V_PROC_IRQ in register R_MISC_IRQ).</li> </ul>                    |
|    | 2         |                | (reserved)    |              |                                                                                                                                                                                                                                                                                                                                                                           |
|    | 3         | 0              | V_LOST_STA    |              | LOST error (frames have been lost)<br>This means that XHFC-1SU did not process all<br>data in 125 µs. So data may be corrupted.<br>Bit V_RES_LOST of register A_INC_RES_FIFO<br>must be set to reset this bit.                                                                                                                                                            |
|    | 4         |                | V_PCM_INIT    |              | PCM module initialization<br>'0' = initialization sequence is finished<br>'1' = initialization sequence is in progress (after<br>hardware reset, global software reset or PCM reset)<br>Note: The PCM clocks F0IO and C4IO are<br>ignored during initialization.                                                                                                          |
|    | 5         |                | V_WAK_STA     |              | Wakeup status<br>This bit contains the current value of pin WAKEUP<br>when V_WAK_EN = '1' in register R_PWM_MD.                                                                                                                                                                                                                                                           |
|    | 6         | 0              | V_MISC_IRQSTA |              | Miscellaneous interrupt overview<br>All miscellaneous interrupts of register<br>R_MISC_IRQ are 'ored'.<br>'0' = No miscellaneous interrupt occured<br>'1' = At least one miscellaneous interrupt is<br>pending<br>This bit has always the same value as<br>V_MISC_IRQ in register R_IRQ_OVIEW.<br>Reading register R_MISC_IRQ clears the<br>miscellaneous interrupt bits. |

(continued on next page)



(continued from previous page)

| Bits Reset value | Name          | Description                                                                                                                                                                                                                                   |
|------------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7                | V_FIFO_IRQSTA | <ul> <li>Any FIFO interrupt</li> <li>All enabled FIFO interrupts in registers</li> <li>R_FIFO_BL0_IRQR_FIFO_BL3_IRQ are 'ored'.</li> <li>'0' = No FIFO interrupt is pending</li> <li>'1' = At least one FIFO interrupt is pending.</li> </ul> |

| R_FIFO_BL0_IRQ | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x20 |
|----------------|--------------|------------------------|------|
|----------------|--------------|------------------------|------|

#### Interrupt status register for FIFO block 0

This register reports the interrupt status of FIFO block 0. A bit is set to '1' when an interrupt event occures.

Reading this register clears the bits. These bits are not masked by V\_FIFO\_IRQMSK in register A\_FIFO\_CTRL, i.e. they show the FIFO conditions even if the interrupt is disabled. But it is important to enable FIFO interrupts globally with V\_FIFO\_IRQ\_EN = '1' in register R\_IRQ\_CTRL.

The interrupt condition can be configured for every FIFO individually (see bitmap V\_FIFO\_IRQ in register V\_FIFO\_IRQ and bit V\_MIX\_IRQ in register V\_MIX\_IRQ).

| Bits | Reset<br>value | Name           | Description                 |
|------|----------------|----------------|-----------------------------|
| 0    | 0              | V_FIFO0_TX_IRQ | FIFO[0,TX] interrupt status |
| 1    | 0              | V_FIFO0_RX_IRQ | FIFO[0,RX] interrupt status |
| 2    | 0              | V_FIFO1_TX_IRQ | FIFO[1,TX] interrupt status |
| 3    | 0              | V_FIFO1_RX_IRQ | FIFO[1,RX] interrupt status |
| 4    | 0              | V_FIFO2_TX_IRQ | FIFO[2,TX] interrupt status |
| 5    | 0              | V_FIFO2_RX_IRQ | FIFO[2,RX] interrupt status |
| 6    | 0              | V_FIFO3_TX_IRQ | FIFO[3,TX] interrupt status |
| 7    | 0              | V_FIFO3_RX_IRQ | FIFO[3,RX] interrupt status |



| R_FIFO_BL1_IRQ | ( <b>r</b> ) | (Reset group: $H, 0, 1$ ) | 0x21 |
|----------------|--------------|---------------------------|------|
|                |              |                           |      |

#### Interrupt status register for FIFO block 1

This register reports the interrupt status of FIFO block 1. A bit is set to '1' when an interrupt event occures.

Reading this register clears the bits. These bits are not masked by V\_FIFO\_IRQMSK in register A\_FIFO\_CTRL, i.e. they show the FIFO conditions even if the interrupt is disabled. But it is important to enable FIFO interrupts globally with V\_FIFO\_IRQ\_EN = '1' in register R\_IRQ\_CTRL.

The interrupt condition can be configured for every FIFO individually (see bitmap V\_FIFO\_IRQ in register V\_FIFO\_IRQ and bit V\_MIX\_IRQ) in register V\_MIX\_IRQ).

| Bits | Reset<br>value | Name           | Description                 |
|------|----------------|----------------|-----------------------------|
| 0    | 0              | V_FIFO4_TX_IRQ | FIFO[4,TX] interrupt status |
| 1    | 0              | V_FIFO4_RX_IRQ | FIFO[4,RX] interrupt status |
| 2    | 0              | V_FIFO5_TX_IRQ | FIFO[5,TX] interrupt status |
| 3    | 0              | V_FIFO5_RX_IRQ | FIFO[5,RX] interrupt status |
| 4    | 0              | V_FIFO6_TX_IRQ | FIFO[6,TX] interrupt status |
| 5    | 0              | V_FIFO6_RX_IRQ | FIFO[6,RX] interrupt status |
| 6    | 0              | V_FIFO7_TX_IRQ | FIFO[7,TX] interrupt status |
| 7    | 0              | V_FIFO7_RX_IRQ | FIFO[7,RX] interrupt status |
|      |                |                |                             |



| R_FIFO_BL2_IRQ | (r) | (Reset group: $H, 0, 1$ )             | 0x22 |
|----------------|-----|---------------------------------------|------|
| ··_····        | (-) | (, -, -, -, -, -, -, -, -, -, -, -, - |      |

#### Interrupt status register for FIFO block 2

This register reports the interrupt status of FIFO block 2. A bit is set to '1' when an interrupt event occures.

Reading this register clears the bits. These bits are not masked by V\_FIFO\_IRQMSK in register A\_FIFO\_CTRL, i.e. they show the FIFO conditions even if the interrupt is disabled. But it is important to enable FIFO interrupts globally with V\_FIFO\_IRQ\_EN = '1' in register R\_IRQ\_CTRL.

The interrupt condition can be configured for every FIFO individually (see bitmap V\_FIFO\_IRQ in register V\_FIFO\_IRQ and bit V\_MIX\_IRQ) in register V\_MIX\_IRQ).

| Bits | Reset<br>value | Name            | Description                  |
|------|----------------|-----------------|------------------------------|
| 0    | 0              | V_FIFO8_TX_IRQ  | FIFO[8,TX] interrupt status  |
| 1    | 0              | V_FIFO8_RX_IRQ  | FIFO[8,RX] interrupt status  |
| 2    | 0              | V_FIFO9_TX_IRQ  | FIFO[9,TX] interrupt status  |
| 3    | 0              | V_FIFO9_RX_IRQ  | FIFO[9,RX] interrupt status  |
| 4    | 0              | V_FIFO10_TX_IRQ | FIFO[10,TX] interrupt status |
| 5    | 0              | V_FIFO10_RX_IRQ | FIFO[10,RX] interrupt status |
| 6    | 0              | V_FIFO11_TX_IRQ | FIFO[11,TX] interrupt status |
| 7    | 0              | V_FIFO11_RX_IRQ | FIFO[11,RX] interrupt status |



| R_FIFO_BL3_IRQ | ( <b>r</b> ) | (Reset group: H, 0, 1) | 0x23 |
|----------------|--------------|------------------------|------|
|----------------|--------------|------------------------|------|

#### Interrupt status register for FIFO block 3

This register reports the interrupt status of FIFO block 3. A bit is set to '1' when an interrupt event occures.

Reading this register clears the bits. These bits are not masked by V\_FIFO\_IRQMSK in register A\_FIFO\_CTRL, i.e. they show the FIFO conditions even if the interrupt is disabled. But it is important to enable FIFO interrupts globally with V\_FIFO\_IRQ\_EN = '1' in register R\_IRQ\_CTRL.

The interrupt condition can be configured for every FIFO individually (see bitmap V\_FIFO\_IRQ in register V\_FIFO\_IRQ and bit V\_MIX\_IRQ) in register V\_MIX\_IRQ).

| Bits | Reset<br>value | Name            | Description                  |
|------|----------------|-----------------|------------------------------|
| 0    | 0              | V_FIFO12_TX_IRQ | FIFO[12,TX] interrupt status |
| 1    | 0              | V_FIFO12_RX_IRQ | FIFO[12,RX] interrupt status |
| 2    | 0              | V_FIFO13_TX_IRQ | FIFO[13,TX] interrupt status |
| 3    | 0              | V_FIFO13_RX_IRQ | FIFO[13,RX] interrupt status |
| 4    | 0              | V_FIFO14_TX_IRQ | FIFO[14,TX] interrupt status |
| 5    | 0              | V_FIFO14_RX_IRQ | FIFO[14,RX] interrupt status |
| 6    | 0              | V_FIFO15_TX_IRQ | FIFO[15,TX] interrupt status |
| 7    | 0              | V_FIFO15_RX_IRQ | FIFO[15,RX] interrupt status |

| (Reset group: H) <b>0x50</b>                                                              |
|-------------------------------------------------------------------------------------------|
|                                                                                           |
| Description                                                                               |
|                                                                                           |
| <b>PLL lock status</b><br>'0' = PLL is unlocked or in standby mode<br>'1' = PLL is locked |
|                                                                                           |



## 9.6.3 Read/write registers

| R          | _PLL_P    |                |               | (r/w)               | (Reset group: H)                                                                                          | 0x51           |
|------------|-----------|----------------|---------------|---------------------|-----------------------------------------------------------------------------------------------------------|----------------|
| <b>P</b> ] | LL prediv | vider prog     | ramming value |                     |                                                                                                           |                |
|            | Bits      | Reset<br>value | Name          | Desc                | ription                                                                                                   |                |
|            | 70        | 0              | V_PLL_P       | Pred<br>The<br>bitm | <b>livider programming value</b><br>divisor of the predivider is V_PL<br>ap value 0 has the meaning of 25 | L_P. The<br>6. |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)

| R_ | PLL_N     |                |         | ( <b>r/w</b> )     | (Reset group: H)                                                                       | 0x52 |
|----|-----------|----------------|---------|--------------------|----------------------------------------------------------------------------------------|------|
| PL | L loop fa | ictor          |         |                    |                                                                                        |      |
|    | Bits      | Reset<br>value | Name    | Dese               | cription                                                                               |      |
|    | 70        | 0              | V_PLL_N | Loo<br>The<br>Note | <b>p factor programming value</b><br>loop factor is V_PLL_N.<br>e: 04 are not allowed. |      |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)

| R  | _PLL_S    |                |                | ( <b>r/w</b> )      | (Reset group: H)                                                                                    | 0x53           |
|----|-----------|----------------|----------------|---------------------|-----------------------------------------------------------------------------------------------------|----------------|
| PI | LL post-s | caler prog     | gramming value |                     |                                                                                                     |                |
|    | Bits      | Reset<br>value | Name           | Des                 | cription                                                                                            |                |
|    | 70        | 0              | V_PLL_S        | Post<br>The<br>bitm | -scaler programming value<br>divisor of the post-scaler is V_PL<br>ap value 0 has the meaning of 25 | L_S. The<br>6. |
|    |           |                |                | The                 | divisor of the post-scaler is V_PL<br>ap value 0 has the meaning of 25                              | L_S. The<br>6. |





# Chapter 10

# **General purpose I/O pins (GPIO)**

Write only registers: Read only registers: Page Address Name Address Name Page 0x40 R\_GPIO\_OUT1 321 0x40 R\_GPIO\_IN1 328 R\_GPIO\_IN2 0x42 R\_GPIO\_EN1 322 0x45 328 0x44 R\_GPIO\_SEL\_BL 323 0x48 R\_GPIO\_IN0 329 0x45 R\_GPIO\_OUT2 323 0x47 R\_GPIO\_EN2 324 0x48 R\_GPIO\_OUT0 324 0x4A R\_GPIO\_EN0 325 R\_GPIO\_SEL 0x4C 326

Table 10.1: Overview of the XHFC-1SU general purpose I/O registers



## **10.1 GPIO functionality**

XHFC-1SU has up to 20 general purpose I/O (GPIO) pins. 6 pins are always available as GPIO. 6 pins are shared with the line interface and are only available if the  $ST/U_p$  interface is not used. Eight further pins are shared with PCM, PWM and clock functions and are individually selectable as GPIO.

Every pin listed in Table 10.2 has three functions. A detailed GPIO block diagram is shown in Figure 10.1. For GPIO8, e.g., the following configurations are available:

• GPIO selection bit V\_GPIO\_SEL0 = '0' in register R\_GPIO\_SEL:

The line interface function  $(1^{st} \text{ pin function})$  is selected. GPIO8 output is disabled within a group of six pins (2<sup>nd</sup> pin functions GPIO8..GPIO11, GPIO16 and GPIO17 are not available).

• GPIO selection bit V\_GPIO\_SEL0 = '1' in register R\_GPIO\_SEL and GPIO enable bit V\_GPIO\_EN8 = '0' in register R\_GPIO\_EN1:

The line interface function  $(1^{st} \text{ pin function})$  is disabled. GPIO functionality is enabled for a group of six pins (2<sup>nd</sup> pin function). GPIO8 ouput is disabled, i.e. the output driver is tristated.

• GPIO selection bit V\_GPIO\_SEL0 = '1' in register R\_GPIO\_SEL and GPIO enable bit V\_GPIO\_EN8 = '1' in register R\_GPIO\_EN1:

The line interface function  $(1^{st} \text{ pin function})$  is disabled. GPIO functionality is enabled for a group of six pins (2<sup>nd</sup> pin function). GPIO8 ouput is enabled.

The GPIO input functionality is always enabled, i.e. registers R\_GPIO\_IN0 and R\_GPIO\_IN1 can always be read.

GPIO 0..7 are implemented in the same way with the exception that the selection bits in register R\_GPIO\_SEL switch only one pin from first to second function.

Unused GPIO pins should be configured as output ports. This sets the level of the input buffer – which is always active at the same pin – to a stable level and avoids floating input effect.

## **10.2 GPIO output voltage**

As the output drivers of the  $ST/U_p$  interface are supplied from an external source, the GPIO output voltage of these pins is influenced by this external source as well.

Yet it is recommended to connect the VDD\_SU pin to VDD when the line interface is not used.

For a few applications a GPIO output voltage different from VDD might be useful. In this case the external voltage must not exceed 3.6 V. Table 10.2 shows the allocation of power supply pins to the GPIO output drivers.





**Figure 10.1:** Block diagram of GPIO pins shared with the  $ST/U_p$  interface (GPIO8, GPIO9 and GPIO16 exemplarily)





to GPIO14, 15, 18, 19 output drivers

Figure 10.2: Block diagram of the additional GPIO block (GPIO12 and GPIO13 exemplarily)



| Pin<br>number | GPIO<br>pin | GPIO<br>byte | Shared with (1 <sup>st</sup> function) | Output driver<br>power supply |
|---------------|-------------|--------------|----------------------------------------|-------------------------------|
| 36            | GPIO0       | 0            | PWM0                                   | VDD                           |
| 35            | GPIO1       | 0            | PWM1                                   | VDD                           |
| 28            | GPIO2       | 0            | F1_0                                   | VDD                           |
| 27            | GPIO3       | 0            | F1_1                                   | VDD                           |
| 21            | GPIO4       | 0            | STIO1                                  | VDD                           |
| 22            | GPIO5       | 0            | STIO2                                  | VDD                           |
| 16            | GPIO6       | 0            | SYNC_O                                 | VDD                           |
| 33            | GPIO7       | 0            | CLK_OUT                                | VDD                           |
| 58            | GPIO8       | 1            | R_A                                    | VDD                           |
| 57            | GPIO9       | 1            | L_A                                    | VDD                           |
| 56            | GPIO10      | 1            | L_B                                    | VDD                           |
| 55            | GPIO11      | 1            | R_B                                    | VDD                           |
| 42            | GPIO12      | 1            |                                        | VDD                           |
| 41            | GPIO13      | 1            |                                        | VDD                           |
| 40            | GPIO14      | 1            |                                        | VDD                           |
| 39            | GPIO15      | 1            |                                        | VDD                           |
| 51            | GPIO16      | 2            | T_A                                    | VDD_SU                        |
| 50            | GPIO17      | 2            | T_B                                    | VDD_SU                        |
| 47            | GPIO18      | 2            |                                        | VDD                           |
| 46            | GPIO19      | 2            |                                        | VDD                           |

Table 10.2: GPIO pins



## 10.3 Activation state F7/G3 signalling

Some GPIO outputs can alternatively be used to report the activation states F7 or G3. This function is typically used to drive LEDs directly from XHFC-1SU pins. Figure 10.3 shows exemplarily for GPIO0, how the activation state is linked up to the GPIO signal path.



Figure 10.3: Activation state signalling exemplarily shown with GPIO0 (similar for GPIO1 . . GPIO5)

| Table | 10.3: | State | F7/G3 | reporting |
|-------|-------|-------|-------|-----------|
| labic | 10.0. | oluic | 17/00 | reporting |

| V_LED_ROT in register R_SU_LED_CTRL |                 |       |       |  |  |  |
|-------------------------------------|-----------------|-------|-------|--|--|--|
| '00'                                | '01'            | '10'  | '11'  |  |  |  |
| GPIO0 and GPIO4                     | GPIO1 and GPIO5 | GPIO2 | GPIO3 |  |  |  |

The line activation state of the line interface can be assigned to pins GPIO0..GPIO5 with the GPIO port number written into V\_LED\_ROT.

Additionally, GPIO4 can be used to report the activation state in parallel to GPIO0 and GPIO5 can be used to report the activation state in parallel to GPIO1.

Table 10.3 shows the assignment of GPIO port numbers 0..5 and the line interface.



# **10.4** Register description

## **10.4.1** Write only registers

| R_                        | R_GPIO_OUT1 |                |              | (w)  | (Reset group: H, 0)         | 0x40 |
|---------------------------|-------------|----------------|--------------|------|-----------------------------|------|
| GPIO output data bits 158 |             |                |              |      |                             |      |
|                           | Bits        | Reset<br>value | Name         | Dese | cription                    |      |
|                           | 0           | 0              | V_GPIO_OUT8  | Out  | put data bit for pin GPIO8  |      |
|                           | 1           | 0              | V_GPIO_OUT9  | Out  | put data bit for pin GPIO9  |      |
|                           | 2           | 0              | V_GPIO_OUT10 | Out  | put data bit for pin GPIO10 |      |
|                           | 3           | 0              | V_GPIO_OUT11 | Out  | put data bit for pin GPIO11 |      |
|                           | 4           | 0              | V_GPIO_OUT12 | Out  | put data bit for pin GPIO12 |      |
|                           | 5           | 0              | V_GPIO_OUT13 | Out  | put data bit for pin GPIO13 |      |
|                           | 6           | 0              | V_GPIO_OUT14 | Out  | put data bit for pin GPIO14 |      |
|                           | 7           | 0              | V_GPIO_OUT15 | Out  | put data bit for pin GPIO15 |      |

1

2

3

4

5

6

7

0

0

0

0

0

0

0



| R        | _GPIO_E                                                                                                                                   | N1             |            | (w)  | (Reset group: H, 0)      | 0x42 |  |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------|------|--------------------------|------|--|--|
| G        | GPIO output enable bits 158                                                                                                               |                |            |      |                          |      |  |  |
| Ev<br>is | Every bit value '1' enables the allocated output driver. If an output driver is disabled (bit value '0'), the pin is used for data input. |                |            |      |                          |      |  |  |
|          | Bits                                                                                                                                      | Reset<br>value | Name       | Desc | ription                  |      |  |  |
|          | 0                                                                                                                                         | 0              | V_GPIO_EN8 | Out  | out enable for pin GPIO8 |      |  |  |
|          |                                                                                                                                           |                |            | -    | -                        |      |  |  |

**Output enable for pin GPIO9** 

**Output enable for pin GPIO10** 

Output enable for pin GPIO11

Output enable for pin GPIO12

Output enable for pin GPIO13

Output enable for pin GPIO14

Output enable for pin GPIO15

V\_GPIO\_EN9

V\_GPIO\_EN10

V\_GPIO\_EN11

V\_GPIO\_EN12

V\_GPIO\_EN13

V\_GPIO\_EN14

V\_GPIO\_EN15



| R_                      | _GPIO_SE                                                                                                                                                                                                                                                                 | EL_BL          | ( w                            | v)                                                                  | (Reset group: H, 0)                                                                                                                                                                                      | 0x44                                             |  |  |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|
| Se<br>12<br>firs<br>tog | Selection register for GPIO block<br>12 GPIO pins are grouped in blocks with 6 GPIO functions each. The first block uses the line interface as<br>first pin function alternatively. The other GPIO block has no alternative pin function but can be enabled<br>together. |                |                                |                                                                     |                                                                                                                                                                                                          |                                                  |  |  |
| Th                      | is register                                                                                                                                                                                                                                                              | controls o     | nly the output driver, whereas | the input                                                           | functionality needs no programmin                                                                                                                                                                        | ıg.                                              |  |  |
|                         | Bits                                                                                                                                                                                                                                                                     | Reset<br>value | Name                           | Descr                                                               | iption                                                                                                                                                                                                   |                                                  |  |  |
|                         | 0                                                                                                                                                                                                                                                                        | 0              | V_GPIO_BL0                     | <b>GPIO</b><br>'0' = li<br>'1' = <b>G</b><br>(secon                 | function on the line interface<br>ne interface used (first pin function)<br>PIO8 GPIO11, GPIO16 and GPIO<br>ad pin function)                                                                             | )<br>17 used                                     |  |  |
|                         |                                                                                                                                                                                                                                                                          |                |                                |                                                                     |                                                                                                                                                                                                          |                                                  |  |  |
|                         | 1                                                                                                                                                                                                                                                                        | 0              | V_GPIO_BL1                     | Enabl<br>Six Gl<br>output<br>well as<br>GPIO <sup>1</sup><br>47) an | e GPIO output function on block<br>PIO pins are combined to a block an<br>drivers have a common enable functs<br>an individual enable function. The<br>2GPIO15 (pins 4239), GPIO18<br>d GPIO19 (pin 46). | no. 1<br>d their<br>ction as<br>se are<br>3 (pin |  |  |
|                         |                                                                                                                                                                                                                                                                          |                |                                | '0' = 0<br>'1' = 0<br>their in<br>R_GP                              | utput drivers of block no. 1 are trista<br>utput drivers of block no. 1 are enab<br>ndividual enable function in register<br>'IO_EN1 and R_GPIO_EN2 is set to                                            | ated<br>led when<br>'s<br>o '1'                  |  |  |
|                         | 72                                                                                                                                                                                                                                                                       | 0              | (reserved)                     | Must                                                                | be 0.                                                                                                                                                                                                    |                                                  |  |  |
|                         |                                                                                                                                                                                                                                                                          |                |                                |                                                                     |                                                                                                                                                                                                          |                                                  |  |  |

| R_ | R_GPIO_OUT2 |                |              | (w) (Reset group: H, 0)      | 0x45 |
|----|-------------|----------------|--------------|------------------------------|------|
| G  | PIO outp    | ut data bi     | its 1916     |                              |      |
|    | Bits        | Reset<br>value | Name         | Description                  |      |
|    | 0           | 0              | V_GPIO_OUT16 | Output data bit for pin GPIC | D16  |
|    | 1           | 0              | V_GPIO_OUT17 | Output data bit for pin GPIC | 017  |
|    | 2           | 0              | V_GPIO_OUT18 | Output data bit for pin GPIC | D18  |
|    | 3           | 0              | V_GPIO_OUT19 | Output data bit for pin GPIC | 019  |
|    | 74          | 0              | (reserved)   | Must be '0000'.              |      |



| R_GPIO_EN2                                                                                                                                |      |                |             | (w) | (Reset group: H, 0)       | 0x47 |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------|------|----------------|-------------|-----|---------------------------|------|--|--|--|
| GPIO output enable bits 1916                                                                                                              |      |                |             |     |                           |      |  |  |  |
| Every bit value '1' enables the allocated output driver. If an output driver is disabled (bit value '0'), the pin is used for data input. |      |                |             |     |                           |      |  |  |  |
|                                                                                                                                           | Bits | Reset<br>value | Name        | Des | cription                  |      |  |  |  |
|                                                                                                                                           | 0    | 0              | V_GPIO_EN16 | Out | put enable for pin GPIO16 |      |  |  |  |
|                                                                                                                                           | 1    | 0              | V_GPIO_EN17 | Out | put enable for pin GPIO17 |      |  |  |  |
|                                                                                                                                           | 2    | 0              | V_GPIO_EN18 | Out | put enable for pin GPIO18 |      |  |  |  |
|                                                                                                                                           | 3    | 0              | V_GPIO_EN19 | Out | put enable for pin GPIO19 |      |  |  |  |
|                                                                                                                                           | 74   | 0              | (reserved)  | Mus | ste be '0000'.            |      |  |  |  |

| R_GPIO_OUT0              |      |                |             | (w) (Reset group: H, 0)       | 0x48 |  |  |  |  |
|--------------------------|------|----------------|-------------|-------------------------------|------|--|--|--|--|
| GPIO output data bits 70 |      |                |             |                               |      |  |  |  |  |
|                          | Bits | Reset<br>value | Name        | Description                   |      |  |  |  |  |
|                          | 0    | 0              | V_GPIO_OUT0 | Output data bit for pin GPIO0 |      |  |  |  |  |
|                          | 1    | 0              | V_GPIO_OUT1 | Output data bit for pin GPIO1 |      |  |  |  |  |
|                          | 2    | 0              | V_GPIO_OUT2 | Output data bit for pin GPIO2 |      |  |  |  |  |
|                          | 3    | 0              | V_GPIO_OUT3 | Output data bit for pin GPIO3 |      |  |  |  |  |
|                          | 4    | 0              | V_GPIO_OUT4 | Output data bit for pin GPIO4 |      |  |  |  |  |
|                          | 5    | 0              | V_GPIO_OUT5 | Output data bit for pin GPIO5 |      |  |  |  |  |
|                          | 6    | 0              | V_GPIO_OUT6 | Output data bit for pin GPIO6 |      |  |  |  |  |
|                          | 7    | 0              | V_GPIO_OUT7 | Output data bit for pin GPIO7 |      |  |  |  |  |


| R_             | _GPIO_E                                                                                                                                                                        | N0             |            | (w)   | (Reset group: H, 0)     | 0x4A |  |  |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------|-------|-------------------------|------|--|--|
| GI<br>Ev<br>is | <b>GPIO output enable bits 70</b><br>Every bit value '1' enables the allocated output driver. If an output driver is disabled (bit value '0'), the pin is used for data input. |                |            |       |                         |      |  |  |
|                | Bits                                                                                                                                                                           | Reset<br>value | Name       | Desci | iption                  |      |  |  |
|                | 0                                                                                                                                                                              | 0              | V_GPIO_EN0 | Outp  | ut enable for pin GPIO0 |      |  |  |
|                | 1                                                                                                                                                                              | 0              | V_GPIO_EN1 | Outp  | ut enable for pin GPIO1 |      |  |  |
|                | 2                                                                                                                                                                              | 0              | V_GPIO_EN2 | Outp  | ut enable for pin GPIO2 |      |  |  |
|                | 3                                                                                                                                                                              | 0              | V_GPIO_EN3 | Outp  | ut enable for pin GPIO3 |      |  |  |
|                | 4                                                                                                                                                                              | 0              | V_GPIO_EN4 | Outp  | ut enable for pin GPIO4 |      |  |  |
|                | 5                                                                                                                                                                              | 0              | V_GPIO_EN5 | Outp  | ut enable for pin GPIO5 |      |  |  |
|                | 6                                                                                                                                                                              | 0              | V_GPIO_EN6 | Outp  | ut enable for pin GPIO6 |      |  |  |
|                | 7                                                                                                                                                                              | 0              | V_GPIO_EN7 | Outp  | ut enable for pin GPIO7 |      |  |  |



| R_ | <b>R_GPIO_SEL</b> (w)         (Reset group: H, 0) |                |                              |                      |                                                                                                                   |  |
|----|---------------------------------------------------|----------------|------------------------------|----------------------|-------------------------------------------------------------------------------------------------------------------|--|
| GI | PIO select                                        | ion regist     | er                           |                      |                                                                                                                   |  |
| Th | is register                                       | controls o     | only the output driver, when | reas the             | input functionality needs no programming.                                                                         |  |
|    | Bits                                              | Reset<br>value | Name                         | D                    | Description                                                                                                       |  |
|    | 0                                                 | 0              | V_GPIO_SEL0                  | S<br>'C<br>'1        | election of first or second pin function<br>)' = PWM0 (first pin function)<br>l' = GPIO0 (second pin function)    |  |
|    | 1                                                 | 0              | V_GPIO_SEL1                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>" = PWM1 (first pin function)<br>" = GPIO1 (second pin function)      |  |
|    | 2                                                 | 0              | V_GPIO_SEL2                  | S<br>'C<br>'1        | election of first or second pin function<br>' = F1_0 (first pin function)<br>' = GPIO2 (second pin function)      |  |
|    | 3                                                 | 0              | V_GPIO_SEL3                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>)' = F1_1 (first pin function)<br>L' = GPIO3 (second pin function)    |  |
|    | 4                                                 | 0              | V_GPIO_SEL4                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>)' = STIO1 (first pin function)<br>L' = GPIO4 (second pin function)   |  |
|    | 5                                                 | 0              | V_GPIO_SEL5                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>)' = STIO2 (first pin function)<br>L' = GPIO5 (second pin function)   |  |
|    | 6                                                 | 0              | V_GPIO_SEL6                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>D' = SYNC_O (first pin function)<br>L' = GPIO6 (second pin function)  |  |
|    | 7                                                 | 0              | V_GPIO_SEL7                  | <b>S</b><br>'C<br>'1 | election of first or second pin function<br>)' = CLK_OUT (first pin function)<br>L' = GPIO7 (second pin function) |  |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)



| R_       | _SU_LED                    | _CTRL                      |                                                               | (w)                                            | (Reset group: H, 0)                                                                                                                                                                                                                                                                                                         | 0x4D                               |
|----------|----------------------------|----------------------------|---------------------------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| LI       | ED contro                  | l register                 |                                                               |                                                |                                                                                                                                                                                                                                                                                                                             |                                    |
| Th<br>Ac | is register<br>tivated sta | can be use<br>te is indica | ed to indicate activated state<br>ated by high level. LEDs wi | es F7 or<br>th serie                           | G3 on one pin of GPIO0GPIO5.<br>s resistor can directly be connected to XHF                                                                                                                                                                                                                                                 | C-1SU.                             |
|          | Bits                       | Reset<br>value             | Name                                                          | D                                              | escription                                                                                                                                                                                                                                                                                                                  |                                    |
|          | 0                          | 0                          | V_LED_EN0                                                     | E<br>'0<br>'1                                  | nable LED output signal on pin GPIO0<br>' = normal GPIO function on pin GPIO0<br>' = activated state is indicated on pin GPIC                                                                                                                                                                                               | 00                                 |
|          | 1                          | 0                          | V_LED_EN1                                                     | E<br>'0<br>'1                                  | nable LED output signal on pin GPIO1<br>' = normal GPIO function on pin GPIO1<br>' = activated state is indicated on pin GPIC                                                                                                                                                                                               | D1                                 |
|          | 2                          | 0                          | V_LED_EN2                                                     | E<br>'0<br>'1                                  | nable LED output signal on pin GPIO2<br>' = normal GPIO function on pin GPIO2<br>' = activated state is indicated on pin GPIO                                                                                                                                                                                               | )2                                 |
|          | 3                          | 0                          | V_LED_EN3                                                     | E<br>'0<br>'1                                  | <b>nable LED output signal on pin GPIO3</b><br>' = normal GPIO function on pin GPIO3<br>' = activated state is indicated on pin GPIC                                                                                                                                                                                        | 03                                 |
|          | 4                          | 0                          | V_LED_EN4                                                     | E<br>'0<br>'1                                  | nable LED output signal on pin GPIO4<br>' = normal GPIO function on pin GPIO4<br>' = activated state is indicated on pin GPIC                                                                                                                                                                                               | 04                                 |
|          | 5                          | 0                          | V_LED_EN5                                                     | E<br>'0<br>'1                                  | nable LED output signal on pin GPIO5<br>' = normal GPIO function on pin GPIO5<br>' = activated state is indicated on pin GPIC                                                                                                                                                                                               | 05                                 |
|          | 76                         | 0                          | V_LED_ROT                                                     | L<br>A<br>to<br>'0<br>G<br>'0<br>G<br>'1<br>'1 | ED output rotator / shifter<br>ctivated state of the line interface can be a<br>pins GPIO0GPIO5 via a signal rotator/<br>0' = line interface is assigned to GPIO0 an<br>PIO4<br>1' = line interface is assigned to GPIO1 ar<br>PIO5<br>0' = line interface is assigned to GPIO2<br>1' = line interface is assigned to GPIO3 | assigned<br>/ shifter.<br>nd<br>nd |

(See Section 13 on page 337 for a fault description and workaround of an address decoding problem which concerns this register among others.)

Cologne Chip

#### 10.4.2 Read only registers

| R_ | _gpio_in                 | 11             |                             | ( <b>r</b> ) | (Reset group: -)        | 0x40 |  |
|----|--------------------------|----------------|-----------------------------|--------------|-------------------------|------|--|
| Gl | GPIO input data bits 158 |                |                             |              |                         |      |  |
| No | ote: Unus                | ed GPIO p      | ins should be configured as | output pins. |                         |      |  |
|    | Bits                     | Reset<br>value | Name                        | Descrip      | tion                    |      |  |
|    | 0                        |                | V_GPIO_IN8                  | Input d      | ata bit from pin GPIO8  |      |  |
|    | 1                        |                | V_GPIO_IN9                  | Input d      | ata bit from pin GPIO9  |      |  |
|    | 2                        |                | V_GPIO_IN10                 | Input d      | ata bit from pin GPIO10 |      |  |
|    | 3                        |                | V_GPIO_IN11                 | Input d      | ata bit from pin GPIO11 |      |  |
|    | 4                        |                | V_GPIO_IN12                 | Input d      | ata bit from pin GPIO12 |      |  |
|    | 5                        |                | V_GPIO_IN13                 | Input d      | ata bit from pin GPIO13 |      |  |
|    | 6                        |                | V_GPIO_IN14                 | Input d      | ata bit from pin GPIO14 |      |  |
|    | 7                        |                | V_GPIO_IN15                 | Input d      | ata bit from pin GPIO15 |      |  |

| R_       | _gpio_in                                                                                | 12             |             | ( <b>r</b> ) | (Reset group: -)            | 0x45 |  |  |
|----------|-----------------------------------------------------------------------------------------|----------------|-------------|--------------|-----------------------------|------|--|--|
| GI<br>No | GPI input data bits 1916<br>Note: Unused GPIO pins should be configured as output pins. |                |             |              |                             |      |  |  |
|          | Bits                                                                                    | Reset<br>value | Name        | Des          | cription                    |      |  |  |
|          | 0                                                                                       |                | V_GPIO_IN16 | Inp          | ut data bit from pin GPIO16 |      |  |  |
|          | 1                                                                                       |                | V_GPIO_IN17 | Inp          | ut data bit from pin GPIO17 |      |  |  |
|          | 2                                                                                       |                | V_GPIO_IN18 | Inp          | ut data bit from pin GPIO18 |      |  |  |
|          | 3                                                                                       |                | V_GPIO_IN19 | Inp          | ut data bit from pin GPIO19 |      |  |  |
|          | 74                                                                                      |                | (reserved)  |              |                             |      |  |  |



| R  | _gpio_i                 | NO                    |                          | ( <b>r</b> )     | (Reset group: -)          | 0x48 |  |  |  |
|----|-------------------------|-----------------------|--------------------------|------------------|---------------------------|------|--|--|--|
| G  | GPIO input data bits 70 |                       |                          |                  |                           |      |  |  |  |
| No | ote: Unu                | sed GPIO <sub>I</sub> | oins should be configure | ed as output pin | s.                        |      |  |  |  |
|    | Bits                    | Reset<br>value        | Name                     | Desc             | ription                   |      |  |  |  |
|    | 0                       |                       | V_GPIO_IN0               | Inpu             | t data bit from pin GPIO0 |      |  |  |  |
|    | 1                       |                       | V_GPIO_IN1               | Inpu             | t data bit from pin GPIO1 |      |  |  |  |
|    | 2                       |                       | V_GPIO_IN2               | Inpu             | t data bit from pin GPIO2 |      |  |  |  |
|    | 3                       |                       | V_GPIO_IN3               | Inpu             | t data bit from pin GPIO3 |      |  |  |  |
|    | 4                       |                       | V_GPIO_IN4               | Inpu             | t data bit from pin GPIO4 |      |  |  |  |
|    | 5                       |                       | V_GPIO_IN5               | Inpu             | t data bit from pin GPIO5 |      |  |  |  |
|    | 6                       |                       | V_GPIO_IN6               | Inpu             | t data bit from pin GPIO6 |      |  |  |  |
|    | 7                       |                       | V_GPIO_IN7               | Inpu             | t data bit from pin GPIO7 |      |  |  |  |





## Chapter 11

# **Electrical characteristics**



#### Absolute maximum ratings \*1

| Parameter           | Symbol                     | Min.             | Max.                                                    | Conditions                      |
|---------------------|----------------------------|------------------|---------------------------------------------------------|---------------------------------|
| Power supply        | $V_{\rm DD}$               | -0.3 V           | +4.6 V                                                  |                                 |
| Input voltage       | $V_{\rm I}$<br>$V_{\rm I}$ | -0.3 V<br>-0.3 V | $V_{\rm DD} + 0.3  { m V} ~(\leq 4.6  { m V})$<br>6.0 V | 3.3 V pins<br>5 V tolerant pins |
| Output voltage      | V <sub>O</sub>             | -0.3 V           | $V_{\rm DD}+0.3{ m V}$                                  |                                 |
| Storage temperature | T <sub>stg</sub>           | -55°C            | +125 °C                                                 |                                 |

#### **Recommended operating conditions**

| Parameter                       | Symbol            | Min.  | Тур.  | Max    | Conditions                             |
|---------------------------------|-------------------|-------|-------|--------|----------------------------------------|
| Power supply                    | $V_{\rm DD}$      | 3.0 V | 3.3 V | 3.6 V  |                                        |
| Operating temperature           | $T_{\rm opr}$     | -30°C |       | +85 °C |                                        |
| Peak-to-peak power supply noise | $V_{ m noise,pp}$ |       |       | 50 mV  | PLL not used or no locking requirement |
|                                 | $V_{ m noise,pp}$ |       |       | 10 mV  | PLL used, stable locking required      |

#### Electrical characteristics for 3.3 V power supply

| Parameter                             | Symbol              | Min.          | Тур.       | Max                            | Conditions |
|---------------------------------------|---------------------|---------------|------------|--------------------------------|------------|
| Low input voltage *2                  | $V_{\rm IL}$        | -0.3 V        |            | 0.8 V                          |            |
| High input voltage *3                 | $V_{\mathrm{IH}}$   | 2.0 V         |            | $V_{\rm DD} + 0.3  \mathrm{V}$ |            |
| High input voltage *4                 | $V_{\mathrm{IH}}$   | 2.0 V         |            | 5.5 V                          |            |
| Low output voltage *2                 | V <sub>OL</sub>     |               |            | 0.4 V                          |            |
| High output voltage *2                | $V_{\rm OH}$        | 2.4 V         |            |                                |            |
| Internal pull-up resistor to $V_{DD}$ | R <sub>pu,int</sub> | $55  k\Omega$ | 110 kΩ     | 330 kΩ                         |            |
| (pin type IOpu # only, see pin lis    | st from page        | 36 and lege   | end on pag | ge 40)                         |            |

The pin capacitance depends on the pin type. For details see legend of the pin list on page 40.

<sup>\*1</sup>: Stresses beyond those listed under 'Absolute maximum ratings' may cause permanent damage to the device. These are stress ratings only, and operation of the device at these or at any other conditions above those given in this data sheet is not implied. Exposure to limiting values for extended periods may affect device reliability.

 $^{*2}$ : All pins except oscillator and S/T/U<sub>p</sub> type.

 $^{*3}$ : All pins except oscillator, S/T / U<sub>p</sub> type and 5 V tolerant pins.

<sup>\*4</sup>: Only 5 V tolerant pins.



#### Power consumption for 3.3 V power supply

| Parameter                                                      | Symbol | Min. Typ. Max | Conditions |
|----------------------------------------------------------------|--------|---------------|------------|
| Oscillator running with 24.576 MHz,                            |        |               |            |
| internal clock disabled                                        | Iopr   | 4 mA          | 21 °C      |
| Oscillator running with 24.576 MHz, internal clock enabled,    |        |               |            |
| FIFOs and PCM 30 clocks running                                | Iopr   | 19 mA         | 21 °C      |
| Oscillator running with 24.576 MHz,<br>internal clock enabled, |        |               |            |
| S/T interface sending 96 kHz                                   |        |               |            |
| test signal on $50 \Omega$ load                                | Iopr   | 29 mA         | 21 °C      |
| Oscillator stopped                                             | Iopr   | 1 mA          | 21 °C      |
| Power consumption of PLL only                                  |        |               |            |
| with $f_{OSC} = 74 \text{ MHz}$ and $M = 1$                    | Iopr   | 7 mA          | 21 °C      |
| Power consumption of PLL only                                  |        |               |            |
| with $f_{OSC} = 74 \text{ MHz}$ and $M = 3$                    | Iopr   | 5 mA          | 21 °C      |

#### Thermal package characteristics

| Parameter        | Symbol          | Min. Typ. Max | Conditions      |
|------------------|-----------------|---------------|-----------------|
| Junction to air  | $\Theta_{J\!A}$ | +52°C/W       | Multi-Layer PCB |
| Junction to case | $\Theta_{JC}$   | +18 °C/W      | Multi-Layer PCB |





Chapter 12

# XHFC-1SU package dimensions











Chapter 13

# XHFC-1SU address decoding erratum

### **13.1 Fault description**

XHFC-1SU has an address decoding problem with write access to some registers. This erratum chapter describes the problem as well as work-arounds to avoid unwanted chip behaviour.

The address decoding fault refers to register addresses 0x48..0x5F. Any write access to these registers writes also to their counterregisters at in the address range 0x08..0x1F.

Due to the fact, that some addresses are not used by the chips, there are only few registers involved as shown in Table 13.1.

| 1    | Write access to |      | Writes also to |
|------|-----------------|------|----------------|
| 0x48 | R_GPIO_OUT0     | 0x08 | R_RAM_ADDR     |
| 0x4C | R_GPIO_SEL      | 0x0C | R_FIFO_THRES   |
| 0x4D | R_SU_LED_CTRL   | 0x0D | R_FIFO_MD      |
| 0x50 | R_PLL_CTRL      | 0x10 | R_SLOT         |
| 0x51 | R_PLL_P         | 0x11 | R_MISC_IRQMSK  |
| 0x52 | R_PLL_N         | 0x12 | R_SU_IRQMSK    |
| 0x53 | R_PLL_S         | 0x13 | R_IRQ_CTRL     |

 Table 13.1: Involved registers of the address decoding fault

Read-only registers are not concerned in this fault.

### 13.2 Work-Around

The general work-around is to write registers in the address range 0x48..0x5F only once during chip initialization. The counterregisters 0x08..0x1F should be written afterwards. Exceptionally, register R\_GPIO\_OUT0 (0x48) can be written at any time, because it's counterregister R\_RAM\_ADDR (0x08) is normally not used.

Table 13.2 shows a complete list of the involved register adresses. Only gray marked lines are concerned in the decoding fault. In these cases, a detailed work-around is described to ensure a faultless chip behaviour.



| Write access to |             | Writes also to |              | Remark                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|-----------------|-------------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0x48            | R_GPIO_OUT0 | 0x08           | R_RAM_ADDR   | R_RAM_ADDR must be written again af-<br>ter R_GPIO_OUT0 write access. Typi-<br>cally, there is no reason for using register<br>R_RAM_ADDR, so that any write access to<br>register R_GPIO_OUT0 causes no problem.                                                                                                                                                                                                                                                                       |  |
| 0x49            | _           | 0x09           | R_RAM_CTRL   | Address 0x49 is not used for write access.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 0x4A            | R_GPIO_EN0  | 0x0A           | _            | Counterregister 0x0A is not available.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| 0x4B            | _           | 0x0B           | R_FIRST_FIFO | Address 0x4B is not used for write access.                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 0x4C            | R_GPIO_SEL  | 0x0C           | R_FIFO_THRES | Register R_GPIO_SEL should be writ-<br>ten during chip initialization. Typically,<br>there is no need to write R_GPIO_SEL<br>later once more. If necessary, regis-<br>ter R_FIFO_THRES must be rewritten<br>afterwards and unwanted FIFO fill<br>levels might be reported in registers<br>R_FILL_BL0R_FILL_BL3. Software<br>should always check the actual FIFO fill<br>level before writing or reading FIFO bytes<br>and should not rely on the expected FIFO<br>fill level threshold. |  |
|                 |             |                |              | (continued on next page)                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

 Table 13.2: Detailed register list and work-around description



| Table 13.2: Detailed registe | r list and work-around description |
|------------------------------|------------------------------------|
|------------------------------|------------------------------------|

| 1  | 1         | C    | •        |       |
|----|-----------|------|----------|-------|
| (( | continued | from | previous | page) |

| ······                       | Writes also to                                                                         |                | Remark                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|------------------------------|----------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0x4D R_SU_LED_CTRL           | LED_CTRL 0x0D R_FIFO_MD Re<br>be<br>Ty<br>R_<br>net<br>act<br>lov<br>thi<br>act<br>str |                | Register R_SU_LED_CTRL should<br>be written during chip initialization.<br>Typically, there is no need to write<br>R_SU_LED_CTRL later once more. If<br>necessary in particular applications, write<br>access to R_SU_LED_CTRL is only al-<br>lowed when no FIFO is in use because<br>this destroys the overall FIFO setup. Write<br>access to this pair of registers must fulfill<br>strong timing constraints as follows: |  |
|                              |                                                                                        |                | R_FIFO_MD.                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
|                              |                                                                                        |                | 2. Initiate a global software reset to accept this setting.                                                                                                                                                                                                                                                                                                                                                                 |  |
|                              |                                                                                        |                | <ul> <li>3. Configure R_SU_LED_CTRL<br/>within a not-busy phase<br/>(V_BUSY = '0' in register<br/>R_STATUS). This write access<br/>is not allowed while V_BUSY = '1'!</li> </ul>                                                                                                                                                                                                                                            |  |
|                              |                                                                                        |                | <ol> <li>Re-write R_FIFO_MD within the<br/>same not-busy phase. As the<br/>FIFO setup is evaluated only dur-<br/>ing busy phases, it is important to<br/>restore the value immediately after<br/>R_SU_LED_CTRL write access.</li> </ol>                                                                                                                                                                                     |  |
| 0x4E –<br>0x4F –             | 0x0E<br>0x0F                                                                           | A_INC_RES_FIFO | Addresses 0x4E and 0x4F are not used for write access.                                                                                                                                                                                                                                                                                                                                                                      |  |
| 0x50 R_PLL_CTRL              | 0x10                                                                                   | R_SLOT         | Typically, register R_PLL_CTRL is written<br>during initialization. R_SLOT should be<br>written afterwards.<br>Applications that use the PLL's en-<br>able/disable function should ensure that<br>PCM time slot selection with register<br>R_SLOT and following access to PCM<br>slot array registers is not interrupted by<br>R_PLL_CTRL write access.                                                                     |  |
| 0x51 R_PLL_P                 | 0x11                                                                                   | R_MISC_IRQMSK  | It is strongly recommended to write registers<br>B PIL P. B PIL N and B PIL S dur-                                                                                                                                                                                                                                                                                                                                          |  |
| 0x52 R_PLL_N<br>0x53 R_PLL_S | 0x12<br>0x13                                                                           | R_SU_IRQMSK    | ing initialization only. The counterpart reg-<br>isters R_MISC_IRQMSK, R_SU_IRQMSK<br>and R_IRQ_CTRL should be initialized af-<br>terwards to avoid unwanted interrupt gener-<br>ation, interrupt suppression or unwanted in-<br>terrupt controller behaviour.                                                                                                                                                              |  |



(continued from previous page)

| Table 13.2: Do | etailed register | list and wo | ork-around | description |
|----------------|------------------|-------------|------------|-------------|
|----------------|------------------|-------------|------------|-------------|

| Write access to |   | Writes also to |                      | Remark                              |  |  |
|-----------------|---|----------------|----------------------|-------------------------------------|--|--|
| 0x54            | _ | 0x14           | R_PCM_MD0            | Addresses 0x540x5F are not used for |  |  |
| 0x55            | _ | 0x15           | (11 multi-registers) | write access.                       |  |  |
| 0x57            | _ | 0x17           | R_SU_SYNC            |                                     |  |  |
| 0x58            | _ | 0x18           | _                    |                                     |  |  |
| 0x59            | _ | 0x19           | _                    |                                     |  |  |
| 0x5A            | _ | 0x1A           | R_TI_WD              |                                     |  |  |
| 0x5B            | _ | 0x1B           | R_BERT_WD_MD         |                                     |  |  |
| 0x5C            | _ | 0x1C           | _                    |                                     |  |  |
| 0x5D            | _ | 0x1D           | _                    |                                     |  |  |
| 0x5E            | _ | 0x1E           | R_PWM_CFG            |                                     |  |  |
| 0x5F            | _ | 0x1F           | _                    |                                     |  |  |



### References

- [1] Cologne Chip AG. *DIGICC<sup>TM</sup> PLL Technology*, November 2004.
- [2] Cologne Chip AG. C3-PLL-2– Phase-locked Loop (PLL) Frequency Synthesizer IP Core, June 2005.
- [3] Electronic Manufacturing Industry Association of Germany, Information & Communication Technology Group (ZVEI Zentralverband Elektrotechnik, Fachverband Informations- und Kommunikationstechnik (I+K Forum)). ZVEI Documentation DKZ-N; Interfaces and signaling protocols for ISDN telecommunication installations. (only available in German under title: ZVEI-Dokumentation DKZ-N; Schnittstellen und Signalisierungsprotokolle für Telekommunikationsanlagen im ISDN), Mai 1989. Volume IV: DKZ-N part 1.2, DKZ-N2 part 2.2.
- [4] European Telecommunications Standards Institute. *Technical Basis for Regulation (TBR 3):* Integrated Services Digital Network (ISDN); Attachment requirements for terminal equipment to connect to an ISDN using ISDN basic access.
- [5] European Telecommunications Standards Institute. *Technical Basis for Regulation (TBR 4):* Integrated Services Digital Network (ISDN); Attachment requirements for terminal equipment to connect to an ISDN using ISDN primary rate access.
- [6] Infineon Technologies. *PEB 2096 Data Sheet; ICs for Communications: Octal Transceiver for Upn Interfaces (OCTAT-P)*, 2.1 edition, April 1999.
- [7] Siemens AG. ICs for Communication. IOM<sup>®</sup>-2 Interface Reference Guide, 3 1991.
- [8] Telecommunication Standardization Sector of International Telecommunication Union (ITU). ITU-T V.27: Data communication over the telephone network; 4800 bits per second MODEM with manual equalizer standardized for use on leased telephone-type circuits, 1988, 1993.
- [9] Telecommunication Standardization Sector of International Telecommunication Union (ITU). ITU-T I.430: Integrated services digital network (ISDN); ISDN user-network interfaces. Basic user-network interface – Layer 1 specification, November 1995.
- [10] Telecommunication Standardization Union (ITU). O.151: Error performance measuring equipment operating at the primary rate and above. In *Specification of measurement equipment*. ITU-T (Telecommunication Standardization Sector of ITU), 1992.
- [11] Telecommunication Standardization Union (ITU). O.150: Equipment for the measurement of digital and analogue/digital parameters. In *General requirements for instrumentation for performance measurements on digital transmission equipment*. ITU-T (Telecommunication Standardization Sector of ITU), 1996.



## List of register and bitmap abbreviations

This list shows all abbreviations which are used to define the register and bitmap names. Appended digits are not shown here except they have a particular meaning.

| 16KHZ | 16 kHz                 | CHANNEL | HFC-channel                        | Е      | E-channel           |
|-------|------------------------|---------|------------------------------------|--------|---------------------|
|       |                        | CHIP    | microchip                          | ECH    | error counter, high |
| 2KHZ  | 2 kHz                  | CI      |                                    |        | byte                |
|       |                        |         | Command/Indication                 | ECL    | error counter, low  |
| AB    | A/B-bit                |         | (C/I channel of the GCI interface) |        | byte                |
| ABO   | abort                  | CIE     | 6 bit C/L channel                  | EN     | enable              |
| ACT   | active, activation     | 010     | length                             | END    | end                 |
| ADDR  | address                | CIBM    | configuration.                     | ERR    | error               |
| ADJ   | adjust                 |         | interrupt and reset                | EV     | event               |
| AF0   | alternative frame      | CLK     | clock                              | EXCHG  | exchange            |
|       | synchronization        | CLKO    | clock output                       | EXP    | expired             |
|       | signai                 | CNT     | counter                            | -      |                     |
| AUTO  | automatic              | CNTH    | counter, high byte                 |        | F-counter           |
| R1    | B1 channel             | CNTL    | counter, low byte                  | FU     | synchronization     |
| B10   | B1 and                 | CON     | connection settings                |        | signal              |
| DIZ   | B1- and<br>B2-channels | CONT    | contention                         | F1     | F1_1 pin            |
| B2    | B2-channel             | CRC     | cyclic redundancy                  | F1     | F1-counter          |
| BAC   | BAC-bit                |         | check                              | F2     | F2-counter          |
| BERT  | bit error rate test    | CTRL    | control                            | FDIR   | direction           |
| BIT   | bit                    |         |                                    |        | (FIFO-related)      |
| BL    | block                  | D       | D-channel                          | FIFO   | FIFO                |
| BUSY  | busy                   | DATA    | data                               | FILL   | fill level          |
| 5001  | ousy                   | DC      | DC-balancing bit                   | FIRST  | first               |
| с     | command bits of        | DF      | data flow                          | FLOW   | flow                |
| -     | the C/I-channel        | DIR     | direction                          | FNUM   | number              |
| C2I   | C2 clock input         | DLL     | double last look                   |        | (FIFO-related)      |
|       | (PCM bit clock)        |         | criterion                          | FR     | frame               |
| C2O   | C2 clock output        | DLY     | delay                              | FREEZE | freeze              |
|       | (PCM bit clock)        | DLYH    | delay, high byte                   | FRQ    | frequency           |
| C4    | C4IO clock (PCM        | DLYL    | delay, low byte                    | FSM    | FIFO sequence       |
|       | double bit clock)      | DONE    | done                               |        | mode                |
| CFG   | configuration          | DR      | data rate                          |        |                     |
| CH    | HFC-channel            | DST     | destination                        | G2     | G2 state            |

#### **XHFC-1SU**



| G3            | G3 state              | MD         | mode                 | REP                | repetition                      |
|---------------|-----------------------|------------|----------------------|--------------------|---------------------------------|
| GCI           | GCI interface         | MISC       | miscellaneous        | RES                | reset                           |
| GLOB          | global                | МІХ        | mixed                | REV                | reverse                         |
| GPIO          | general purpose       | MOD        | modification         | ROT                | Rotator, rotation               |
|               | input/output          | MON        | monitor channel of   | ROUT               | routing                         |
| GRD           | guard                 |            | the GCI interface    | RPT                | repeat                          |
|               |                       | MR         | handshake bit MR     | RV                 | revision                        |
| HDLC          | high-level data link  | MS         |                      | RX                 | receive                         |
|               | control               |            | multiframe/superfran | <sup>1e</sup> RXHS | receiver handshake              |
| HFC           | HDLC FIFO             | MSK        | mask                 | RXR                | receiver ready                  |
| ш             | bigh                  | MSS        |                      |                    |                                 |
|               | high priority. O hits |            | multiframe/superfram | <sup>1e</sup> S    | S-bit                           |
| <b>HPRIU9</b> | nigh priority, 9 bus  | МУ         | handshaka hit MY     | S                  | PLL post-scaler                 |
|               | indication bits of    |            |                      | SCRM               | scrambler                       |
|               | the C/I-channel       | N          | PLL loop factor      | SDIR               | direction                       |
| ICR           | increase              | NEG        | negative             | 0.51               | (slot-related)                  |
| ID            | identifier            | NEXT       | next                 | SEL                | select, selection               |
| IDX           | index                 |            | no inversion         | SEQ                | sequence                        |
| IFF           | inter frame fill      | NO         | no                   | SET                | setup                           |
|               | ignore                |            | no increment         | SG                 | S/G-bit                         |
| IN            | input                 | NDES       | active low reset     | SH                 | shape                           |
| INC           | increment             | NRES<br>NT | NT mode              | SHOH               | shape 0, high byte              |
|               | INFO 0 line           |            | number               | SHOL               | shape 0, low byte               |
| INFOU         | condition (no         | NUM        | number               | SH1H               | shape 1, high byte              |
|               | signal)               | OD         | open drain output    | SH1L               | shape 1, low byte               |
| INIT          | initialization        | OFF        | off                  | SIG                | signal                          |
| INT           | internal              | OFES       | offset               | SL                 | time slot                       |
| INV           | invert, inversion     | 090        | oscillator           | SLIP               | frequency slip                  |
| IRQ           | interrupt             |            | output               | SLOI               | time slot                       |
| IRQMSK        | interrupt mask        | OVIEW      | overview             | SLOW               | slow                            |
| IRQSTA        | interrupt status      | OVIEW      | overview             | SMPL               | sample                          |
|               | -                     | Р          | PLL predivider       | SNUM               | (slot-related)                  |
| LD            | load                  | PAT        | pattern              | 50                 | S/O-bits                        |
| LED           | Light emitting        | PCM        | pulse code           | SBAM               | SRAM                            |
|               | diode                 |            | modulation           | SBC                | source                          |
| LEN           | length                | PLL        | phase locked loop    | SRES               | software reset                  |
| LO            | low                   | POL        | polarity             | SSYNC              | single                          |
| LOCK          | locked                | PROC       | processing           |                    | synchronization                 |
| LOOP          | loop                  | PU         | pulse                |                    | pulse                           |
| LOST          | frame data lost       | PULSE      | pulse                | ST                 | S/T interface                   |
| LPRIO         | low priority          | PWM        | pulse width          | STA                | state, status                   |
| LPRIO11       | low priority, 11 bits |            | modulation           | START              | start                           |
|               |                       |            |                      | STATUS             | status                          |
| Μ             | M-bit                 | RAM        | RAM                  | STIO               | STIO pins                       |
| Μ             | divider value M       | RD         | read                 | STOP               | stop                            |
| MAN           | manual                | RDY        | ready                | STR                | strict                          |
| MAX           | maximum               | REG        | register             | STUP               | S/T / U <sub>p</sub> interface) |

### XHFC-1SU



| SU<br>SUBCH<br>SWAP<br>SYNC<br>SYNCI | Universal ISDN<br>Port (combined S/T<br>and U <sub>p</sub> interface)<br>subchannel<br>swap<br>synchronize,<br>synchronization<br>synchronization<br>input signal | TI<br>TRI<br>TRP<br>TS<br>TST<br>TX<br>TXHS<br>TXR | timer<br>tristate<br>transparent<br>time step<br>test<br>transmit<br>transmitter<br>handshake<br>transmitter ready | USE<br>VAL<br>VIO<br>WAIT<br>WAK<br>WD<br>WB | use, usage<br>value<br>code violation<br>wait<br>wakeup<br>watchdog timer<br>write |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------|
| T<br>T2<br>THRES                     | T-bits<br>S/T timer T2<br>threshold                                                                                                                               | UNIDIR<br>UP<br>USAGE                              | unidirectional<br>U <sub>p</sub> interface<br>usage                                                                | Z1<br>Z2                                     | Z1-counter<br>Z2-counter                                                           |

### Index of register and bitmap names

Index entries are sorted by name. Pages of the register tables are printed in bold type.

A\_CHANNEL Ch. 2: 45 Ch. 3: 82, 84, 86, 93, 95–97, 99, 101, 103, 104, 106, 107, 119, 120, 122, 123 Ch. 4: 150 A\_CH\_MSK Ch. 2: 45 Ch. 3: 86, 87, 94, 101, 102, 108, 109, 113–116, 118, 119, 121, 122 Ch. 4: 136, 146 A CON HDLC Ch. 2: 45 Ch. 3: 77, 79, 86, 87, 89–91, 94-97, 101, 102, 104–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 126, 128, 131, 147, 152 Ch. 9: 292 A F1 Ch. 3: 86 Ch. 4: 138 A F2 Ch. 3: 86 Ch. 4: 139 A\_FIFO\_CTRL Ch. 2: 45 Ch. 3: 86, 101 Ch. 4: 140, 147, 152 Ch. 8: 272, 275 Ch. 9: 302, 310-313 A\_FIFO\_DATA Ch. 3: 86 Ch. 4: 128, 145

A\_FIFO\_DATA\_NOINC Ch. 3: 86 Ch. 4: 128, 131, 145 A\_FIFO\_SEQ Ch. 2: 45 Ch. 3: 86, 101, 103, 104, 106, 107 Ch. 4: 151 A\_FIFO\_STA Ch. 4: 136, 140, 153 A\_INC\_RES\_FIFO Ch. 13: 340 Ch. 3: 86 Ch. 4: 126, 127, 129, 131, 136 Ch. 9: 309 A\_SL\_CFG Ch. 2: 45 Ch. 3: 82, 84, 89–92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 213–215, 238, 240, 262, 266 A\_SUBCH\_CFG Ch. 2: 45 Ch. 3: 86, 87, 93, 94, 101, 102, 108, 109, 113, 114, 116, 117, 119–123 Ch. 4: 132, 146, **149** A USAGE Ch. 4: 141 A\_Z1 Ch. 3: 86 Ch. 4: 138 A Z2 Ch. 3: 86 Ch. 4: 138

R\_B1\_RX Ch. 5: 159, 162, 177, 178, 186, 208 R\_B1\_TX Ch. 5: 159, 177, 186, 200 R\_B2\_RX Ch. 5: 159, 162, 177, 178, 186, 208 R\_B2\_TX Ch. 5: 159, 177, 186, 200 R BAC S TX Ch. 5: 159, 177, 186, 192, 194, 202 **R\_BERT\_ECH** Ch. 8: 272, 275, 277, 278 **R\_BERT\_ECL** Ch. 8: 272, 275, 277, 278 **R\_BERT\_STA** Ch. 6: 220, 258 Ch. 8: 272, 275, 277 R\_BERT\_WD\_MD Ch. 13: 341 Ch. 8: 272, 276 Ch. 9: 297 R\_CHIP\_ID Ch. 2: 72 R\_CHIP\_RV Ch. 2: 72 **R** CIRM Ch. 4: 126 Ch. 9: 280, 290, 298 R\_CI\_RX Ch. 6: 235, 264 R CI TX Ch. 6: 236, 259 R\_CLK\_CFG

Ch. 9: 280, 284, 300 **R** CTRL Ch. 2: 70 Ch. 9: 280 R\_D\_RX Ch. 5: 159, 162, 177, 178, 186, 198, 206, 209, 210 **R D TX** Ch. 5: 159, 177, 186, 192, 194. 201 R E RX Ch. 5: 159, 161, 162, 177, 178, 186, 198, 206, 209, 210 **R\_F0\_CNTH** Ch. 6: 263 **R F0 CNTL** Ch. 6: 263 **R** FIFO Ch. 3: 79, 84-86, 89-91, 93, 95-97, 99, 101, 102, 104–106, 109, 113–123 Ch. 4: 126, 130, 131, 136, **137**, 138–141, 145–152 **R FIFO BLO IRQ** Ch. 4: 152 Ch. 9: 292, 305, 310 **R\_FIFO\_BL1\_IRQ** Ch. 9: 305, 311 **R\_FIFO\_BL2\_IRQ** Ch. 9: 305, 312 R\_FIFO\_BL3\_IRQ Ch. 4: 152 Ch. 9: 292, 305, 310, 313 **R FIFO MD** Ch. 13: 338, 340 Ch. 3: 85, 93, 99 Ch. 4: 128, 133, 135, 137 **R FIFO THRES** Ch. 13: 338, 339 Ch. 4: **134**, 141–144 **R FILL BLO** Ch. 13: 339 Ch. 4: 141 **R FILL BL1** Ch. 4: 142 **R FILL BL2** Ch. 4: 143 R\_FILL\_BL3

Ch. 13: 339 Ch. 4: 144 **R FIRST FIFO** Ch. 13: 339 Ch. 3: 99-103 Ch. 4: 127, 133 **R FSM IDX** Ch. 3: 86, 99, 101, 103, 104, 106, 107 Ch. 4: 137 **R GCI CFG0** Ch. 6: 235–238, 240, 260 **R GCI CFG1** Ch. 6: 238, 240, 261, 262 **R GCI STA** Ch. 6: 236, 244, 265 **R GPIO EN0** Ch. 10: 325 Ch. 13: 339 R\_GPIO\_EN1 Ch. 10: 316, 322, 323 R\_GPIO\_EN2 Ch. 10: 323, 324 **R\_GPIO\_IN0** Ch. 10: 316, 329 R\_GPIO\_IN1 Ch. 10: 316, 328 **R GPIO IN2** Ch. 10: 328 **R\_GPIO\_OUT0** Ch. 10: 324 Ch. 13: 338, 339 **R\_GPIO\_OUT1** Ch. 10: 321 **R\_GPIO\_OUT2** Ch. 10: 323 **R\_GPIO\_SEL** Ch. 10: 316, 326 Ch. 13: 338, 339 **R\_GPIO\_SEL\_BL** Ch. 10: 323 **R INT DATA** Ch. 2: 45, 73 **R\_IRQ\_CTRL** Ch. 13: 338, 340 Ch. 4: 152 Ch. 9: 291, 292, 302, 310-313 **R\_IRQ\_OVIEW** 



Ch. 9: 292, 294, 305, 309 **R\_MISC\_IRQ** Ch. 6: 236 Ch. 9: 294–296, 301, 306, 307, 309 **R MISC IROMSK** Ch. 13: 338, 340 Ch. 5: 208 Ch. 6: 235, 236 Ch. 9: 294-296, 301, 307 R\_MON\_RX Ch. 6: 235, 236, 244, 265 Ch. 9: 296 **R MON TX** Ch. 6: 236, 241, 242, 244, 262, 265 Ch. 9: 295 R MSS0 Ch. 6: 227, 229–231, 246, 249 R MSS1 Ch. 5: 192 Ch. 6: 229, 246, 255 R MS DF Ch. 5: 192, 198, 209, 210 R MS RX Ch. 5: 157, 161, 167, 176, 177, 183, 206, 209, 210 R MS TX Ch. 5: 157, 161, 162, 167, 176-178, 183, 194, 198, 201, 202, 206 R\_PCM\_MD0 Ch. 13: 341 Ch. 6: 212, 215, 231–233, 238, 240, 246, 247–249, 251, 253, 255-257 R\_PCM\_MD1 Ch. 6: 212, 214, 220, 245, 246, 251, 253, 263, 266 R\_PCM\_MD2 Ch. 6: 215, 220, 222, 246, 253 **R PLL CTRL** Ch. 13: 338, 340 Ch. 9: 286, 304 R PLL N Ch. 13: 338, 340 Ch. 9: 314

R\_PLL\_P Ch. 13: 338, 340 Ch. 9: 314 R\_PLL\_S Ch. 13: 338, 340 Ch. 9: 314 **R\_PLL\_STA** Ch. 9: 313 R\_PWM0 Ch. 7: 268, 269 R PWM1 Ch. 7: 268, 269, 270 **R PWM CFG** Ch. 13: 341 Ch. 7: 268, 269 R PWM MD Ch. 7: 268, 270 Ch. 9: 295, 309 **R RAM ADDR** Ch. 13: 338, 339 Ch. 2: 71, 74 **R RAM CTRL** Ch. 13: 339 Ch. 2: 71, 74 **R RAM DATA** Ch. 2: 45, 71, 74 **R\_RAM\_USE** Ch. 2: 72 R SH0H Ch. 6: 232, 233, 246–248, 256 **R SHOL** Ch. 6: 232, 233, 246–248, 256 R SH1H Ch. 6: 233, 246–248, 257 R\_SH1L Ch. 6: 233, 246-248, 256 **R** SLOT Ch. 13: 338, 340 Ch. 3: 82, 84, 89–92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 238, 240, **245**, 262, 266 R SL MAX Ch. 6: 263 **R SL SELO** Ch. 6: 232, 246, 247 R\_SL\_SEL1

Ch. 6: 232, 233, 246, 247, 248 R SL SEL7 Ch. 2: 70 Ch. 5: 166, 182 Ch. 6: 246, 248 **R STATUS** Ch. 13: 340 Ch. 4: 127 Ch. 5: 186, 200–202, 208-210 Ch. 6: 215 Ch. 9: 290, 306, 307, 309 **R ST CTRL3** Ch. 5: 190, 195, 196 R SU CLK DLY Ch. 5: 158, 163, 167, 179, 183, 199 R\_SU\_CTRL0 Ch. 5: 159, 167, 176, 183, 189, 193, 207 R\_SU\_CTRL1 Ch. 4: 127 Ch. 5: 163, 164, 167, 180, 182, 183, 191 R\_SU\_CTRL2 Ch. 5: 159, 167, 169, 176, 183, 189, 192 **R SU DLYH** Ch. 5: 167, 183, 204, 205 R\_SU\_DLYL Ch. 5: 167, 183, 204, 205 **R\_SU\_IRQ** Ch. 5: 167, 183, 186 Ch. 9: 291, 301, 306, 308 **R\_SU\_IRQMSK** Ch. 13: 338, 340 Ch. 5: 186 Ch. 9: 291, 301, 308 **R SU LED CTRL** Ch. 10: 320, 327 Ch. 13: 338, 340 R\_SU\_RD\_STA Ch. 5: 163, 167, 179, 182, 183, 188, 203 R SU STA Ch. 5: 207 Ch. 9: 294, 307 **R\_SU\_SYNC** 



Ch. 13: 341 Ch. 6: 220, 253, 258 R\_SU\_WR\_STA Ch. 5: 163, 164, 167, 179, 180, 182, 183, 188, 191, 203 R TI WD Ch. 13: 341 Ch. 9: 294, 297, 303 **R UP CTRL3** Ch. 5: 182, 195, 196 V\_ABO\_DONE Ch. 4: 136, 140 V ADDR INC Ch. 2: 71 V ADDR RES Ch. 2: 71 V AUTO SYNCI Ch. 6: 221, 258 V\_AUTO\_WD\_RES Ch. 8: 276 Ch. 9: 297 V\_B12\_SWAP Ch. 5: 161, 162, 177, 178, 191 V B1 RX Ch. 5: 208 V\_B1\_RX\_EN Ch. 5: 159, 162, 176, 178, 192 V B1 TX Ch. 5: 200 V\_B1\_TX\_EN Ch. 5: 159, 161, 176, 177, 189 V B2 RX Ch. 5: 208 V\_B2\_RX\_EN Ch. 5: 159, 162, 176, 178, 192 V B2 TX Ch. 5: 200 V B2 TX EN Ch. 5: 159, 161, 176, 177, 189 V BAC D Ch. 5: 161, 191 V\_BAC\_NINV Ch. 5: 161, 177, 198

V\_BAC\_S\_SEL Ch. 5: 161, 177, 192, 198 V\_BAC\_TX Ch. 5: 202 V\_BERT\_ECH Ch. 8: 274, 278 V\_BERT\_ECL Ch. 8: 274, 277 V BERT EN Ch. 4: 152 Ch. 8: 272-275 V\_BERT\_ERR Ch. 8: 272, 273, 276 V\_BERT\_INV\_DATA Ch. 8: 274, 275, 277 V\_BERT\_SYNC Ch. 8: 272, 274, 277 V BIT CNT Ch. 3: 108–111, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 146, 149 Ch. 8: 272-275 **V BUSY** Ch. 13: 340 Ch. 4: 127 Ch. 9: 290, 309 V\_C2I\_EN Ch. 6: 215, 221, 222, 253 V\_C2O\_EN Ch. 6: 221, 222, 253 V C4 POL Ch. 6: 221, 246 V\_CHIP\_ID Ch. 2: 72 V CHIP RV Ch. 2: 72 V\_CH\_FDIR Ch. 3: 84, 93, 95–97, 103, 104, 106, 107, 119, 120, 122, 123 Ch. 4: 150 V CH FNUM Ch. 3: 84, 93, 95–97, 103, 104, 106, 107, 119, 120, 122, 123 Ch. 4: 150 V CH MSK Ch. 3: 112–114, 116, 119, 122

Ch. 4: 146 V CH SDIR Ch. 3: 82, 84, 89-92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 238, 240, 266 V CH SNUM Ch. 3: 82, 84, 89-92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 238, 240, 266 V CI IRQ Ch. 6: 236 Ch. 9: 294, 307 V\_CI\_IRQMSK Ch. 6: 235, 236 Ch. 9: 294, 301 V\_CLKO\_HI Ch. 9: 280, 281, 284, 300 V CLKO OFF Ch. 9: 280, 281, 284, 300 V\_CLKO\_PLL Ch. 9: 280, 281, 284, 300 V\_CLK\_F1 Ch. 9: 280, 281, 284, 300 V\_CLK\_OFF Ch. 9: 280, 281, 298 V CLK PLL Ch. 9: 280, 281, 300 V\_DATA\_FLOW Ch. 3: 77, 79-81, 89-91, 95-97, 104-106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 148 V\_DF\_MD Ch. 3: 85, 93, 99 Ch. 4: 135, 137 V D RES Ch. 4: 127 Ch. 5: 161, 177, 191 V D RX Ch. 5: 209 V D RX AB Ch. 5: 209 V D RX S Ch. 5: 209 V D RX SG Ch. 5: 209 V D TX Ch. 5: 201

V\_D\_TX\_BAC Ch. 5: 201 V D TX S Ch. 5: 201, 202 V\_EV\_TS Ch. 9: 294, 303 V E RX Ch. 5: 210 V\_E\_RX\_AB Ch. 5: 210 V E RX S Ch. 5: 210 V E RX SG Ch. 5: 210 V F0 CNTH Ch. 6: 263 V F0 CNTL Ch. 6: 263 V\_F0\_LEN Ch. 6: 215, 221, 228, 230, 231, 246 V\_F0\_NEG Ch. 6: 221, 246 V F1 Ch. 4: 138 **V\_F2** Ch. 4: 139 V FIFO0 RX IRQ Ch. 9: 293, 310 V\_FIFO0\_TX\_IRQ Ch. 9: 293, 310 V\_FIFO10\_RX\_IRQ Ch. 9: 312 V\_FIFO10\_TX\_IRQ Ch. 9: 312 V\_FIFO11\_RX\_IRQ Ch. 9: 312 V\_FIFO11\_TX\_IRQ Ch. 9: 312 V\_FIFO12\_RX\_IRQ Ch. 9: 313 V\_FIFO12\_TX\_IRQ Ch. 9: 313 V\_FIFO13\_RX\_IRQ Ch. 9: 313 V FIFO13 TX IRQ Ch. 9: 313 V FIFO14 RX IRQ Ch. 9: 293, 313

oane

V\_FIFO14\_TX\_IRQ Ch. 9: 313 V\_FIFO15\_RX\_IRQ Ch. 9: 293, 313 V\_FIFO15\_TX\_IRQ Ch. 9: 293, 313 V\_FIFO1\_RX\_IRQ Ch. 9: 293, 310 V\_FIFO1\_TX\_IRQ Ch. 9: 293, 310 V\_FIFO2\_RX\_IRQ Ch. 9: 310 V FIFO2 TX IRQ Ch. 9: 293, 310 V\_FIFO3\_RX\_IRQ Ch. 9: 310 V\_FIFO3\_TX\_IRQ Ch. 9: 310 V\_FIFO4\_RX\_IRQ Ch. 9: 311 V FIFO4 TX IRQ Ch. 9: 311 V\_FIFO5\_RX\_IRQ Ch. 9: 311 V\_FIFO5\_TX\_IRQ Ch. 9: 311 V\_FIFO6\_RX\_IRQ Ch. 9: 311 V\_FIFO6\_TX\_IRQ Ch. 9: 311 V FIFO7 RX IRQ Ch. 9: 311 V\_FIFO7\_TX\_IRQ Ch. 9: 311 V\_FIFO8\_RX\_IRQ Ch. 9: 312 V\_FIFO8\_TX\_IRQ Ch. 9: 312 V\_FIFO9\_RX\_IRQ Ch. 9: 312 V\_FIFO9\_TX\_IRQ Ch. 9: 312 V\_FIFO\_BL0\_IRQ Ch. 9: 292, 293, 305 V\_FIFO\_BL1\_IRQ Ch. 9: 293, 305 V\_FIFO\_BL2\_IRQ Ch. 9: 293, 305 V\_FIFO\_BL3\_IRQ

Ch. 9: 292, 293, 305 V\_FIFO\_DATA Ch. 4: 145 V\_FIFO\_DATA\_NOINC Ch. 4: 145 V\_FIFO\_DIR Ch. 3: 79, 81, 84, 89–91, 93, 95-97, 104-106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 137, 148 V\_FIFO\_ERR Ch. 4: 136, 140, 153 V\_FIFO\_IRQ Ch. 3: 87, 89-91, 94-97, 102–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 126, 147, 148, 152 Ch. 9: 292, 310-313 V\_FIFO\_IRQMSK Ch. 4: 152 Ch. 9: 302, 310–313 V\_FIFO\_IRQSTA Ch. 9: 310 V\_FIFO\_IRQ\_EN Ch. 4: 152 Ch. 9: 292, 293, 302, 310-313 V\_FIFO\_LPRIO Ch. 2: 70 V\_FIFO\_MD Ch. 4: 128, 135 V\_FIFO\_NUM Ch. 3: 84, 89-91, 95-97, 104–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 137 V\_FILL\_FIFO0\_RX Ch. 4: 141 V\_FILL\_FIFO0\_TX Ch. 4: 141 V\_FILL\_FIFO10\_RX Ch. 4: 143 V\_FILL\_FIFO10\_TX Ch. 4: 143 V\_FILL\_FIFO11\_RX Ch. 4: 143 V\_FILL\_FIF011\_TX Ch. 4: 143





coloane

Chip

Ch. 4: 143 V\_FILL\_FIFO9\_TX Ch. 4: 143 V\_FIRST\_FIFO\_DIR Ch. 3: 101, 103 Ch. 4: 127, 133 V\_FIRST\_FIFO\_NUM Ch. 3: 101, 103 Ch. 4: 127, 133 V FR ABO Ch. 4: 140, 153 V\_G2\_G3 Ch. 5: 163, 182, 203 V\_G2\_G3\_EN Ch. 5: 163, 164, 180, 182, 191 V GCI ABO Ch. 6: 244, 265 V\_GCI\_C Ch. 6: 236, 259 V GCI EN Ch. 6: 235, 238, 240, 261 V\_GCI\_I Ch. 6: 236, 264 V\_GCI\_MR Ch. 6: 265 V\_GCI\_MX Ch. 6: 265 V\_GCI\_RX Ch. 6: 265 V GCI SL Ch. 6: 234, 235, 238, 240, 262 V\_GCI\_SWAP\_RXHS Ch. 6: 237, 240, 260, 261 V\_GCI\_SWAP\_STIO Ch. 6: 237, 240, 260, 261 V\_GCI\_SWAP\_TXHS Ch. 6: 237, 240, 260, 261 V\_GLOB\_IRQ\_EN Ch. 9: 291, 302 V GPIO BL0 Ch. 10: 317, 318, 323 V\_GPIO\_BL1 Ch. 10: 323 V GPIO EN0 Ch. 10: 320, 325 V GPIO EN1 Ch. 10: 325

V\_GPIO\_EN10 Ch. 10: 322 V GPIO EN11 Ch. 10: 322 V\_GPIO\_EN12 Ch. 10: 322 V\_GPIO\_EN13 Ch. 10: 322 V\_GPIO\_EN14 Ch. 10: 322 V\_GPIO\_EN15 Ch. 10: 322 V GPIO EN16 Ch. 10: 317, 324 V\_GPIO\_EN17 Ch. 10: 324 V GPIO EN18 Ch. 10: 324 V\_GPIO\_EN19 Ch. 10: 324 V GPIO EN2 Ch. 10: 325 V\_GPIO\_EN3 Ch. 10: 325 V\_GPIO\_EN4 Ch. 10: 325 V\_GPIO\_EN5 Ch. 10: 325 V\_GPIO\_EN6 Ch. 10: 325 V\_GPIO\_EN7 Ch. 10: 325 V\_GPIO\_EN8 Ch. 10: 316-318, 322 V\_GPIO\_EN9 Ch. 10: 317, 318, 322 V\_GPIO\_IN0 Ch. 10: 320, 329 V\_GPIO\_IN1 Ch. 10: 329 V\_GPIO\_IN10 Ch. 10: 328 V\_GPIO\_IN11 Ch. 10: 328 V\_GPIO\_IN12 Ch. 10: 328 V\_GPIO\_IN13 Ch. 10: 328 V\_GPIO\_IN14

Ch. 10: 328 V\_GPIO\_IN15 Ch. 10: 328 V\_GPIO\_IN16 Ch. 10: 317, 328 V\_GPIO\_IN17 Ch. 10: 328 V\_GPIO\_IN18 Ch. 10: 328 V\_GPIO\_IN19 Ch. 10: 328 V\_GPIO\_IN2 Ch. 10: 329 V GPIO IN3 Ch. 10: **329** V\_GPIO\_IN4 Ch. 10: 329 V GPIO IN5 Ch. 10: 329 V\_GPIO\_IN6 Ch. 10: 329 V\_GPIO\_IN7 Ch. 10: 329 V\_GPIO\_IN8 Ch. 10: 317, 318, 328 V\_GPIO\_IN9 Ch. 10: 317, 318, 328 V GPIO OUTO Ch. 10: 320, 324 V\_GPIO\_OUT1 Ch. 10: 324 V\_GPIO\_OUT10 Ch. 10: 321 V\_GPIO\_OUT11 Ch. 10: 321 V\_GPIO\_OUT12 Ch. 10: 321 V\_GPIO\_OUT13 Ch. 10: 321 V\_GPIO\_OUT14 Ch. 10: 321 V GPIO OUT15 Ch. 10: 321 V\_GPIO\_OUT16 Ch. 10: 317, 323 V GPIO OUT17 Ch. 10: 323 V GPIO OUT18 Ch. 10: 323

oloane

V\_GPIO\_OUT19 Ch. 10: 323 V\_GPIO\_OUT2 Ch. 10: 324 V\_GPIO\_OUT3 Ch. 10: 324 V\_GPIO\_OUT4 Ch. 10: 324 V\_GPIO\_OUT5 Ch. 10: 324 V\_GPIO\_OUT6 Ch. 10: 324 V GPIO OUT7 Ch. 10: 324 V\_GPIO\_OUT8 Ch. 10: 317, 318, 321 V GPIO OUT9 Ch. 10: 317, 318, 321 V GPIO SELO Ch. 10: 316, 320, 326 V GPIO SEL1 Ch. 10: 326 V\_GPIO\_SEL2 Ch. 10: 326 V\_GPIO\_SEL3 Ch. 10: 326 V\_GPIO\_SEL4 Ch. 10: 326 V\_GPIO\_SEL5 Ch. 10: 326 V\_GPIO\_SEL6 Ch. 10: 326 V\_GPIO\_SEL7 Ch. 10: 326 V HDLC TRP Ch. 3: 87, 89–91, 95–97, 103–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 131, 147 Ch. 9: 292 V\_HFC\_RES Ch. 4: 126 Ch. 9: 290, 299 V IDX Ch. 3: 101, 103, 104, 106, 107 Ch. 4: 137 V IFF Ch. 3: 89-91, 95-97,

104–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 128, 147 V\_INC\_F Ch. 4: 129, 131, 136 V\_INT\_DATA Ch. 2: 73 V\_INV\_DATA Ch. 3: 114, 116, 117, 119, 120, 122, 123 Ch. 4: 149 V IRQ POL Ch. 9: 291, 302 V LED ENO Ch. 10: 320, 327 V\_LED\_EN1 Ch. 10: 327 V LED EN2 Ch. 10: 327 V\_LED\_EN3 Ch. 10: 327 V\_LED\_EN4 Ch. 10: 327 V LED EN5 Ch. 10: 327 V\_LED\_ROT Ch. 10: 320, 327 **V LOOP FIFO** Ch. 3: 114, 116, 117, 119, 120, 122, 123 Ch. 4: 149 V\_LOST\_STA Ch. 9: 309 V\_MAN\_SYNC Ch. 6: 220, 221, 258 V\_MISC\_IRQ Ch. 9: 294, 306, 309 V\_MISC\_IRQSTA Ch. 9: 306, 309 V\_MIX\_IRQ Ch. 4: 147, 152 Ch. 9: 292, 310–313 V\_MON\_CI6 Ch. 6: 236, 259, 260, 264 V\_MON\_DLL Ch. 6: 236, 260 V MON END Ch. 6: 236, 242, 260 V\_MON\_RX

Ch. 6: 265 V MON RXR Ch. 6: 236, 244, 265 V\_MON\_RX\_IRQ Ch. 9: 294, 296, 307 V\_MON\_RX\_IRQMSK Ch. 6: 235 Ch. 9: 294, 296, 301 V\_MON\_SLOW Ch. 6: 260 V\_MON\_TX Ch. 6: 262 V MON TXR Ch. 6: 236, 242, 265 V\_MON\_TX\_IRQ Ch. 6: 236 Ch. 9: 294, 295, 307 V MON TX IRQMSK Ch. 6: 236 Ch. 9: 294, 295, 301 V MSS DLY Ch. 6: 228–230, 255 V\_MSS\_MOD Ch. 6: 228, 230, 231, 249 V\_MSS\_MOD\_REP Ch. 6: 228, 230, 249 V\_MSS\_OFFS Ch. 6: 228, 255 V\_MSS\_OUT\_EN Ch. 6: 228, 231, 249 V MSS OUT REP Ch. 6: 228, 231, 249 V\_MSS\_SRC Ch. 6: 228, 229, 250 V\_MSS\_SRC\_EN Ch. 6: 227-229, 249 V\_MSS\_SRC\_GRD Ch. 6: 228, 229, 249 V MS RX Ch. 5: 176, 206 V\_MS\_RX\_RDY Ch. 5: 176, 206 V\_MS\_SSYNC1 Ch. 5: 192 Ch. 6: 228, 255 V MS SSYNC2 Ch. 5: 161, 177, 192 Ch. 6: 255 V\_MS\_TX



Ch. 5: 176, 194, 198, 201, 202 V\_MS\_TX\_RDY Ch. 5: 176, 206 V\_M\_S\_SRC Ch. 5: 161, 177, 198 **V NEXT FIFO DIR** Ch. 3: 103, 104, 106, 107 Ch. 4: 151 V\_NEXT\_FIFO\_NUM Ch. 3: 103, 104, 106, 107 Ch. 4: 151 V NO CRC Ch. 4: 153 **V NO REP** Ch. 4: 153 V NT SYNC Ch. 2: 70 Ch. 6: 221 V\_OSC\_OFF Ch. 2: 70 Ch. 9: 281 V\_PAT\_SEQ Ch. 8: 272–274, 276 **V PCM CLK** Ch. 9: 280, 281, 300 V\_PCM\_DR Ch. 6: 212, 221, 245, 251, 263 V\_PCM\_IDX Ch. 6: 232, 233, 246, 247-249, 251, 253, 255-257 V\_PCM\_INIT Ch. 6: 215 Ch. 9: 290, 309 V\_PCM\_LOOP Ch. 6: 214, 251 V\_PCM\_MD Ch. 4: 128 Ch. 6: 212, 215, 221, 237, 238, 240, 246 V PCM OD Ch. 6: 213, 214, 251, 266 **V PCM RES** Ch. 9: 290, 299 **V PCM SMPL** Ch. 6: 214, 252 V\_PLL\_ADJ

Ch. 6: 220, 221, **251**, 253 **V PLL FREEZE** Ch. 9: 286, 304 V\_PLL\_ICR Ch. 6: 220, 221, 253, 254 **V PLL LOCK** Ch. 9: 286, 313 V PLL M Ch. 9: 286, 304 V PLL MAN Ch. 6: 220-222, 253, 254 V PLL N Ch. 9: 285, 286, 314 **V PLL NRES** Ch. 9: 286, 304 V PLL P Ch. 9: 286, 314 V PLL S Ch. 9: 286, 314 V\_PLL\_TST Ch. 9: 304 V PROC Ch. 5: 186, 200–202, 208 - 210Ch. 9: 307, 309 V\_PROC\_IRQ Ch. 9: 294, 295, 307, 309 **V PROC IROMSK** Ch. 9: 294, 295, 301 V PWM0 Ch. 7: 269 V\_PWM0\_16KHZ Ch. 7: 268, 269 V\_PWM0\_MD Ch. 7: 268, 270 V PWM1 Ch. 7: 270 V\_PWM1\_16KHZ Ch. 7: 268, 269 V PWM1 MD Ch. 7: 268, 270 V\_PWM\_FRQ Ch. 7: 268, 269 V\_RAM\_ADDR0 Ch. 2: 71 V RAM ADDR1 Ch. 2: 71 V RAM DATA Ch. 2: 74



V\_RD\_SYNC\_SRC Ch. 6: 220, 258 Ch. 8: 277 V\_RES\_FIFO Ch. 4: 126, 127, 136 V\_RES\_FIFO\_ERR Ch. 4: 127, 136, 140 V\_RES\_LOST Ch. 4: 136 Ch. 9: 309 V REV Ch. 3: 87, 89-91, 94-97, 103–106, 114, 116, 117, 119, 120, 122, 123 Ch. 4: 131, 137 **V ROUT** Ch. 3: 89-92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 213, 214, 238, 240, 266 V\_SEQ\_END Ch. 3: 101, 103, 104, 106, 107 Ch. 4: 151 V\_SG\_AB\_INV Ch. 5: 162, 178, 198 V\_SH0H Ch. 6: 233, 256 V SHOL Ch. 6: 233, 256 V SH1H Ch. 6: 233, 257 V\_SH1L Ch. 6: 233, 256 V SH SEL0 Ch. 6: 232, 247 V SH SEL1 Ch. 6: 232, 233, 247, 248 V\_SLIP\_IRQ Ch. 9: 294, 307 V\_SLIP\_IRQMSK Ch. 5: 208 Ch. 9: 294. 301 V\_SL\_DIR Ch. 3: 84, 89-92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 238, 240, 245 V SL MAX Ch. 6: 263

V\_SL\_NUM Ch. 3: 84, 89-92, 96, 97, 105, 116, 117, 122, 123 Ch. 6: 238, 240, **245** V\_SL\_SEL0 Ch. 6: 232, 247 V SL SEL1 Ch. 6: 232, 233, 247, 248 V\_SL\_SEL7 Ch. 6: 248 V\_SQ\_T\_DST Ch. 5: 162, 178, 198, 209, 210 V SO T SRC Ch. 5: 161, 177, 198 V\_SRAM\_USE Ch. 2: 72 V SRES Ch. 4: 126 Ch. 9: 290, 298 V\_START\_BIT Ch. 3: 108–111, 114–117, 119, 120, 122, 123 Ch. 4: 149 **V STUP IRQ** Ch. 9: 306 V\_ST\_D\_ACT Ch. 5: 207 V\_ST\_D\_CONT Ch. 5: 207 V\_ST\_D\_HPRIO9 Ch. 5: 207 V\_ST\_D\_LPRIO Ch. 5: 189, 207 V ST D LPRIO11 Ch. 5: 207 V\_ST\_E\_IGNO Ch. 5: 161, 191 V ST E LO Ch. 5: 161, 191 V\_ST\_PULSE Ch. 5: 190, 195 V ST PU CTRL Ch. 5: 161, **190** V ST SEL Ch. 5: 195, 196 V ST SMPL Ch. 5: 199 V\_ST\_SQ\_EN

Ch. 5: 159, 161, 189 V SU 2KHZ Ch. 5: 161, 177, 189, 193 V\_SU\_ACT Ch. 5: 163, 179, 188 V SU AF0 Ch. 5: 207, 208 Ch. 9: 294, 307 V\_SU\_CLK Ch. 2: 70 Ch. 9: 280, 281 V\_SU\_CLK\_DLY Ch. 5: 158, 199 V SU DLYH Ch. 5: 205 V SU DLYL Ch. 5: 204 V SU EXCHG Ch. 5: 161, 167, 169, 177, 183, 193 V SU FR SYNC Ch. 5: 203 V SU INFO0 Ch. 5: 163, 203 V\_SU\_IRQ Ch. 5: 186 Ch. 9: 292, 301, 308 **V SU IROMSK** Ch. 5: 186 Ch. 9: 292, 301 V SU LD STA Ch. 5: 163, 179, 182, 188 V\_SU\_MD Ch. 5: 167, 183, 189 V SU RES Ch. 9: 290, 299 V\_SU\_RX\_VAL Ch. 5: 162, 178, 198, 209, 210V\_SU\_SET\_G2\_G3 Ch. 5: 164, 180, 188, 191 V\_SU\_SET\_STA Ch. 5: 188 V\_SU\_STA Ch. 5: 203 V\_SU\_STOP Ch. 5: 162, 167, 178, 183, 190 V\_SU\_SYNC\_NT



Ch. 5: 167, 183, 192 V SU T2 EXP Ch. 5: 203 V\_SU\_TRI Ch. 5: 161, 167, 177, 183, 193 V SU TST SIG Ch. 5: 161, 177, 189, 193 V\_SYNC\_OUT1 Ch. 6: 221. 253 V\_SYNC\_OUT2 Ch. 6: 221, 253, 254 **V SYNC SEL** Ch. 6: 220, 221, 258 **V SYNC SRC** Ch. 6: 220, 221, 253 V S TX Ch. 5: 201, 202 V\_THRES\_RX Ch. 4: 134, 141-144 V THRES TX Ch. 4: 134, 141–144 V\_TI\_IRQ Ch. 9: 294, 307 V\_TI\_IRQMSK Ch. 9: 294, 301 V\_UNIDIR\_MD Ch. 4: 128, 135 V\_UNIDIR\_RX Ch. 4: 128, 135 V UP DC OFF Ch. 5: 177, 196 V\_UP\_DC\_STR Ch. 5: 177, 196 V\_UP\_RPT\_PAT Ch. 5: 177, 183, 196 V\_UP\_SCRM\_MD Ch. 5: 177, 178, 182, 183, 196 V\_UP\_SCRM\_RX\_OFF Ch. 5: 178, 182, 183, 197 V\_UP\_SCRM\_TX\_OFF Ch. 5: 177, 182, 183, 197 V\_UP\_SEL Ch. 5: 196 V UP S RX Ch. 5: 176, 206 V UP S TX Ch. 5: 176, 194, 198

#### XHFC-1SU

V\_UP\_VIO Ch. 5: 196 V\_USAGE Ch. 4: 141 V\_WAIT\_PROC Ch. 9: 298 V\_WAIT\_REG Ch. 9: 298 V\_WAK\_EN Ch. 7: 270

Ch. 9: 295, 309 V\_WAK\_IRQ Ch. 9: 294, 295, 307 V\_WAK\_IRQMSK Ch. 9: 294, 295, 301 V\_WAK\_STA Ch. 9: 295, 309 V\_WD\_EN Ch. 8: 276 V\_WD\_RES Ch. 8: 276 Ch. 9: 297 V\_WD\_TS Ch. 9: 297, 303 V\_Z1 Ch. 4: 138 V\_Z2 Ch. 4: 138 ologne

hip

## **Index of pin names**

Index entries are sorted by name. Pages of the pin list are printed in bold type.

/CS ALE Ch. 1: 34, 36 Ch. 1: 34, 36 Ch. 1: 34, 39 Ch. 2: 46, 49 Ch. 2: 43, 44, 47, 51-54 D6 Ch. 2: 43, 44, 46, 47, 49, 52, 54 Ch. 1: 34, 36 C2IO /INT Ch. 2: 46, 49 Ch. 1: 34, 35, 37 Ch. 1: 34, 35, 36 D7 Ch. 4: 128 Ch. 2: 43, 57 Ch. 1: 34, 36 Ch. 6: 215, 222, 253 Ch. 4: 152 Ch. 2: 43, 44, 46, 49 C4IO Ch. 9: 291, 301, 302, 305 DN0 Ch. 1: 34, 35, 37 Ch. 1: 35, 36 /IOR Ch. 4: 128 Ch. 2: 57 Ch. 1: 34, 39 Ch. 6: 212, 215, 216, 218, Ch. 2: 43, 44, 47 DN1 220, 222, 224, 229-231, /IOW Ch. 1: 35, 36 234, 237, 246, 251, 256, Ch. 1: 34, 39 Ch. 2: 57 257 Ch. 2: 43, 44, 47 DN2 CLK\_OUT /RES Ch. 1: 35, 36 Ch. 10: 319, 326 Ch. 1: 34, 35, 36 Ch. 2: 57 Ch. 1: 34, 35, 37 Ch. 2: 43, 57 DN3 Ch. 9: 280, 281, 283, 284, Ch. 9: 290 Ch. 1: 35, 36 300 /SPISEL Ch. 2: 57 Ch. 1: 33, 35, 36 D0 Ch. 2: 57, 59-66 F0IO Ch. 1: 34, 36 /WAIT Ch. 1: 34, 35, 37 Ch. 2: 43, 44, 46, 49 Ch. 1: 34, 39 D1 Ch. 4: 126, 128 Ch. 2: 43, 46, 49 Ch. 5: 166, 182, 208 Ch. 1: 34, 36 Ch. 9: 298 Ch. 6: 212, 215, 216, 218, Ch. 2: 46, 49 /WD 220, 222, 224, 227, D2 229-232, 234, 237, 246, Ch. 1: 34, 35, 37 Ch. 1: 34, 36 Ch. 9: 297 250, 263 Ch. 2: 46, 49 Ch. 9: 294 D3 F1\_0 A0 Ch. 1: 34, 36 Ch. 1: 34, 36 Ch. 2: 46, 49 Ch. 10: 319, 326 Ch. 2: 43, 44, 46-51, 53 D4 Ch. 1: 34, 35, 37 ADJ Ch. 6: 232, 247, 256 Ch. 1: 34, 36 Ch. 1: 34, 35, 38 Ch. 2: 46, 49 F1 1 Ch. 5: 168 D5 Ch. 10: 319, 326

Ch. 1: 34, 35, 37 Ch. 6: 232, 248, 256, 257 Ch. 9: 280, 281, 300 GND Ch. 1: 34, 35, 36–39 **GPIO0** Ch. 10: 319, 320, 324-327, 329 Ch. 1: 34, 35, 37 GPIO1 Ch. 10: 319, 320, 324-327, 329 Ch. 1: 34, 35, 37 GPIO10 Ch. 10: 319, 321, 322, 328 Ch. 1: 34, 35, 38 GPIO11 Ch. 10: 316, 319, 321-323, 328 Ch. 1: 34, 35, 38 GPIO12 Ch. 10: 318, 319, 321–323, 328 Ch. 1: 34, 35, 38 GPIO13 Ch. 10: 318, 319, 321, 322, 328 Ch. 1: 34, 35, 38 GPIO14 Ch. 10: 319, 321, 322, 328 Ch. 1: 34, 35, 38 GPIO15 Ch. 10: 319, 321-323, 328 Ch. 1: 34, 35, 38 GPIO16 Ch. 10: 316, 317, 319, 323, 324, 328 Ch. 1: 34, 35, 38 GPIO17 Ch. 10: 316, 319, 323, 324, 328 Ch. 1: 34, 35, 38 GPIO18 Ch. 10: 319, 323, 324, 328 Ch. 1: 34, 35, 38 GPIO19 Ch. 10: 319, 323, 324, 328 Ch. 1: 34, 35, 38 GPIO2

Ch. 10: 319, 320, 324–327, 329 Ch. 1: 34, 35, 37 GPIO3 Ch. 10: 319, 320, 324–327, 329 Ch. 1: 34, 35, 37 GPIO4 Ch. 10: 319, 320, 324-327, 329 Ch. 1: 34, 35, 37 GPIO5 Ch. 10: 319, 320, 324–327, 329 Ch. 1: 34, 35, 37 GPIO6 Ch. 10: 319, 324-326, 329 Ch. 1: 34, 35, 36 GPIO7 Ch. 10: 319, 324-326, 329 Ch. 1: 34, 35, 37 GPIO8 Ch. 10: 316, 317, 319, 321-323, 328 Ch. 1: 34, 35, 39 GPIO9 Ch. 10: 317, 319, 321, 322, 328 Ch. 1: 34, 35, 39 LΑ Ch. 10: 317, 319 Ch. 1: 34, 35, 39 Ch. 5: 168 LΒ Ch. 10: 319 Ch. 1: 34, 35, 38 Ch. 5: 168 MODE0 Ch. 1: 34, 35, 37 Ch. 2: 42-44, 57 Ch. 9: 290 MODE1 Ch. 1: 34, 35, 37 Ch. 2: 42-44, 57 Ch. 9: 290 NC Ch. 1: 34, 35, 38, 39

OSC IN Ch. 1: 34, 35, 37 Ch. 9: 281, 283-285, 300 OSC OUT Ch. 1: 34, 35, 37 Ch. 9: 280, 281, 283 PWM0 Ch. 10: 319, 320, 326 Ch. 1: 34, 35, 37 Ch. 7: 268-270 PWM1 Ch. 10: 319, 326 Ch. 1: 34, 35, 37 Ch. 7: 268-270 R\_A Ch. 10: 317, 319 Ch. 1: 34, 35, 39 Ch. 5: 157, 166-168, 182, 183 R B Ch. 10: 319 Ch. 1: 34, 35, 38 Ch. 5: 157, 166-168, 182, 183 SPI CLK Ch. 1: 35, 39 Ch. 2: 57, 65, 66 SPI\_INV Ch. 1: 35, 39 Ch. 2: 57, 65, 66 SPI RX Ch. 1: 35, 36 Ch. 2: 57, 59, 60, 62-64 SPI TX Ch. 1: 35, 36 Ch. 2: 57, 59-64 STI01 Ch. 10: 319, 326 Ch. 1: 34, 35, 37 Ch. 3: 89-92, 96, 97, 105, 116, 122 Ch. 6: 212–216, 218, 229, 234, 235, 237, 238, 240, 250, 251, 261, 266 STIO2 Ch. 10: 319, 326 Ch. 1: 34, 35, 37



#### XHFC-1SU



Ch. 3: 90–92, 96, 97, 105, 117, 123 Ch. 6: 212–216, 218, 229, 234, 235, 237, 238, 240, 251, 261, 266 SYNC\_I Ch. 1: 34, 35, **36** Ch. 6: 222, 224–226, 229, 250, 253, 254, 258 Ch. 8: 277 SYNC\_O Ch. 10: 319, 326 Ch. 1: 34, 35, **36** Ch. 6: 222–226, 253 T\_A Ch. 10: 317, 319 Ch. 1: 34, 35, **38** Ch. 5: 157, 167, 169, 183 T\_B Ch. 10: 319 Ch. 1: 34, 35, **38** Ch. 5: 157, 167, 169, 183 VDD Ch. 10: 317, 319, 320 Ch. 1: 34, 35, **36–39**, 40 VDD\_SU Ch. 10: 316, 317, 319 Ch. 1: 34, 35, **38** Ch. 5: 169

WAKEUP

Ch. 1: 34, 35, **37** Ch. 2: 70

Ch. 7: 270

Ch. 9: 280, 298, 307, 309




Cologne Chip AG Data Sheet of XHFC-1SU