# CXA16/CXB16 **User Guide** | | | | 医乳头 医多种乳质性 的复数人 | | | |------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | | | | | | | | | 시 하는 항상과 강사 전혀 없다. | 회 후 얼마나 되었다. 얼마나 | | | | | | | 되었다. 그리고 하다 하는 그리지 않는 | | | | | | 그가 네트를 보고하셨다는 것 같아. | 병생들은 나를 하는 생물을 받 | 발과 하기 등 기계 등이 되어 | | | | | 이 등록 어느림을 그림을 당했다. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 그렇는 그 회에 동생들이 되었다. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 현실 시작을 근처로 한다. | | | | | | | | | er af easter of the control c | | | | | | | | | | | | | | The state of s | | | | | | | | | | | 다른하다 하고 왕들이 하고 있다. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 결과에 하는 말이 되었다. | | | | 이번 그를 가는 사람들이 불렀다고 됐다. | 이 사람들 내용을 보고 보고 하였다. | | | | | | 그림으로 하는데 그는 그렇게 돌아왔다. | 내륙 가락한 생물하는 하는 것이다. | | | | | | 그러 어디 사람들 강기 살아온 모양한 | 그렇다 얼마를 살아보다 하다. | | | | | | 어느는 시간에 되는 뭐 하면 근목사회 | | 그는 이 상태를 하고 있는 것은 | | | | | | | | | | | | | | 화물의 일본 이 문화 나도를 | 분인의 하고 얼마나 가게요 | | | | | | 원회 불어받아 작품을 받아? | | | | | | | ##################################### | 그루 시작한 경험을 하고 | | | | | | [11일 : 기존 11일 그리고 12] | | 2001년 1월 1일 | | | | | | [경기] : [경기 : [경기 : 경기 : [경기 [ | | | | | | 보통하는 살이 되어 먹어 되었다. | | | | | | 그 그리 중에 없네 봤다습니다. 그 글 | | | | | | | 그림 사람이 얼굴하다 말하다 그래요. | | raint in an an air seil | | | | | 일반 그는 사람이 없는 이렇게 먹어 있다. | | | | | | | | 늘 계속 물로 되었다. 어린 사람이 | | | | | | 그렇지 뭐까? 생각하다는 이 시간다. | | | | | | | 지수의 희망을 받았다. | | | | | | | 그 걸 가입니다 중요하다. 이 것 | | 그 하는 이 그를 모습니다. | | | | | | | | | | | | 이 마느 그렇게 하느 이렇게 | | | | | | | 그들이 없다면서 하고 있다니까? | | | | | | | | | 함께 그 말이 하는 것이 없다. | \$P\$ 快速 1. 4 1 1 1 1 1 1 1 4 | | | | 기계 보고 그렇게 되었다. | 최근 사람들의 사람들의 보다. | 이 경험을 하는 것도 하지까? | | | | | 그 얼마 얼마나 있다면 하다 하다 하다. | | | | | | | 그리다 "김 교육하네게 시고하였다. | 중점점점이 함께 그리고 살이 하다 | 경기들에 하는 그리 살고 있습니 | | | | | 그 설문을 되고 환경되는 것은 | | | | | | | | 잃어버렸다. 그리 그는 | 실험하다 한 사람은 가득하다 | | | | | | | | | | | 그는 하는 문항 ㅎ 이 없는 화물에 | | | | | | | | | 불량하십시시 등 기계 등 다시 | | | | | | | 요. (1) 1 대통령 시민 (1) - 발표를 보고 있다.<br>연구들 (1) 등 발표하는 보고 하는 기교 중요. (1) | | | | | | | | 불쾌로 발표되었다고요 어 | | | | | 그렇게 그렇게 가라고 가게 걸었다. | 진화계약에는 하는 하면 하다. | 바람들이 보고 되는데 함께 없다. | | | | | | 불의 마음이 많아요 이 같아. | | | | | | | | 사람들의 회장 마음을 하였다. | | | | | | 경험설계 등 기계의 이 사 | | | | | | | 함께서 취임하게 되었습니다. | | | | | | 그 마시의 사고 있는 그렇고 뭐야? | #되워볼레임테크 #임리. | 강치하다고 병장 보통하다. | | | | | 마시다를 걸었습니다. | | | | | | 그 그 그 스 등 등 사람들은 옷을 | | 시간 경기 동안 되는 아니라 그 모르고 있다. | 그렇다 가는 말을 하는데 하는데 그렇게 되었다. | | | | | | 되고 하네티트 하고 휴대로 하다. | | | | | | | | | | | | | | | 기선에 되로 한당하다 | | | | | | | | | A 🔾 🤲 🔐 Alberton | | | 电电阻器 数据证据的证据 多位 | | | | | | | | | | | | | | 가지 않는 그렇게 하고 뭐하는 없어. | | | | | | | | | | | | | | 그러면 그렇지 아름답으로? | | | | | | | | | | | | | | | | | | | | | | | | | and the state of | | | | | | anger by difference (1966).<br>Difference and difference (1966). | | | | The state of s | <ol> <li>In the second state of the second seco</li></ol> | mantendrong that is a property of the contract | the contract of o | | ## CXA16/CXB16 **User Guide** Prepared by Educational Services of Digital Equipment Corporation 1st Edition, December 1986 2nd Edition, September 1989 #### Oigital Equipment Corporation 1986, 1989 All Rights Reserved The information in this document is subject to change without notice and should not be construed as a commitment by Digital Equipment Corporation. Digital Equipment Corporation assumes no responsibility for any errors that may appear in this document. #### Printed in U.S.A. Book production was done by Educational Services Development and Publishing in Merrimack, NH. The following are trademarks of Digital Equipment Corporation: | DEC | DIBOL | Scholar | |--------------|--------------|---------| | DECmate | MASSBUS | ULTRIX | | DECset | PDP | UNIBUS | | DECspell | P/OS | VAX | | DECsystem-10 | Professional | VMS | | DECSYSTEM-20 | Rainbow | | | DECUS | RSTS | diait | RSX **DECwriter** #### CONTENTS **PREFACE** 1.4.4 1.5.1 1.5.2.1 1.5.3 #### INTRODUCTION CHAPTER 1 SCOPE ...... 1-1 1.1 OVERVIEW ..... 1-1 1.2 Self-Test Facility ..... 1-3 Diagnostic Programs ..... 1-3 1.2.1.2 Preventing Data Loss ..... 1-3 1.2.1.3 Physical Description ...... 1-3 1.2.2 1.2.2.1 Configurations ..... 1-5 1.2.3 Connections ...... 1-7 1.2.4 SPECIFICATION ..... 1-8 1.3 Electrical Requirements ...... 1-8 Q-bus Loads ..... 1-8 1.3.2.1 Performance ...... 1-9 1.3.3 Data Rates ..... 1-9 1.3.3.1 Throughput ...... 1-9 1.3.3.2 1.4 SERIAL INTERFACES ...... 1-9 Speed and Distance Considerations ..... 1-9 1.4.2 Line Receivers ..... 1-12 1.4.3 Line Transmitters ..... 1-12 | CHAPTER 2 | INSTALLATION | | |------------|-------------------------------------|------| | 2 1 CCORE | | 2-1 | | 2.1 SCOPE | | 2-1 | | 2.2 UNPACK | NG AND INSPECTION | ~ - | | 2 3 DDEDAD | NG THE CXA16/CXB16 MODULE | Z- 4 | | 2 2 1 2442 | ass and Vector Assignment | 4-4 | | 3 3 3 DHM1 | or Dunil Programming Mode Selection | Z-: | | 2 3 3 Satt | ing the Address Switches | Z-4 | | 2 3 4 50++ | ing the Vector Switches | 2-5 | FUNCTIONAL DESCRIPTION ..... 1-13 General ...... 1-13 CXA16/CXB16 Main Functions ...... 1-15 Transmission ..... 1-15 Reception ..... 1-15 OCTART Chip ..... 1-16 | 2.4 BUS CONTINUITY | | |-------------------------------------------------------------------------------------------------|------| | 2.4.1 Bus Grant Continuity Jumpers | | | 2.5 PRIORITY SELECTION | | | 2.5.1 Recommendations | | | 2.5.2 DMA Request Priority | 2-7 | | 2.6 CXA16/CXB16 INSTALLATION | 2-8 | | 2.7 INSTALLATION TESTING | 2-11 | | 2.7.1 Installation Tests on MicroPDP-11 Systems | 2-11 | | 2.7.2 Testing in MicroVAX II Systems | 2-12 | | 2.8 LOOPBACK TEST CONNECTORS | 2-12 | | 2.8.1 H3101 Loopback Connector | 2-12 | | | | | CHAPTER 3 PROGRAMMING | | | 3.1 SCOPE | 3_1 | | 3.1 SCOPE | 3-1 | | 3.2 REGISTERS | 3-1 | | 3.2.1 Register Access | 3-1 | | 3.2.2 Register Bit Definitions | 3-4 | | 3.2.2.1 Control and Status Register (CSR) | 3-0 | | | 3-11 | | | 3-12 | | 3.2.2.4 Receive Timer Register (RXTIMER), DHUll Mode Only 3.2.2.5 Line-Parameter Register (LPR) | 3-13 | | | 3-15 | | | 3-16 | | | 3-17 | | 3.2.2.8 Line-Status Register (STAT), DHV11 Mode Only 3.2.2.9 Line-Control Register (LNCTRL) | 3-18 | | 3.2.2.9 Line-Control Register (LNCIRL) | 3-22 | | 3.2.2.10 Transmit Buffer Address Register Number 2 (TBUFFAD2) | 3-23 | | | 3-24 | | 3.2.2.12 Transmit DMA Buffer Counter (TBUFFCT) | 3-25 | | 3.3.1 Initialization | 3-25 | | | 3-26 | | 3.3.2 Configuration | 3-27 | | 3.3.3.1 DMA Transfers | 3-27 | | 3.3.3.2 Programmed I/O (DHV11 Mode) | 3-28 | | 3.3.3.3 Programmed I/O (DHU11 Mode) | 3-28 | | 3.3.4 Receiving | 3-29 | | 3.3.5 Interrupt Control | 3-29 | | 3.3.6 Auto XON and XOFF | | | 3.3.7 Error Indication | 3-33 | | 3.3.8 Maintenance Programming | 3-33 | | 3.3.9 Diagnostic Codes | 3-33 | | 3.3.9.1 Self-Test Diagnostic Codes | 3-33 | | 3.3.9.2 Interpretation of Self-Test Codes | 3-33 | | 3.3.9.3 Skipping Self-Test | 3-35 | | 3.3.9.4 Background Monitor Program (BMP) | 3-36 | | | | | | | G EXAMPLES | 3 | 3-36 | |---------|-----------------------------------------|----------------------------------------------|---------|-------------------| | | | | • • • ~ | , ,, | | 3.4.1 | Resetting | ation | 3 | 3-38 | | 3.4.2 | Configura | ation | | 3-39 | | 3.4.3 | Transmitt | ting | | 3-30 | | 3.4.3 | • • • • • • • • • • • • • • • • • • • • | | | , ,, | | 3.4.3 | 0 0:1- | Character Drogrammed Transfer (DHVII MOUE) | | J <b>3</b> \ | | 3.4.3 | 2 DM3 00-0 | amafar | | , , | | 3.4.3 | A Bhambin | ng a Transmission | | J-4. | | 3.4.4 | | ~ | | J-4. | | | BULL VON | and vore | | フーマリ | | 3.4.5 | Chacking | Diagnostic Codes | | 3-48 | | 3.4.6 | Checking | Diagnostic codes | | | | CHAPTI | ER 4 | TROUBLESHOOTING | | | | | | | | 4-1 | | 4.1 | SCOPE | | | 4-1 | | | rroubleshoo | OTING | • • • | 4 _ 1 | | 4.2.1 | Preventiv | ve Maintenance | • • • • | 4 – 1 | | 4.2.2 | Troublest | hooting Procedures | | 4-1 | | 4.3 | TRITEDNIAL DI | TACNOSTICS | ' | 4-4 | | 4.3.1 | Calf_Tect | + | | 4-4 | | 1 2 2 | Packarour | nd Monitor Program (BMP) | • • • ' | 4-4 | | 4.4 | Backgroui<br>Micropop 11 | 1 DIAGNOSTICS | | 4-5 | | 4.4 1 | MICLOPUP-11 | e Diagnostics | | 4-5 | | 4.4.1 | User-Mode | e Diagnostics | | 4-5 | | 4.4.1 | .l Running | g User-Mode Tests | • • • | 1 5<br>1 - 5 | | | MicroVAX II | I DIAGNOSTICS | • • • | 4 5 | | 4.5.1 | User-Mode | e Tests | • • • | 4-5 | | 4.6 | FIELD-REPLA | ACEABLE UNITS (FRUS) | • • • | 4-5 | | APPEN | DIX A | CXA16/CXB16 Q-bus CONNECTIONS | | | | APPEN | DIX B | FLOATING ADDRESSES | | | | | | | | n 1 | | B.l | FLOATING D | EVICE ADDRESSES | • • • | P-T | | B.2 | FLOATING V | ECTORS | • • • | B-4 | | | | | | | | APPEN | DIX C | AUTOMATIC FLOW CONTROL | | | | C.1 | OVERVIEW . | • • • • • • • • • • • • • • • • • • • • | | C-1 | | C 2 | CONTROL OF | TRANSMITTED DATA | | C-1 | | 0.2 | CONTROL OF | RECEIVED DATA | | $\bar{C}-\bar{3}$ | | 0.3 | CONTROL OF | RECEIVED DAIA of the Bossius FIFO | ••• | C-3 | | C.3.1 | Flow Con | trol by the Level of the Receive FIFO | • • • | C-5 | | C.3.2 | Flow Cont | trol by Program Initiation | • • • | C-6 | | C.3.3 | Mixing th | he two Types of Received Data Flow Control . | • • • | C-0 | | APPEN | DIX D | GLOSSARY OF TERMS | | | | n 1 | CCODE | | | D-1 | | ר. ד• ת | SCOPE | | • • • | י ב | | D.2 | GLOSSARY . | *************************************** | | D-1 | | INDEX | | | | | ### FIGURES | Figure No. | Title | Page | |-------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | 1-1<br>1-2<br>1-3<br>1-4<br>2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>2-6<br>3-1<br>4-1<br>C-1<br>C-2<br>C-3 | CXA16/CXB16 Module Layout Example of CXA16 Configuration CXA16/CXB16 Connections CXA16/CXB16 Functional Block Diagram Location of the Switchpacks Setting the Device Address Setting the Vector Address Bus Grant Continuity Flow CXA16/CXB16 Installation H3101 Loopback Connector Register Coding Cable Loopbacks Transmitted Data Flow Control Receive FIFO-Level Flow Control Program-Initiated Flow Control | 1-6<br>1-7<br>1-14<br>2-3<br>2-4<br>2-5<br>2-6<br>2-10<br>2-13<br>3-4<br>4-3<br>C-2<br>C-4 | | | TABLES | | | Table No. | Title | Page | | 1-1<br>1-2<br>3-1<br>3-2<br>3-3<br>3-4<br>A-1<br>B-1<br>B-2 | Maximum Distance Guidelines for CXA16/CXB16 Serial-Line Connections for the 36-pin Connector | 1-13<br>3-2<br>3-3<br>3-15<br>3-34<br>A-1<br>B-1 | The CXA16/CXB16 User Guide provides reference information on physical layout, system configuration, installation and testing, programming characteristics, and maintenance. There is a glossary of technical terms generally used in DIGITAL technical manuals, and a name index for easy topic reference. The User Guide is divided into four chapters as follows: CHAPTER 1 INTRODUCTION. This chapter gives a physical description of the CXA16/CXB16, explains how it can be configured, and explains how it interfaces with the system bus and serial data lines. CHAPTER 2 INSTALLATION. This chapter describes how to install a CXAl6/CXBl6 option, with detailed information on device and vector address selection, backplane positioning, cables and connectors, and testing after installation. CHAPTER 3 PROGRAMMING. This chapter describes CXA16/CXB16 control registers. Some programming examples are also included. CHAPTER 4 TROUBLESHOOTING. This chapter explains maintenance strategy and how to use diagnostic programs to locate a faulty module. A simple troubleshooting flowchart is included. APPENDICES. These expand on topics discussed in this manual: APPENDIX A - CXA16/CXB16 BUS CONNECTIONS APPENDIX B - FLOATING ADDRESSES APPENDIX C - AUTOMATIC FLOW CONTROL APPENDIX D - GLOSSARY OF TERMS | | | | | • | | | |-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|---------------------------------------|----|-----| | | | | | | 4 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 | | | | | | | | | | | | | | | | . ! | | · . · · · | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 12 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ara da jaran 1966.<br>Baran arabatan 1966. | | | | | | | | | | | | | | | | | | | | | | | | | | | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | and the second s | And the second s | | | | | #### 1.1 SCOPE This chapter gives an overview of the CXA16/CXB16 asynchronous multiplexer, describes the facilities it offers, and defines its physical parameters and electrical requirements. #### 1.2 OVERVIEW #### 1.2.1 General Description The CXAl6/CXBl6 is a serial-line interface which provides 16 full-duplex serial data channels for use in BA213/BA214-based Q-bus systems. The CXAl6/CXBl6 can be used in many applications, including data concentration, real-time processing, and interactive terminal handling. It has two programming modes: DHVll and DHUll. The register sets in these two modes are compatible with those of the DHVll and DHUll respectively. The preferred mode of operation is DHUll mode. The main features of the CXAl6/CXBl6 are as follows. - Sixteen full-duplex asynchronous data-only channels - The CXA16 supports DEC423 connections, and the CXB16 supports DEC422 connections #### NOTE DEC422 is a term used in this manual to indicate a data-leads-only implementation of the RS-422-A standard. DEC423 is a term used in this manual to indicate a data-leads-only implementation of the RS-423-A standard. - For each line: DMA transfers, and program transfers to a l-character transmit buffer in DHVll mode, or program transfers to a 64-character transmit FIFO in DHUll mode - A 256-entry FIFO buffer for received characters, and diagnostic information - For CXA16, the electrical characteristics and signaling standards are compatible with RS-423-A. As the physical interface does not use a 37-way subminiature D-type connector, it does not comply with this section of the RS-449 standards - For CXB16, the electrical characteristics and signaling standards are compatible with RS-422-A. As the physical interface does not use a 37-way subminiature D-type connector, it does not comply with this section of the RS-449 standards - The transmit and receive baud rates for each line can be individually programmed - A total module throughput of 50,000 characters per second, using 8-bit characters, with all channels operating at 38.4 kbaud for both character reception and transmission - Automatic flow control of transmitted data, with XON/XOFF character reporting through the receive FIFO, if enabled - Self-test and background monitor testing - Switch functions for selecting: - Addresses and vectors - DHVll or DHUll programming mode - All the other functions are selected by program - The module handle forms part of the system bulkhead. Signal distribution is through two 36-way connectors - Transient surge suppressors on all serial lines for static discharge and surge protection. The CXAl6/CXBl6 is a data device and is not intended for connection to modems or other Wide Area Network equipment. Note that, although the two program modes are referred to as DHVll and DHUll, the modem control signals supported by these devices are NOT supported by the CXAl6/CXBl6. - 1.2.1.1 Self-Test Facility -- The CXA16/CXB16' incorporates self-test sequencers which operate independently of the host. They test the device on power-up or initialization, and report diagnostic information to the host. - 1.2.1.2 Diagnostic Programs -- A full range of diagnostic programs is available. These run under the PDP-11 diagnostic supervisor or MicroVAX II maintenance system. Diagnostic information is also provided to the host system through the receive FIFO buffer. Loopback test connectors are not needed when running the user-mode diagnostics. A maintenance kit with service-mode diagnostics and loopback connectors is available from DIGITAL. A green LED indicates GO/NO-GO status for the device. - 1.2.1.3 Preventing Data Loss -- The CXA16/CXB16 can be programmed for automatic XON and XOFF operation, to prevent the loss of data at high throughput. The reporting of received XON/XOFF characters to the software driver can be enabled or disabled. - 1.2.2 Physical Description The CXA16/CXB16 is based on a standard quad-height module 10.4 inches long and 8.4 inches wide (26.4 x 21.3 cm). Figure 1-1 shows the layout. The spacing of the backplane slots into which the module connects is physically different from a standard Q-bus backplane, although they are electrically compatible. The serial-line interface is through two 36-way connectors, J1 and J2, mounted on the module handle. This handle forms part of the BA213/BA214 bulkhead. Connections to terminals and other peripheral devices from these connectors are made by two 36-wire cables (BC16D-25) and H3104 cable concentrators. Figure 1-1 CXA16/CXB16 Module Layout - 1.2.2.1 On-Board Switchpacks -- The CXA16/CXB16 has two on-board switchpacks to select the following device functions. - Ten-position switchpack (S2) Switch position 1 selects DHUll programming mode when open, or DHVll mode when closed. Switch positions 2 to 10 select the device Q-bus address. Eight-position switchpack (S1) Switch position I enables the on-board oscillator. This is a manufacturing test switch, and must be closed for normal operation. The device will not function with the switch open. Switch position 2 selects the external loopback indicator for self-test. This is a manufacturing test switch, and must be open for normal operation. Switch positions 3 to 8 select the device-interrupt vector address. #### 1.2.3 Configurations The CXA16/CXB16 can be used in many different system configurations. Figure 1-2 shows a typical application. Figure 1-2 Example of CXA16 Configuration #### 1.2.4 Connections The CXA16/CXB16 module is connected to the system backplane. Figure 1-3 shows the interconnections and test arrangements. Figure 1-3 CXA16/CXB16 Connections #### 1.3 SPECIFICATION #### 1.3.1 Environmental Conditions Environmental constraints for storage and operation of the CXA16/CXB16 are as follows. - Storage temperature within the range -40 degrees C to 66 degrees C (-40 degrees F to 151 degrees F) - Operating temperature within the range 5 degrees C to 60 degrees C (41 degrees F to 140 degrees F) - Relative humidity within the range 10 percent to 95 percent, non-condensing, at a maximum wet-bulb temperature of 32 degrees C and a minimum dew point of 2 degrees C. DIGITAL normally defines the the operating temperature range for a system as 5 degrees C to 50 degrees C (41 degrees F to 122 degrees F); the 10 degrees C difference between the upper limits quoted allows for the temperature gradient within the system box. The maximum operating temperatures must be derated by 1.8 degrees C/1000 m (1 degree F/1000 ft) for operation at high-altitude sites. #### 1.3.2 Electrical Requirements The CXAl6/CXBl6 needs the following electrical supplies (from the backplane). - 5 V dc plus or minus 5 percent at 2.1 A maximum current, 1.4 A typical - 12 V dc plus or minus 3 percent at 135 mA maximum, 110 mA typical (CXA16 only). The CXAl6 has an on-board switch-mode power supply, which generates a -10 V supply with the following characteristics: - -10 V dc plus or minus 5 percent - 1.3.2.1 Q-bus Loads -- The loads applied to the Q-bus are: - 3.0 ac loads - 1.5 dc loads. #### 1.3.3 Performance 1.3.3.1 Data Rates -- Each channel can be separately programmed to operate at one of 16 baud rates. | 50 | 1800 | |-------|-------| | 75 | 2000 | | 110 | 2400 | | 134.5 | 4800 | | 150 | 7200 | | 300 | 9600 | | 600 | 19200 | | 1200 | 38400 | Each channel can also be programmed for split-speed operation. #### NOTE Not all DIGITAL software supports the two highest speeds (19200 and 38400). Check with your Software Product Description. See also Section 1.4.2 (Speed and Distance Considerations). 1.3.3.2 Throughput -- There is a total module throughput of 50,000 characters per second, using 8-bit characters, with all channels operating at 38.4 kbaud for both character reception and transmission. #### 1.4 SERIAL INTERFACES #### 1.4.1 Interface Standards The CXAl6 conforms to the electrical characteristics of RS-423-A. The CXBl6 conforms to the electrical characteristics of RS-422-A. However, it is a data-leads-only implementation (no modem control). #### 1.4.2 Speed and Distance Considerations As of December 1985, the Electronics Industries Association (EIA) decided to replace the 'RS-' identifier with 'EIA'. Therefore RS-232-C has been replaced by EIA-232-D. These two standards are compatible with each other. This manual refers to EIA-232-D. The EIA-232-D/CCITT V.24/V.28 standard was originally designed to specify the connection between a local interface and a modem. It was not intended to be used for connecting to terminals over long distances. The maximum specified cable length is 50 feet (15 metres). Shielded cable must be used in order to meet the requirements of FCC and VDE Radio Frequency Interference (RFI) regulations. Although cable lengths greater than 50 ft can be used with reasonable success, cable capacitance, noise, and ground potential difference restrict the line speed as the distances increase. Consequently, the performance of long-distance communications to a terminal using EIA-232-D often does not meet today's requirements for terminal wiring. DEC423 is a superset of the RS-423-A/CCITT V.10 standard. RS-423-A has a different grounding and signal return path arrangement from EIA-232-D, as well as using different line driver and receiver chips. DEC423 uses line driver and receiver chips which have better filtering and tighter level tolerances than those specified by RS-423-A. In addition, DEC423 devices include transient suppressors for electrical overstress (EOS) and electrostatic discharge (ESD) protection. DEC423 devices may also be connected with unshielded cable. The features provided by DEC423 devices provide reliable data communication over increased distances, typically 1000 feet (300 metres) at 9600 baud. See Table 1-1 for maximum distance guidelines. Table 1-1 Maximum Distance Guidelines for CXA16/CXB16 | | Up to 4.8 Kb | 9.6 Kb | 19.2 Kb | 38.4 Kb | |---------------------|----------------|----------------|---------|---------| | DEC423 to DEC423 | 1000 ft | 1000 ft | 1000 ft | 500 ft | | | 300 m | 300 m | 300 m | 150 m | | DEC423 to EIA-232-D | 250 ft<br>75 m | 200 ft<br>60 m | - | - | | DEC422 to DEC422 | 4000 ft | 4000 ft | 4000 ft | 4000 ft | | | 1200 m | 1200 m | 1200 m | 1200 m | DEC423 is for data-leads-only connections to terminal equipment, and is not suitable for connection to modems or other Wide Area Network equipment. The standard also specifies the use of a modified modular jack (MMJ) connector, instead of the much larger D-type connectors defined in RS-449. DEC423 is signal compatible with the EIA-232-D standard when used for data-leads-only interconnection, in that interconnection between devices using the different standards is possible. However, the restrictions on speed and distance of EIA-232-D will still apply. DEC423 should always be used in preference to EIA-232-D for direct terminal connection over extended distances. #### NOTE EIA-232-D terminals can be connected to the CXA16 using either of the following: an H8521 passive terminal adapter or an H3105 active terminal adapter. An H3105 active terminal adapter is necessary when using an EIA-232-D terminal with a DEC423 interface, if the longer cable lengths obtainable with DEC423 are required. A terminal may be connected directly to the H3104 cable concentrator. The recommended cable is BC16E-xx, which has MMJ plugs at both ends, and is available in lengths up to 100 ft (30 m). The cable is also available without MMJ connectors in 1000 ft (300 m) reels, part number H8240. MMJs are available in packs of 50, part number H8220. There are many other DEC423 connection components available. For more information, contact your local sales office. #### NOTE DEC423 and EIA-232-D connections local communication. intended for general, communication devices can become non-operational or be damaged if the total cable length exceeds 1000 ft (300 m) for DEC423 devices, or 300 ft (100 m) for EIA-232-D devices. The cable should not be the building, and the outside low-voltage data wiring must be separated from ac power wiring. The installation or site may require additional devices to correct problems in communication. #### NOTE Under ideal conditions, DEC 423 devices can drive cables considerably longer than the 1000 ft maximum stated above. However, differences in ground potential, pick-up from mains ac power cabling, and risk of induced interference limits the maximum distance for reliable communications in most practical situations. DEC422 also incorporates EOS/ESD protection and RS-422 compatible drivers and receivers. This makes it an ideal standard for use in high-noise environments. Note that while connection between DEC422 and DEC423/EIA-232-D devices is feasible, it is not recommended or supported by DIGITAL for this product. DEC 422 supports cable lengths of up to 4000 ft (1200 m) at all supported speeds. #### 1.4.3 Line Receivers The CXA16/CXB16 module uses octal serial-line receivers, which convert the input signals to TTL levels suitable for use by the OCTART. Signals are inverted by the receivers. #### 1.4.4 Line Transmitters The CXA16 module uses octal serial-line transmitters, and the CXB16 uses quad line drivers. These convert the TTL level signals from the OCTART to DEC423 or DEC422 levels on the data lines. The signals are inverted by the transmitters. Table 1-2 shows connections to the 36-pin connectors used on the CXA16/CXB16. Table 1-2 Serial Line Connections for the 36-Pin Connector | 1 2 | Blu/Wht | Line 0 Transmit + | 19 Wht/Blu | Line 0 Transmit - | |-----|---------|-------------------|------------|-------------------| | | Org/Wht | Line 0 Receive + | 20 Wht/Org | Line 0 Receive - | | 3 | Grn/Wht | Line l Transmit + | 21 Wht/Grn | Line l Transmit - | | 4 | Brn/Wht | Line l Receive + | 22 Wht/Brn | Line l Receive - | | 5 | Slt/Wht | Line 2 Transmit + | 23 Wht/Slt | Line 2 Transmit - | | 6 | Blu/Red | Line 2 Receive + | 24 Red/Blu | Line 2 Receive - | | 7 | Org/Red | Line 3 Transmit + | 25 Red/Org | Line 3 Transmit - | | 8 | Grn/Red | Line 3 Receive + | 26 Red/Grn | Line 3 Receive - | | 9 | Brn/Red | Line 4 Transmit + | 27 Red/Brn | Line 4 Transmit - | | 10 | Slt/Red | Line 4 Receive + | 28 Red/Slt | Line 4 Receive - | | 11 | Blu/Blk | Line 5 Transmit + | 29 Blk/Blu | Line 5 Transmit - | | 12 | Org/Blk | Line 5 Receive + | 30 Blk/Org | Line 5 Receive - | | 13 | Grn/Blk | Line 6 Transmit + | 31 Blk/Grn | Line 6 Transmit - | | 14 | Brn/Blk | Line 6 Receive + | 32 Blk/Brn | Line 6 Receive - | | 15 | Slt/Blk | Line 7 Transmit + | 33 Blk/Slt | Line 7 Transmit - | | 16 | Blu/Yel | Line 7 Receive + | 34 Yel/Blu | Line 7 Receive - | | 17 | Org/Yel | Spare | 35 Yel/Org | Spare | | 18 | Grn/Yel | Spare | 36 Yel/Grn | Spare | #### 1.5 FUNCTIONAL DESCRIPTION #### 1.5.1 General The CXAl6/CXBl6 functional blocks are shown in Figure 1-4. Most of the functions are provided by three chips: one control chip and two OCTART chips. Q-bus buffering uses six DC021 bidirectional buffers. Serial-line interface buffering uses two octal line receivers and two octal line transmitters for the CXA16, and two octal EIA receivers and four quad line transmitters for the CXB16. A $2k \times 8$ static RAM chip provides the memory requirements. Switchpacks provide vector address, module address, and programming mode selection. Figure 1-4 CXA16/CXB16 Functional Block Diagram #### 1.5.2 CXA16/CXB16 Main Functions - 1.5.2.1 Transmission -- In the preferred programming mode (DHUll), characters may be either written directly to the transmit data FIFO (programmed transfer), or may be transferred from the host memory to the transmit data FIFO using DMA transfers. - In DHV11 programming mode, only single characters can be transmitted using programmed transfers. Characters can also be transferred by DMA as in DHU11 programming mode. - 1.5.2.2 Reception -- Received characters are descrialized by the OCTART and transferred to a four-character area in the RAM (one such area per line) by the control chip OCTART interface, following an interrupt from the OCTART. The OCTART interface later removes characters from the bottom of this 4-character FIFO, and places it in the 256 x 16 receive FIFO, which can be read by the host. - 1.5.3 Control Chip The control chip contains the following functional blocks. - Q-bus Interface -- Matches addresses, generates vector addresses, and handles interrupts. It also interfaces the Q-bus signals to other functional blocks. - DIO Control -- Controls host access to device registers. - OCTART Interface -- Transfers data between the OCTARTs and RAM, and handles flow control. It also controls the operation of the OCTART. - Self-Test/Power-Up Sequencer -- This section powers up the module to a fixed set of initial conditions, such as 9600 baud rate on all lines; it also handles self-test. - DMA Sequencer -- Initiates and manages all DMA data transfers to the module. - RAM Arbitrator -- Provides RAM and OCTART bus access to the various sequencers. # 1.5.4 OCTART Chip This chip contains eight UARTs, which perform parallel-to-serial and serial-to-parallel data conversions. It interfaces with the control chip through eight registers. Four are read-only and four are write-only. An index register is used to access individual lines. The OCTART chip shares the RAM bus with the control chip, the RAM itself, and a second OCTART chip. The OCTART chip also includes: - Receive and transmit control blocks - Interrupt logic for interfacing with the control chip - A 16-output baud-rate generator - All necessary line-parameter registers - Diagnostic loopback logic #### 2.1 SCOPE This chapter describes the preparation and installation of the CXAl6/CXBl6 as add-on options. If the option was ordered as part of a system, it will be already installed, and you should refer to the system unpacking instructions. This chapter contains the following sections. - Unpacking - Preparation - Installation - Testing. The procedures described in this chapter are designed for use only by qualified service engineers. #### 2.2 UNPACKING AND INSPECTION There are two options available, the CXAl6-AA and the CXBl6-AA. The contents of each option are as follows. | Item | Part number | Quantity | | | |--------------------|-------------|----------|----------|--| | | | CXA16-AA | CXB16-AA | | | CXA16 module | M3118-YA | 1 | | | | CXB16 module | M3118-YB | | 1 | | | Cable concentrator | н3104 | 2 | 2 . | | | Cable | BC16D-25 | 2 | 2 | | | Loopback connector | н3101 | 1 | 1 | | | User Guide | EK-CAB16-UG | 1 | 1 | | | Labels | | 1 . | 1 | | Undo each package and examine the contents for physical damage. Check that the contents of each package are complete. Report any damaged or missing items to the shipper and to the local DIGITAL office. Do not dispose of the packing material until the unit has been installed and is operational. - 2.3 PREPARING THE CXA16/CXB16 MODULE Three parameters must be defined before installation. - Q-bus base address - Q-bus interrupt vector - DHV11 or DHU11 programming mode. These are selected using switchpacks on the CXA16/CXB16 module. 2.3.1 Address and Vector Assignment Switchpack S1 and Switchpack S2 determine the device address and vector for the CXA16/CXB16 module respectively. The CXA16/CXB16's factory settings are only correct if no other floating address or vector options are installed in the microsystem. If you have other options, or more than one CXA16/CXB16, check your host system manuals; they may give recommended addresses and vector settings for the different options. If this information is not available, the full assignment rules must be applied; these are given in Appendix B. NOTE Some systems have additional restrictions on module addresses and on slot locations. Figure 2-1 Location of the Switchpacks 2.3.2 DHVll or DHUll Programming Mode Selection The CXAl6/CXBl6 offers two separate programming modes, DHVll and DHUll. The mode selected depends on the device driver used in your system. The mode is determined by switch position 1 of the 10-position switchpack S2 (see Figures 2-1 and 2-2). DHUll programming mode generally gives better performance because of reduced CPU overhead transferring characters to and from the device. The Software Product Description states whether the operating system supports DHUll programming mode. DHUll programming mode is the preferred mode of operation. ## 2.3.3 Setting the Address Switches The device address for the CXA16/CXB16 is set on the 10-position switchpack S2. The location of this switchpack is shown in Figure 2-1. Figure 2-2 shows how to set the device address on the switchpack. The example shown is for the address of 17760440 (octal). (Switch 1 on the switchpack is for DHV11/DHU11 programming-mode selection.) Figure 2-2 Setting the Device Address #### 2.3.4 Setting the Vector Switches The six high-order bits of the interrupt vector address are set on the eight-position switchpack S1. Figure 2-1 shows the location of this switchpack. Figure 2-3 shows an example of these switches set to 300 (octal). (Switch positions 1 and 2 are used during manufacture, switch position 1 must be closed, and switch position 2 must be open for correct operation of the CXA16/CXB16.) Figure 2-3 Setting the Vector Address #### 2.4 BUS CONTINUITY Bus grant continuity jumper cards are used in vacant backplane slots to provide bus continuity. #### 2.4.1 Bus Grant Continuity Jumpers The CXA16/CXB16 uses the Q/CD backplane, Q-bus on A and B connectors, and user-defined signals on C and D. In Q/CD backplanes, bus grant signals pass through each installed module through the A connectors of each bus slot. Lines AM2 and AN2 (BIAK), and AR2 and AS2 (BDMG), carry the bus grant signals. Figure 2-4 shows the bus grant routing. Figure 2-4 Bus Grant Continuity Flow #### 2.5 PRIORITY SELECTION The CXA16/CXB16 uses the BIRQ4 line to request interrupt service. It does not monitor any of the higher-level interrupt request lines. Because of this, both the interrupt-request and DMA (non-processor request) priorities of the CXA16/CXB16 are selected by the position of the CXA16/CXB16 on the bus. Devices closest to the processor module have the highest priority. The bus (backplane) position may be a compromise between DMA and interrupt priority requirements. As a general rule, consider DMA request priorities first, then interrupt (bus) requests. #### 2.5.1 Recommendations In general the CXA16/CXB16 bus position is not critical. However, it is recommended that you place the module after any mass-storage interfaces and high-speed synchronous communications options; these are more sensitive to bus position. The following list shows the recommended module sequence: - 1. CPU - 2. Memory modules - 3. Synchronous communications modules no silo - 4. General-purpose I/O ports - 5. Line printer interface - 6. Asynchronous communications modules no silo - 7. Asynchronous communications modules silo - 8. Synchronous communications modules DMA - 9. Communications module smart DMA - 10. Asynchronous communications modules silo/DMA (e.g. CXA16/CXB16). #### 2.5.2 DMA Request Priority DMA request priority is usually assigned according to throughput. Faster devices (higher throughput) usually have priority over slower DMA devices; for example, disk has priority over tape, which itself has priority over communications devices. This is because fast devices usually reach overrun or underrun conditions sooner than slower ones. #### 2.6 CXA16/CXB16 INSTALLATION This section gives a step-by-step guide to installing the option. Figure 2-5 shows how the parts of the option connect together. - 1. Before you begin the installation, check that the system is operating correctly by running appropriate diagnostics. - 2. Turn the system power off. #### WARNING Shut off the system power and disconnect the main system power cord before performing any procedure in this chapter. #### **ATTENTION** Avant d'effectuer l'une des procédures de ce chapitre, mettez le système hors tension et débranchez le cordon d'alimentation. #### VORSICHT! Schalten Sie das System ab, und ziehen Sie das Netzkabel, bevor Sie die in diesem Kapitel beschriebenen Answeisungen ausführen. #### **ATENCION** Apague el sistema y desconecte el cable principal de alimentación antes de realizar ningún procedimiento de este capítulo. 3. Remove the module blanking plate at the chosen position in the system box, and the grant card, if fitted. #### NOTE Make sure that bus grant continuity is maintained from the CPU to the last module on the bus. 4. Insert the module into the backplane. #### NOTE - 1. Be careful not to snag module components on the card guides or adjacent modules. - 2. Ensure that you are wearing an antistatic wriststrap, part number 29-11762-00. - 5. Turn the power on. After two seconds check that the self-test LED is on; this indicates a successful self-test\*. Correct any problems before proceeding with the installation. - 6. Run the user-mode diagnostics\* to test the module; no test connectors are required. - 7. Connect the BC16D-25 cables to Jl and J2 on the module bulkhead. - Connect the other ends of each BC16D cable to an H3104 cable concentrator. - \* The self-test and diagnostics used to test the installation of the CXA16/CXB16 are briefly described in Section 2.7, and in more detail in Chapter 4. Figure 2-5 CXAl6/CXBl6 Installation 2.7 INSTALLATION TESTING This section details the diagnostics used to test the option during and after installation. The diagnostics are also used to test other Q-bus modules in the same family, for example, DHV11. The diagnostics will automatically 'size' the option to determine which one is being tested. The CXA16/CXB16 can be tested in either of its two programming modes. Both PDP-11 and MicroVAX II diagnostics are described. After successful completion of the appropriate system test, the CXA16/CXB16 may be connected to external equipment. Further information on the diagnostics is given in Chapter 4. - 2.7.1 Installation Tests on MicroPDP-11 Systems To verify that the MicroPDP-11 system and the CXA16/CXB16 module are functioning correctly: - Check that the green self-test LED on the CXA16/CXB16 module is on. - Boot the MicroPDP-11 Customer Diagnostic media. Refer to your MicroPDP-11 System Manual for further information. - 3. Type 'I' at the main menu to allow the diagnostics to identify the new module and add it to the configuration file. #### NOTE Look at the list of devices displayed, and make sure that the new module is included. If it is not included, repeat the installation sequence, and make sure that the module switches have been set correctly. 4. Type 'T' at the main menu to run the system tests. These should complete without error; if an error occurs, call DIGITAL Field Service. A MicroPDP-11 Maintenance Kit is available, which allows you to run individual diagnostic programs under the XXDP+ diagnostic monitor, and to configure and run DECX11 system test programs. The XXDP+ functional diagnostic is VHQA\*\*.BIN, and the DECX11 module is XDHV\*\*.OBJ. # 2.7.2 Testing in MicroVAX II Systems To verify that the MicroVAX II system and the CXA16/CXB16 module are functioning correctly: - Check that the green self-test LED on the CXA16/CXB16 module is on. - 2. Boot the MicroVAX Maintenance System media. Refer to your MicroVAX II System Manual for further information. - 3. Type '2' at the main menu to show the system configuration and devices. #### NOTE Look at the list of devices displayed, and make sure that the new module is included. If it is not included, repeat the installation sequence, and make sure that the module switches have been set correctly. 4. Type 'l' at the main menu to run the system tests. These should complete without error; if an error occurs, call DIGITAL Field Service. # 2.8 LOOPBACK TEST CONNECTORS Two loopback connectors are available for the CXA16/CXB16: the H3101 and the H3103; only the H3101 is shipped with the option. # 2.8.1 H3101 Loopback Connector The H3101 loopback connector is two loopback connectors in one package, and consists of a female 36-way loopback connector and a male 36-way loopback connector. It can be inserted into the cabling at the module bulkhead, or at the cable concentrator. To test the cables, type characters at the keyboard and make sure that they are echoed to the screen (refer to Chapter 4). Figure 2-6 shows the wiring of the H3101 loopback connector. Figure 2-6 H3101 Loopback Connector | | | 1 - 4 - 1 | | | | | |------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | in Angelon (1997)<br>Singaport (1997) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | garan da Kilipa Ki | | | | | | | | 整线 医克尔氏法 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 발생님은 보다를 | | | | | | | | | | | | | | | 김 경찰의 집에 가르다 | | | | | | | 열리를 잃었다면 그 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 4년 5년 18 - ESE | | | | | | | | | | | | | | | | | | | | | | | | | | | | tiga a si ti di kabasa da sa | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | State of the second | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | official side | | | | | | | | | | | | | | | | | | | | | | | | | | | en e | e securiti de la la como de la literación de securiti de la combinación de la descripción de la literación d | terro - marchitenno retalizione medite reportazione menter | en en esta a anticata carbon de California de la compansión de compansión de compansión de la | mandamente considera con un manda de dos de de | ting the state of the second section (i.e., and self-con- | AND THE RESIDENCE OF THE STATE | # 3.1 SCOPE This chapter describes the program control registers, and how they are used to control and monitor the CXA16/CXB16. The chapter covers: - The bit functions and format of each register - Programming features available to the host. Some programming examples are also included. # NOTE DHUll programming mode is the preferred mode of operation for the CXA16/CXB16. The development of user drivers that use the CXA16/CXB16 in DHVll programming mode is not recommended. # 3.2 REGISTERS The host system controls and monitors the CXA16/CXB16 module through several Q-bus-addressable registers. Command words or bytes written to the registers are interpreted and Status reports and data are also executed by the sequencers. transferred through the registers. # 3.2.1 Register Access CXA16/CXB16 registers occupy 8 words (16 bytes) of memory-mapped I/O space. Some of these registers perform several functions, selected through bits in the CSR. The base physical address of the eight CXA16/CXB16 registers is selected by switches on the module. The address selected must be in the peripheral I/O space. Tables 3-1 and 3-2 list the CXA16/CXB16 registers and their addresses (in DHV11 mode and DHU11 mode). The suffix (I) means that there are eight of these registers, one for each channel. When an (I) register is accessed, the address given in the table is indexed by the contents of CSR<3:0> to select the register for the appropriate channel. The term 'base' means the lowest I/O address on the module; that is to say, when the four low-order address bits = 0. #### NOTE Before indexed (I) registers are accessed, the channel number must be written to the CSR. Table 3-1 CXA16/CXB16 Registers in DHV11 Mode | Register | Address (Octal) | Type | |--------------------------------------|-----------------|------------| | Control and Status Register (CSR) | Base | Read/Write | | Receive Buffer (RBUF) | Base+2 | Read Only | | Transmit Character (TXCHAR) | Base+2 (I) | Write Only | | Line-Parameter Register (LPR) | Base+4 (I) | Read/Write | | Line Status (STAT) | Base+6 (I) | Read Only | | Line Control (LNCTRL) | Base+10(I) | Read/Write | | Transmit Buffer Address 1 (TBUFFAD1) | Base+12(I) | Read/Write | | Transmit Buffer Address 2 (TBUFFAD2) | Base+14(I) | Read/Write | | Transmit Buffer Count (TBUFFCT) | Base+16(I) | Read/Write | # NOTE In DHVll mode it is possible to write to the line-status register. However, the host should not write to this register. Table 3-2 CXA16/CXB16 Registers when in DHUll Mode | Register | Address (Octal) | Type | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | Control and Status Register (CSR) Receive Buffer (RBUFF) Receive Timer* (RXTIMER) Line-Parameter Register (LPR) FIFO Data (FIFODATA) FIFO Size (FIFOSIZE) Line Status (STAT) Line Control (LNCTRL) Transmit Buffer Address 1 (TBUFFAD1) Transmit Buffer Count (TBUFFCT) | Base Base+2 Base+2 Base+4 (I) Base+6 (I) Base+6 (I) Base+7 (I) Base+10(I) Base+12(I) Base+14(I) Base+16(I) | Read/Write Read Write(byte) Read/Write Write Read(byte) Read/Write Read/Write Read/Write Read/Write | <sup>\*</sup> Only accessible when CSR<3:0>=0000. There are 16 line-parameter registers, only 1 of which is accessed at any one time. The register which is accessed is associated with the line selected using CSR<3:0>. However, read-modify-write instructions may be used on all registers except CSR and RBUF. For example, to read the line-parameter register of channel 3, the following I/O commands would be executed: MOVB #CHAN, 0 #BASE ; WRITE CHANNEL NUMBER (SEE BELOW) TO CSR MOVB 0 #BASE+4, RO ; READ THE LINE PARAMETER REGISTER In the above example, CHAN = 0er00011(binary) #### Where e = the RXIE bit of the CSR r = the MASTER.RESET bit (which would be 0) 0011 = channel number 3 #### NOTE Not all register bits are used. In a write action, all unused bits must be written as 0s. In a read action, unused bits are undefined. 3.2.2 Register Bit Definitions Registers which are modified by reset sequences are coded as shown in Figure 3-1. Figure 3-1 Register Coding # 3.2.2.1 Control and Status Register (CSR) -- RE10 | Bit | Name | Description | |-----|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | TX.ACTION (Transmitter Action) | This bit is set by the CXA16/CXB16 when: | | | (R) | <ol> <li>The last character of a DMA<br/>buffer has left the OCTART.</li> </ol> | | | | 2. DMA transfer has been aborted. | | | | 3. DMA transfer has been terminated by CXA16/CXB16 because non-existent memory was addressed, or because of a memory parity error. | | | | 4. In DHV11 mode when a single-character programmed output has been accepted, that is, a character taken from TX.BUFF. | | | | 5. In DHUll mode, following a programmed data transfer, the module has emptied a transmit FIFO. | | | | The bit is cleared if the host reads the CSR after the TX.ACTION FIFO has become empty. To avoid losing TX.ACTION reports, the host must not let more than 16 reports accumulate. It is advisable to read the CSR until TX.ACTION becomes clear. | | | | NOTE | | | TX.ACTION reports byte of the CSF read of the CSR. | may be lost if the upper<br>R is discarded following a | | 14 | TXIE (Transmit<br>Interrupt Enable)<br>(R/W) | When set, this bit allows the CXA16/CXB16 to interrupt the host when CSR<15> (TX.ACTION) becomes set. | | | | The bit is cleared by BINIT, but not by MASTER.RESET. | | Bit | Name | Description | |--------|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | DIAG.FAIL<br>(Diagnostic Fail)<br>(R) | When set, this bit indicates that CXA16/CXB16 internal diagnostics have detected an error, by the self-test diagnostic or by the BMP. | | | | This bit is associated with the diagnostic-passed LED. When it is set, the LED will be off. When it is cleared, the LED will be on. | | | | The bit is set by MASTER.RESET. It is cleared after the internal diagnostic programs have been run successfully. | | | | It is valid only after MASTER.RESET bit CSR<5> has been cleared. | | 12 | TX.DMA.ERROR<br>(Transmit DMA Error)<br>(R) | If this bit is set and TX.ACTION is also set, either the channel indicated by CSR<11:8> has failed to transfer DMA data within 10 microseconds (in DHV11 mode), or 20 microseconds (in DHU11 mode), of bus request being acknowledged, or a memory parity error exists. | | | | The TBUFFAD1 and TBUFFAD2 registers will contain the address of the memory location at which the error occurred. TBUFFCT will be cleared. | | <11:8> | TX.LINE (Transmit<br>Line Number) (R) | If TX.ACTION is set, these bits hold the TX.ACTION line number. | | 7 | RX.DATA.AVAIL (Received Data Available) (R) | When set, this bit indicates that a received character is available. The bit is clear when the receive FIFO is empty. It is used to request a receive interrupt. | | | | The bit is set after MASTER.RESET because the receive FIFO contains diagnostic information. | | Bit | Name | Description | | | | | |--------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 6 RXIE | (Receiver<br>Interrupt Enable)<br>(R/W) | When set, this bit allows the CXA16/CXB16 to interrupt the host when RX.DATA.AVAIL is set. An interrupt is generated under the following conditions. | | | | | | | | l. RXIE is set and a character is<br>placed into the empty receive<br>FIFO. | | | | | | | | 2. The receive FIFO contains one or more characters, and RXIE is changed from 0 to 1. It is cleared by BINIT but not by MASTER.RESET. | | | | | | 5 | MASTER.RESET (Master<br>Reset) (R/W) | This is set by the host in order to reset when in DHV11 mode. It stays set while the CXA16/CXB16 runs a self-test sequencer, and then performs an initialization sequence. The bit is then cleared to tell the host that the process is complete. | | | | | | | | This bit is set by BINIT (bus initialization signal), or by the host processor setting CSR<5>. | | | | | | | | If the CSR is written to while a MASTER.RESET sequence is in progress, the MASTER.RESET bit must be cleared. | | | | | | Bit | Name | Description | |-------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | SKIP (Skip Self-Test)<br>(RW) | In DHUll mode, this bit is used to shorten the reset/initialization time to about 30 milliseconds. | | | | The host program must only set this bit at the same time as it sets MASTER.RESET. It must then clear the bit, but must wait at least 20 microseconds before doing so. It is recommended that the host always set SKIP when setting MASTER.RESET. The CXA16/CXB16 will execute the full self-test, regardless of whether SKIP is set or not. The 1.7 seconds delay during MASTER.RESET is purely for DHUll hardware compatibility. In DHV11 mode, this bit is ignored for compatibility reasons. | | <3:0> | IND.ADDR.REG<br>(Indirect Address<br>Register) (R/W) | For indexed registers, these bits select one of 16 channels. | 3.2.2.2 Receive Buffer (RBUF) -- A READ from base + 2 is interpreted by the CXA16/CXB16 hardware as a READ from the receive FIFO. Therefore, RBUF is a 256-character register with a single-word address. The least-significant bit (LSB) of the character is in bit 0. RBUF (READ BASE + 2) RE2748 | Bit | Name | Description | |-----|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | DATA.VALID<br>(Data Valid) (R) | This bit is set if there is data in the receive FIFO. | | | | When this bit is clear, the contents of RBUF<14:0> are not valid. | | | | After self-test, diagnostic information is loaded into the receive FIFO. Therefore, this bit is always set after a successful master reset sequence. | | 14 | OVERRUN.ERR (Overrun<br>Error) (R) | This bit is set if one or more previous characters of the channel indicated by bits <11:8> were lost because of a full receive FIFO, or failure to service the UARTS (see also RX.CHAR). | # NOTE The 'all ls' code for bits <14:12> is reserved. This code indicates that RBUF<7:0> holds diagnostic information. | Bit | Name | Description | |--------|--------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 13 | FRAME.ERR (Framing Error) (R) | This bit is set if the first stop bit of the received character was not detected (also see RX.CHAR). | | 12 | PARITY.ERR (Parity<br>Error) (R) | This bit is set if this character has a parity error, and parity is enabled for the channel indicated by bits <11:8> (also see RX.CHAR). | | <11:8> | RX.LINE (Receive<br>Line Number) (R) | These bits hold the binary number of the channel on which the character of RBUF<7:0> was received. | | <7:0> | RX.CHAR (Received Character) (R) | If RBUF<14:12> = 000, these eight bits contain the oldest character in the receive FIFO. The character is good. | | | | If RBUF<14:12> = 001, 010, or 011, these eight bits contain the oldest character in the receive FIFO, but the character is bad. | | | | <pre>If RBUF&lt;14:12&gt; = 111, then RBUF&lt;7:1&gt; contains diagnostic information.</pre> | | | | If there is an overrun condition, the UART data buffer for that channel will be cleared. This data will be lost. A null character is placed in the receive FIFO, and RBUF<14> is set. | | | | The CXA16/CXB16 does not have a break-detect bit. A line break is indicated to the program as a null character with FRAME.ERR set, and OVERRUN.ERR clear. | 3.2.2.3 Transmit Character Register (TXCHAR), (DHV11 Mode Only) -- Single-character programmed transfers are made through the transmit character register. Bit function is as follows: # TXCHAR (WRITE BASE + 2,DHV11 MODE) | Bit | Name | Description - | |-------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | TX.DATA.VALID (Transmit Data Valid) (W) | When set, this bit instructs the CXA16/CXB16 to transmit the character held in bits <7:0>. The bit is sensed by the CXA16/CXB16, which then transfers the character, clears the bit, and sets TX.ACTION. | | | | TX.DATA.VALID and the character can be written together, or by separate MOVB instructions. | | <7:0> | TX.CHAR (Transmit Character) (W) | This byte sets the character to be transmitted. The LSB is bit 0. For 7-, 6-, or 5-bit characters, unused bits must be 0. | 3.2.2.4 Receive Timer Register (RXTIMER) (DHUll Mode Only) -- The indirect address register (CSR<3:0>) must = 0000 in order to access the receive timer. It can be used by the host to delay the receive interrupt. # Rx TIMER (WRITE BASE+2,DHU11 MODE) | 15 | | | | | | | | | | | | |----|--|--|--|---|---|---|---|---|---|---|---| | | | | | w | w | w | w | w | w | w | w | Bit Description Name The receive interrupt is normally <7:0> RX.TIMER raised when a received character is (Receive loaded into the previously empty timer) The binary number (W BYTE) receive FIFO. loaded into RXTIMER modifies this procedure as follows. 0 = Infinite timeout. This timeout overridden by will be conditions below. 1 = No timeout. The interrupt will be raised immediately. 2 to 255 = Timer delay milliseconds. becomes (critical). The three-quarters overridden when the receive FIFO Set to value of 1 by MASTER.RESET. timer is full 3.2.2.5 Line Parameter Register (LPR) -- This register is used to configure its associated channel. Bit function is as follows: LPR (BASE + 4) \* 00 = NORMAL OPERATION 01 = SCREEN RECEIVED XON/XOFF CHARACTERS FROM ENTRY INTO RECEIVER BUFFER IF 0 AUTO IS SET RE2751 | Bit | Name | Description | |---------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------| | <15:12> | TX.SPEED<br>(Transmitted Data<br>Rate) (R/W) | This is set to 1101 by MASTER.RESET (9600 bits/s). It defines the transmit data rate (Table 3-3). | | <11:8> | RX.SPEED (Receive Data Rate) (R/W) | This is set to 1101 by MASTER.RESET (9600 bits/s). It defines the receive data rate (Table 3-3). | | 7 | STOP.CODE (Stop<br>Code) (R/W) | This bit defines the length of the transmitted stop bit. | | | | 0 = 1 stop bit for 5-, 6-, 7-, or 8-bit characters | | | | <pre>1 = 2 stop bits for 6-, 7-, or<br/>8-bit characters, or 1.5 stop bits<br/>for 5-bit characters</pre> | | | | The bit is cleared by MASTER.RESET. | | 6 | EVEN.PARITY (Even Parity) (R/W) | If LPR<5> is set, this bit defines the type of parity. | | | | <pre>1 = Even parity 0 = Odd parity</pre> | | | | The bit is cleared by MASTER.RESET. | | Bit | Name | Description | |-------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | PARITY.ENAB (Parity<br>Enable) (R/W) | This causes a parity bit to be generated on transmit, and checked on receive. 1 = Parity enabled 0 = Parity disabled The bit is cleared by MASTER.RESET. | | <4:3> | CHAR.LGTH (Character<br>Length) (R/W) | This defines the length of characters. It does not include start, stop, and parity bits. 00 = 5 bits 01 = 6 bits 10 = 7 bits 11 = 8 bits | | | | The bit is set to 11 by MASTER.RESET. | | <2:1> | DIAG (Diagnostic<br>Code) (R/W) | These are diagnostic control codes. They are used by the host as follows. 00 = Normal operation 01 = Causes the Background Monitor Program (BMP) to report the CXA16/CXB16 status to the receive FIFO. | | <0> | DISAB.XRPT (Disable XON/XOFF Reporting) (R/W) | <pre>0 = XON and XOFF characters are reported on all channels. l = If LNCTRL&lt;4&gt; is also set for a particular channel, these characters are filtered from the received data stream, to relieve the host of the need to do so. On initialization, this bit is cleared. To read or write to this bit, CSR&lt;3:0&gt; must equal zero.</pre> | | | An XOFF code = $0$ : | NOTE octal) = DCl = CTRL/Q. 23(octal) = DC3 = CTRL/S. are specified for the | Table 3-3 Data Rates | Code | Data Rate (Bits/s) | Maximum<br>Error (% | |------|--------------------|---------------------| | 0000 | 50 | 0.01 | | 0001 | 75 | 0.01 | | 0010 | 110 | 0.08 | | 0011 | 134.5 | 0.07 | | 0100 | 150 | 0.01 | | 0101 | 300 | 0.01 | | 0110 | 600 | 0.01 | | 0111 | 1200 | 0.01 | | 1000 | 1800 | 0.01 | | 1001 | 2000 | 0.19 | | 1010 | 2400 | 0.01 | | 1011 | 4800 | 0.01 | | 1100 | 7200 | 0.01 | | 1101 | 9600 | 0.01 | | 1110 | 19200 | 0.01 | | 1111 | 38400 | 0.01 | 3.2.2.6 FIFO Data Register (FIFODATA), (DHUll Mode Only) -- To write a character or characters to a transmit FIFO, the host writes the character(s) to the FIFO data register of the appropriate channel. To make sure that there is room in the transmit FIFO, the host should first read the associated FIFO size register. If single characters are sent, they must be written to the low byte of FIFODATA. | Bit | Name | Description | |--------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <15:0> | FIFODATA<15> | This word contains two characters (FIFO Data for transfer to the transmit FIFO). After a write-word action to this (W) register, FIFODATA<7:0> and then FIFODATA<15:8> are transferred to the FIFO. | | | | The least-significant bits of the characters are in FIFODATA bits 0 and 8. Unused bits must be cleared. | | | | This byte is cleared by MASTER.RESET. | | <7:0> | FIFODATA<7> (FIFO Data Register) (W BYTE) | This byte contains a single character for transfer through to the transmit FIFO. After a write-byte action to this register, FIFODATA <7:0> is transferred to the FIFO. | | | | The least-significant bit of the character is in FIFODATA bit 0. Unused bits must be cleared. | | | • | The byte is cleared by MASTER.RESET. | 3.2.2.7 FIFO Size Register (FIFOSIZE) (DHUll Mode Only) -- This low-byte register holds a number which indicates the space available in the transmit FIFO. # FIFOSIZE (READ BASE +6, DHU11 MODE ONLY) 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 R R R R ALWAYS 0 FIFO SIZE 0 TO 64 DHUIND SET TO 1, DHUII MODE MDL SET TO 1, MODEM SUPPORT NOT PROVIDED 3-16 | Bit | Name | Description | |-------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <9> | (MDL Modem<br>Support Low) (R) | Always set to 1 - Modem support is not provided. | | <8> | (DHUID Identification Bit) (R) | This bit allows software to distinguish between DHVll mode and DHUll mode. It is always 1 in DHUll mode. | | <7:0> | FIFOSIZE<br>(FIFO Size)<br>(R BYTE) | This byte indicates the available space (in characters) in the transmit FIFO. The range is 00000000(binary) to 01000000(binary) (0(decimal) to 64(decimal)). This register should be read before sending a character, or a sequence of characters, to the FIFO data register. The byte is set to 64 characters by MASTER.RESET. | # 3.2.2.8 Line-Status Register (STAT) (DHV11 mode only) -- STAT (READ BASE +6, DHV11 MODE ONLY) RE2754 | Bit | Name | Description | |-----|--------------------------------------|----------------------------------------------------------------------------------------------------------| | <9> | (MDL Modem<br>Support Low) (R) | Always set to 1 - Modem support is not provided. | | <8> | (DHUID<br>Identification Bit)<br>(R) | This bit allows software to distinguish between DHV11 mode and DHU11 mode. It is always 0 in DHV11 mode. | 3.2.2.9 Line-Control Register (LNCTRL) -- The main function of this register is to control the line interface. | Bit | Name | Description | |-------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <7:6> | MAINT (Maintenance<br>Mode) (R/W) | These bits can be written by the driver or test programs, in order to test the channel. | | | | The coding is as follows: | | | | 00 = Normal operation | | | | Ol = Automatic echo mode Received data is looped back to the terminal (regardless of the state of TX.ENA) at the data rate selected for the receiver. The received characters are processed normally and placed in the receive FIFO. Any data that the host attempts to transmit on this channel will be discarded by the OCTART. The RX.ENA bit must be set when operating in this mode. | | Bit | Name | Description | |-------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <7:6> | MAINT (cont.) | 10 = Local loopback Data transmitted by the host is looped back to the receive buffer. Data received from the terminal is ignored, and the transmit data line to the terminal is held in the mark condition. The data rate selected for the transmitter is used for both transmission and reception. The TX.ENA bit still controls transmission in this mode. The RX.ENA bit is ignored. | | | | <pre>1l = Remote loopback In this mode, data received from the terminal is looped back to the terminal at a clock rate equal to the received clock rate. The data is not placed in the receive FIFO. The state of TX.ENA is ignored. The RX.ENA bit must be set on this channel.</pre> | | 5 | FORCE.XOFF (Force XOFF) (R/W) | This bit can be set by the program to indicate that this channel is congested at the host system (for example, if the typeahead buffer is full). When it sees this bit set, the CXA16/CXB16 will send an XOFF code. Until the bit is reset, XOFFs will be sent after every alternate character received on this channel. When the bit is reset, an XON will be sent unless IAUTO is set and the receive FIFO is critical. | | Bit | Name | Description | |-----|---------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | OAUTO (Outgoing Auto<br>Flow) (R/W) | This bit is the auto-flow control bit for outgoing characters. When set, if RX.ENA is also set, the CXA16/CXB16 will automatically respond to XON and XOFF codes received from a channel. The CXA16/CXB16 uses the TX.ENA bit in TBUFFAD2 to stop and start the flow. If DISAB.XRPT is also set, XON/XOFF codes are not entered in the receive FIFO. | | 3 | BREAK (Break<br>Control) (R/W) | If set, this bit forces the transmitter of this channel to the spacing state. | | | | Transmission is restarted when the bit is cleared. | | | of up to 200 mic<br>the bit and the ch<br>a character is alre<br>the OCTART, the<br>transmitted immedia | NOTE e, there may be a delay roseconds between writing annel changing state. If eady being transmitted by BREAK signal will be ately afterwards. | | 2 | RX.ENA (Receiver<br>Enable) (R/W) | If set, this receiver channel is enabled. | | | | If reset when this OCTART channel is assembling a character, that character is lost. | | | | The bit is cleared by MASTER.RESET. | | 1 | IAUTO (Incoming Auto<br>Flow) (R/W) | This is the auto-flow control bit for incoming characters. If it is set, the CXA16/CXB16 will control incoming characters by transmitting XON and XOFF codes. | | | | If the receive FIFO becomes more than three-quarters full, the CXA16/CXB16 will send an XOFF code to channels with this bit set. If a character is received, an XON will be sent when the receive FIFO becomes less than half full. | | Bit | Name | Description | |-----|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | TX.ABORT (Transmit<br>Abort) (R/W) | This bit is set by the driver program to halt data transmission. If a DMA transfer was in progress, the DMA address and count registers (TBUFFAD1, TBUFFAD2, and TBUFFCT) will be updated to reflect the number of characters which have been transmitted. The transfer can be continued by clearing TX.ABORT, and then setting TX.DMA.START in TBUFFAD2. No characters will be lost. | | | | If DMA is not in progress, the following actions will occur: DHVll mode no action DHUll mode characters in the transmit FIFO will be discarded. Because of sequencer delays, it is possible to transmit a few characters before the abort is actioned. Therefore, the host cannot determine how many characters have been lost. | | Bit | Name | | Description | |-----|----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | TX.ABORT | (cont.) | When an abort sequence has been completed, the CXAl6/CXBl6 will set the TX.ACTION bit in the CSR. If the transmitter interrupt is enabled, the program will be interrupted at the transmit vector. | | | | | The program must make sure that TX.ABORT is clear before setting TX.DMA.START. Otherwise, the transfer will be aborted before any characters are transmitted. | | | | | The bit is cleared by MASTER.RESET. | # 3.2.2.10 Transmit Buffer Address Register Number 1 (TBUFFAD1) -- RD1178 | Bit | Name | Description | |--------|-----------------------------------------------------|---------------------------------| | <15:0> | TBUFFAD<15:0> (Transmit Buffer Address [Low]) (R/W) | Bits <15:0> of the DMA address. | # 3.2.2.11 Transmit Buffer Address Register Number 2 (TBUFFAD2) -- # TBUFFAD2 (BASE + 14) | Bit | Name | Description | |-----|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------| | 15 | TX.ENA (Transmitter Enable) (R/W) | When this bit is set, the CXA16/CXB16 will transmit all characters. | | | | When cleared, the CXA16/CXB16 will only transmit internally generated flow-control characters. | | | | The bit is set by MASTER.RESET. | | | | In the OAUTO mode, this bit is used by the CXA16/CXB16 to control outgoing characters. | | 7 | TX.DMA.START (Transmit DMA Start) (R/W) | This bit is set by the host to start a DMA transfer. The CXA16/CXB16 will reset the bit before returning TX.ACTION. | | | | The bit is cleared by MASTER.RESET. | | | • | NOTE | | | write to TBUFFCT | bit, the host must not, TBUFFAD1, or TBUFFAD2.ACTION report has been | | Bit | Name | Description | |-------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <5:0> | TBUFFAD<21:16> (Transmit Buffer Address [High]) (R/W) | Bits <21:16> of the DMA address. Before a DMA transfer, TBUFFAD1 and the low byte of TBUFFAD2 are loaded with the start address of the DMA buffer. This address will be continuously changing during a DMA transfer and has no meaning. Once TX.ACTION has been returned, the register contains the final DMA transfer address. | # 3.2.2.12 Transmit DMA Buffer Counter (TBUFFCT) -- TBUFFCT (BASE + 16) DMA CHARACTER COUNT (WHEN VALID HOLDS NO. OF CHARS STILL TO BE SENT) RD1179 | Bit | Name | Description | |--------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------| | <15:0> | TX.CHAR.CT (Transmit<br>Character Count)<br>(R/W) | This word is loaded with the number of characters to be transferred by the DMA. | | | | The number of characters is specified as a 16-bit unsigned integer. | | | | After a DMA transfer has been aborted, this location will hold the number of characters still to be transferred. | | | | See also the previous NOTE. | #### 3.3 PROGRAMMING FEATURES # 3.3.1 Initialization The CXAl6/CXBl6 is initialized by its on-board sequencers. Initialization takes place after a bus reset sequence, or when the host sets CSR<5> (MASTER.RESET). Before starting initialization, the on-board diagnostics run a self-test program. The results of this test are reported by eight diagnostic bytes in the receive FIFO. The CXAl6/CXBl6 state, after a successful self-test, is as follows: - 1. Eight diagnostic codes are placed in the receive FIFO - 2. The diagnostic fail bit (CSR<13>) is reset - 3. All channels set for: - a. Send and receive 9600 bits/s - b. Eight data bits - c. One stop bit - d. No parity - e. Parity odd - f. Auto-flow off - q. Receive disabled - h. Transmit enabled - i. No break on line - j. No loopback - k. DMA character counter zero - 1. DMA start address register zero - m. TX.DMA.START cleared - n. TX.ABORT cleared - o. AUTOFLOW REPORTS enabled The CXAl6/CXBl6 clears the MASTER.RESET bit (CSR<5>) when initialization and self-test are complete. 3.3.2 Configuration After CXAl6/CXBl6 self-initialization, the driver program can configure the CXAl6/CXBl6 as needed. This is done through the LPR and LNCTRL registers. The line characteristics for a channel can be set up by writing to the LPR and LNCTRL registers associated with this channel. These are: - Transmit speed - Receive speed - Number of stop bits - Parity type or parity disabled - Character length - Flow-control characteristics - Normal or maintenance mode - Receiver enable/disable # NOTE If RX.ENA is reset while a received character is being assembled, that character will be lost. 3.3.3 Transmitting Each CXA16/CXB16 channel can be set up to transfer the characters by DMA for transmission, or characters can be transferred to the module under program control. 3.3.3.1 DMA Transfers -- Before setting up the transfer of a DMA buffer, the program should make sure that TX.DMA.START is not set. TBUFFCT, TBUFFAD1, and TBUFFAD2 should not be written unless TX.DMA.START is clear. Transmission starts when the program sets TX.DMA.START. DMA buffer size and start address can be written to TBUFFCT, TBUFFAD1, and TBUFFAD2 in any order. However, TBUFFAD2 contains TX.ENA and TX.DMA.START, so it is probably simpler to write to TBUFFAD2 last. By using byte operations on this register, TX.ENA and TX.DMA.START can be separated. The CXAl6/CXBl6 will perform the transfer and set TX.ACTION when it is complete. If TXIE is set, the program will be interrupted at the transmit vector. Otherwise, TX.ACTION must be polled. TX.ACTION is not returned until the UART has completely transmitted the last character of the DMA buffer. To abort a DMA transfer, the program must set TX.ABORT. The CXAl6/CXBl6 stops transmission and updates TBUFFCT, TBUFFAD1, and TBUFFAD2 <7:0> to reflect the number of characters transmitted. TX.DMA.START will be cleared. If TXIE is set, TX.ACTION interrupts the program at the transmit vector. If the program clears TX.ABORT and sets TX.DMA.START, transfer can be continued without loss of characters. If a DMA transfer fails because of a memory error, the transmission will be terminated. TBUFFAD1 and TBUFFAD2 will point to the failing location. TBUFFCT will be cleared. 3.3.3.2 Programmed I/O (DHV11 Mode) -- Single characters are transferred through a channel TX.CHAR register. The character and the DATA.VALID bit must be written as defined in Section 3.2.2.3. Note that the character and the DATA.VALID bit can be written by separate MOVB instructions. The CXAl6/CXBl6 returns TX.ACTION when the module removes the character from TX.CHAR. This will generate an interrupt if TXIE is set. #### NOTE In single-character mode, TX.ACTION is returned when the CXA16/CXB16 accepts the character, not when it has been transmitted. Each channel can buffer up to three characters. Therefore, if line parameters are changed immediately after the last TX.ACTION of a message, the end of the message could be lost unless three null characters are added to the end of each single-character programmed transfer message. 3.3.3.3 Programmed I/O (DHUll Mode) -- Before writing a character or sequence of characters to the FIFODATA register, the program should read the FIFOSIZE register to check that there is space in the transmit FIFO. If there is enough space, characters can be written as bytes (one character) or words (two characters) to FIFODATA. After a low-byte write, FIFODATA <7:0> is transferred to the FIFO. After a word write, FIFODATA <7:0> is transferred to the FIFO, followed by FIFODATA <15:8>. High-byte writes to FIFODATA are not allowed. The CXAl6/CXBl6 returns TX.ACTION when the transmit FIFO becomes empty. An interrupt will also be generated if TXIE is set. As distinct from DMA mode, in programmed I/O mode TX.ACTION is returned when the CXAl6/CXBl6 transfers the last character from the transmit FIFO to the OCTART, not when it has been transmitted. Thus, if line parameters are changed immediately after the last TX.ACTION of a message, the end of the message could be lost. The program can avoid this loss by adding two null characters to the end of each programmed transfer FIFO message. 3.3.4 Receiving Received characters, tagged with the channel number, error information, and DATA.VALID, are placed in the receive FIFO. RX.DATA.AVAIL is clear when the receive FIFO is empty. When a character is put into the empty receive FIFO, the CXA16/CXB16 sets RX.DATA.AVAIL. A receive interrupt is generated if RXIE is set. RX.DATA.AVAIL stays set while there is valid data in the receive FIFO. It is recommended that the receive character routine continues to read characters from the receive FIFO until DATA.VALID is clear. #### NOTE The interrupt is dynamic. It is raised as RX.DATA.AVAIL is set after RXIE, or as RXIE is set after RX.DATA.AVAIL. If the interrupt routine does not empty the receive FIFO, RXIE must be toggled to raise another interrupt. In DHUll mode, the interrupt is generated after a delay (set by RX.TIMER). If RXIE is not set, the program must poll RBUF often enough to prevent data loss. 3.3.5 Interrupt Control The CXAl6/CXBl6 provides one of two vector addresses during a bus interrupt sequence. The receive vector address is the address set up on the vector address switches. The transmit vector address is the receive vector address + 4. The receive interrupt is generated when: - RXIE is set and a character is placed into an empty receive FIFO - RXIE is changed from 0 to 1, and the receive FIFO contains one or more characters. # NOTE In DHUll mode an interrupt is generated either immediately, or after the delay set by RX.TIMER. The transmit interrupt vector is generated when: - TXIE is set and TX.ACTION becomes set - TXIE is changed from 0 to 1 while TX.ACTION is set #### NOTE The TX.ACTION FIFO can hold up to 16 TX.ACTION reports, but an interrupt is only generated when the FIFO receives a TX.ACTION after being empty. Therefore it is recommended that your program reads the CSR until the TX.ACTION bit becomes clear. Reports will be lost if more than 16 have accumulated. At the two vectors, the host must provide the addresses of suitable routines to deal with the above conditions. In DHUll mode, an interrupt is generated either immediately data is put into an empty receive FIFO, or after a delay, set by RX.TIMER. #### 3.3.6 Auto XON and XOFF XON and XOFF characters are commonly used to control data flow on communications channels. To use this facility, interfaces must have suitable decoding hardware or software. A channel using flow control that receives an XOFF stops sending characters until it receives an XON. A channel becoming overrun by received data sends an XOFF. It sends an XON when it can safely receive more data, if flow control is enabled. The CXA16/CXB16 automatically controls character flow when programmed accordingly (auto-flow). Four bits control this function: - IAUTO -- LNCTRL<1> - FORCE.XOFF -- LNCTRL<5> - OAUTO -- LNCTRL<4> - DISAB.XRPT -- LPR<0> IAUTO and FORCE.XOFF both control incoming characters. IAUTO is an enable bit which allows the level of the receive FIFO to control the generation of XOFF and XON characters. The FORCE.XOFF bit is a direct command from the program to control the incoming data stream. 1. The CXA16/CXB16 hardware recognizes when the receive FIFO is three-quarters full and half full. The logic uses these states for auto-flow control. Each channel has a separate IAUTO bit. If there are 191 or more characters in the receive FIFO, and a character is received on a channel with IAUTO set, an XOFF character is sent. If the channel does not respond to the XOFF, the CXA16/CXB16 will send another XOFF in response to every alternate character received. An XON will be sent when the receive FIFO contains less than 128 characters, unless the FORCE.XOFF bit for that channel is set. XONs are only sent to channels to which an XOFF has previously been sent. By inserting XON and XOFF characters into the data stream, the program can perform flow-control directly. However, if the CXA16/CXB16 is in IAUTO mode, the results will be unpredictable. In IAUTO mode, if RX.ENA is set, XON and XOFF characters will be transmitted even if TX.ENA is cleared. - 2. When FORCE.XOFF is set, the CXA16/CXB16 sends an XOFF and then acts as if IAUTO is set and the receive FIFO is critical (was three-quarters full, and is not yet less than half full). When FORCE.XOFF is reset, an XON will be sent unless the receive FIFO is critical and IAUTO is set. - 3. If the program sets OAUTO, the CXA16/CXB16 will automatically respond to XON and XOFF characters from the channel. It does this by clearing or setting the TX.ENA bit. The program may also control the TX.ENA bit, so in this case it is important to keep track of received XON and XOFF characters. Received XON and XOFF characters will always be reported through the receive FIFO, unless the DISAB.XRPT bit is set. It is possible, during read-modify-write operations by the program, for the CXA16/CXB16 to change the TX.ENA bit between the read and the write actions. For this reason, if DMA transfers are started while OAUTO is set, it is advisable to write to the low byte of TBUFFAD2 only. 4. If DISAB.XRPT is clear, XON and XOFF characters will be processed as normal characters and entered into the receive FIFO. DISAB.XRPT allows the individual line OAUTO bits to control whether XON or XOFF characters received on that channel are discarded. When DISAB.XRPT is set and OAUTO is set, this filtering is enabled. #### NOTES - 1. The CXA16/CXB16 may change the state of TX.ENA for up to 50 microseconds after OAUTO is cleared by the program. - 2. When checking for flow-control characters, the CXA16/CXB16 checks only characters which do not contain transmission errors. The parity bit is stripped, and the remaining bits are checked for XON (21(octal)) and XOFF (23(octal)) codes. - 3. Auto flow-control does not absolutely guarantee overrun errors will not occur. These errors may still occur if the transmitting devices do not respond to the XOFF immediately. #### 3.3.7 Error Indication Four bits inform the program of transmission and reception errors. - TX.DMA.ERR -- CSR<12>. - PARITY.ERR -- RBUF<12>. - FRAME.ERR -- RBUF<13>. - OVERRUN.ERR -- RBUF<14>. RBUF<14:12> may also identify a diagnostic code. ## 3.3.8 Maintenance Programming The host can set bits 7 and 6 of LNCTRL to allow each channel to be configured in normal, automatic echo, local loopback, and remote loopback modes. These modes allow an individual data channel to be looped back to the host, or to be looped back to the terminal to assist in isolating communication problems. The host must provide suitable software to use these modes. ## 3.3.9 Diagnostic Codes 3.3.9.1 Self-Test Diagnostic Codes -- After bus reset or master reset, the CXAl6/CXBl6 executes a self-test and initialization sequence. During the sequence, eight diagnostic codes are put in the receive FIFO, and RX.DATA.AVAIL is set. After an error-free test, DIAG.FAIL will be reset and the 'diagnostic passed' LED will be on. If an error is detected, DIAG.FAIL will be set and the LED will be off. 3.3.9.2 Interpretation of Self-Test Codes -- The high byte of diagnostic codes in RBUF can be interpreted as in Section 3.2.2.2, except that bits <11:8> are not the line number. They indicate the sequence of the diagnostic byte, that is to say, 0 = first byte, 1 = second byte, and so on. Table 3-4 shows the meaning of each of the error codes. Table 3-4 CXA16/CXB16 Self-Test Error Codes | Code (Octal) bits<7:0> | Test | |---------------------------------|-------------------------------------------------------------------------------------------------------| | 201<br>203<br>211<br>213<br>225 | Self-test null code (used as a filler) Self-test skipped Low OCTART error High OCTART error RAM error | | All other error | error codes should be treated as an undefine | | If bit 7 = circuit re | = 0 and bit 0 = 1, then bits <5:2> contain evision information | | Bit 6 alwa | ays reads 1 for the CXA16/CXB16, and indicate circuit contains control and OCTART chips | | | cates to which chip the information refers: | After self-test, the eight FIFO codes consist of six diagnostic codes and two circuit-revision codes. If there are less than six errors to report, null codes (201(octal)) fill the unused places. After an error-free test, six null codes and two circuit-revision codes will be returned. Self-test may be 'skipped' to shorten the initialization cycle (see Section 3.3.9.3). The module is still tested, even if self-test is skipped. The reset delay is much shorter, but test coverage is not affected; therefore skipping self-test is advantageous. After 'skip self-test' self-test, the eight FIFO codes consist of six diagnostic codes and two circuit revision codes. If there are fewer than six errors to report, 203(octal) codes fill the unused places. After an error-free test, six 203(octal) codes and two circuit revision codes will be returned. 3.3.9.3 Skipping Self-Test -- In DHUll mode only, the method is to set SKIP (CSR bit 4) and MASTER.RESET (CSR bit 5) simultaneously, that is, write 60(octal) to the CSR register. SKIP must not be cleared until at least 20 microseconds after it was set. SKIP must be cleared by the host so that the master reset sequence can complete. In DHVll mode (this also works in DHUll mode, but the previous method is preferred) the following method is used: - The program resets the CXA16/CXB16. - 2. The program waits 10 ms (+ or 1 ms) after issuing reset, and then writes 052525(octal) throughout the control registers (not the CSR) within the next 4 ms. - 3. The self-test sequencer waits until 16 ms after reset, and then checks for a 052525(octal) code in common RAM. If it finds the code, the DIAG.FAIL bit is cleared, and the reset delay is shortened to 30 ms. If the code is not found, the reset delay is between one and two seconds. #### NOTE The program must not write to the CSR, or to the control registers, during the period starting 15 ms after reset, and ending when the MASTER.RESET bit is cleared. Writing during this period could cause a diagnostic fail condition. 3.3.9.4 Background Monitor Program (BMP) -- The CXA16/CXB16 BMP logic performs background self-tests by checking for OCTART interrupts. One or two codes are returned to the receive FIFO: 305(octal) -- CXA16/CXB16 running 307(octal) -- CXA16/CXB16 defective (also LED off) A single diagnostic word is returned to the receive FIFO. The low byte contains the diagnostic code. In the high byte, OVERRUN.ERR, FRAME.ERR, and PARITY.ERR are all set to indicate that bits <7:0> do not hold a normal character. The line number (RBUF<11:8>) = 0. BMP normally only reports when it finds an error. However, the program can get a BMP report at any time to validate the CXA16/CXB16. This is done by setting DIAG (LPR <2:1>) of any channel to 01. The line number returned is that of the LPR used to request the report. On completing the check, BMP clears the 01 code in DIAG. The host should not write to the LPR of that channel until DIAG is cleared to 00. #### 3.4 PROGRAMMING EXAMPLES This section contains programming examples of the CXAl6/CXBl6 used in DHUll mode. Programs for DHVll mode are included. These programs are not presented as the only way of driving the option, and are neither guaranteed nor supported. ## 3.4.1 Resetting the CXA16/CXB16 In the following example: - DIAG is a routine to check the diagnostic codes. It returns with CARRY set if it detects an error code. - The loop at 1\$ can take up to 2.5 seconds, so the programmer could poll by using a timer or poll at interrupt level zero. ``` ; A ROUTINE TO RESET THE CXA16/CXB16 AND CHECK THAT IT IS ; FUNCTIONING CORRECTLY. CXARES:: MOV #40,0#CXACSR ; SET MASTER.RESET AND ; CLEAR INTERRUPT ENABLES. 1$: BIT #40,@#CXACSR ; WAIT FOR MASTER.RESET TO ; CLEAR. BNE BIT #20000,@#CXACSR ; CHECK THE DIAGNOSTICS FAIL BNE DIAGER ; BIT. ; NOTE: TEST INSTRUCTION IS ; OK BECAUSE THERE ARE : NO TX.ACTS PENDING. MOV #8.,R5 ; SET UP A COUNT. 2$: VOM @#RBUFF,RO ; GET NEXT DIAGNOSTIC CODE. ; PROCESS IT. JSR PC, DIAG BCS DIAGER ; CARRY SET - MUST HAVE BEEN ; AN ERROR. SOB R5,2$ ; GO BACK FOR NEXT CODE. RTS PC ; RETURN - CARD IS RESET. ; CXA16/CXB16 HAS FAILED TO RESET PROPERLY, SO HALT AND WAIT FOR ; THE FIELD SERVICE ENGINEER. ``` DIAGER: HALT BR DIAGER ## 3.4.2 Configuration This routine sets the characteristics of channel 1 as follows: - 1. Transmit and receive at 300 bits/s - 2. Seven data bits with even parity and one stop bit - Transmitters and receivers enabled No automatic flow control. #### SETUP:: ; LOAD INDEX REG #1,@#CXACSR MOV ; WITH CHANNEL NO. ; DATA RATE, STOP BITS, #052560,@#LPR MOV ; PARITY AND LENGTH. ; ENABLE THE RECEIVER. ; ENABLE THE TRANSMITTER. MOV #4,@#LNCTRL MOVB #200,@#TBFAD2+1 ; RETURN - CHANNEL 1 DONE. RTS PC #### 3.4.3 Transmitting 3.4.3.1 Programmed Transfer (DHUll Mode) -- The following is a program to send a message on channel 1. The CSR is polled for TX.ACTION reports, but a TX.ACTION interrupt could also be used. This program would function on a CXA16/CXB16 with only this channel active. Otherwise it would lose TX.ACTION reports of other channels. However, a program to control all channels would be too big to use as an example. ``` ; A ROUTINE TO WRITE A MESSAGE TO CHANNEL 1 USING FIFO OUTPUT ; MODE (PROGRAMMED TRANSFERS). FIFOUT:: ; POINT TO CHANNEL WE WISH MOV #1,@#CXACSR ; TO TALK TO. ; POINT TO MESSAGE. #MESS,RO MOV ; PUT COUNT IN. MOV #MESIZE,Rl 1$: ; CHECK THAT THERE IS SPACE IN @#FIFOSIZE TSTB ; THE FIFO. 1$ BEO (R0)+,@#FIFODATA ; MOVE CHARACTER TO TRANSMIT FIFO. MOVB ; GO BACK FOR NEXT CHARACTER. R1,1$ SOB 2$: ; WAIT FOR TX.ACT. MOV @#CXACSR,R2 BPL 2$ ; ISOLATE CHANNEL NUMBER. BIC #170377,R2 #000400,R2 CMP ; IGNORE THE TX.ACT IF IT IS BNE 2$ ; NOT OURS (SHOULD NOT HAPPEN). ; MESSAGE SENT. PC RTS .ASCII /A TRANSMIT FIFO MESSAGE FOR CHANNEL 1/ MESS: MESIZE = .-MESS .EVEN ``` 3.4.3.2 Single-Character Programmed Transfer (DHV11 Mode) -- This is a program to send a message on channel 1. The message (MESS) is an ASCII string with a null character as terminator. Polling is used, but a TX.ACTION interrupt could also be used. This program would function on a CXA16/CXB16 with only this channel active. Otherwise it would lose TX.ACTION reports of other channels. However, a program to control all channels would be too big to use as an example. ``` ; A ROUTINE TO WRITE A MESSAGE TO CHANNEL 1 USING SINGLE-CHARACTER ; MODE. SINGOT:: ; LOAD INDEX REG WITH MOV #1,0#CXACSR ; CHANNEL NO. ; POINT TO MESSAGE. MOV #MESS,RO 1$: ; MOVE CHARACTER TO TRANSMIT MOVB (RO)+,@#TXCHAR ; BUFFER. ; GO RETURN IF ALL BEO 3$ ; CHARACTERS GONE. ; SET DATA VALID BIT TO MOVB #200,@#TXCHAR+1 ; START. MOV 2$: @#CXACSR,Rl ; WAIT FOR TX.ACT 2$ BPL #174377,R1 ; ISOLATE CHANNEL NUMBER. BIC CMP #000400,R1 ; IGNORE THE TX.ACT IF IT IS TXI BNE 2$ ; NOT OURS (SHOULD NOT HAPPEN) ; GO BACK FOR NEXT CHARACTER. BR 1$ 3$: RTS PC : MESSAGE SENT. MESS: .ASCIZ /A SINGLE-CHARACTER MESSAGE FOR CHANNEL 1/ ``` #### 3.4.3.3 DMA Transfer -- ``` ; THIS PROGRAM SENDS A MESSAGE OUT ON EACH LINE OF THE CXA16/CXB16 ; AND HALTS THE MACHINE WHEN ALL TRANSMISSIONS HAVE COMPLETED. ; THE MESSAGES ARE TRANSMITTED USING DMA MODE, AND INTERRUPTS ARE ; USED TO SIGNAL TRANSMISSION COMPLETION. DMAINT:: MOV #TXINT, @#TXVECT ; SET UP THE INTERRUPT VECTORS. VOM #200,@#TXPSW ; INTERRUPT PRIORITY FOUR. MOV #16.,R0 ; SIXTEEN LINES TO START. CLR Rl ; START AT LINE ZERO. 1$: MOVB R1,0#CXACSR ; SELECT THE REGISTER BANK. VOM #DMASIZ, @#TBFCNT ; SET LENGTH OF MESSAGE. VOM #DMAMES, @#TBFAD1 ; SET LOWER 16 ADDRESS BITS. MOV #100200,@#TBFAD2 ; START DMA WITH TRANSMITTER ; ENABLED (ASSUME UPPER ADDRESS ; BITS ARE ZERO). INC Rl ; POINT TO NEXT CHANNEL. SOB R0,1$ ; REPEAT FOR ALL LINES. CLR R5 ; R5 IS USED BY INTERRUPT ROUTINE. MOVB #100,@#CXACSR+1 ; ENABLE TRANSMITTER INTERRUPTS. 2$: #16.,R5 CMP ; WAIT FOR ALL LINES TO FINISH. BNE 2$ 3$: HALT ; ALL DONE, SO STOP. 3$ BR ``` ``` ; TRANSMITTER INTERRUPT ROUTINE. ; R5 IS INCREMENTED AS EACH LINE COMPLETES. TXINT:: MOV @#CXACSR,RO ; GET LINE NUMBER OF FINISHED LINE. BIT #100000,R0 ; CHECK FOR (ANOTHER) TX.ACTION. BEQ 4$ ; IF NOT, GO RETURN AND WAIT. BIT #010000,R0 ; CHECK FOR DMA FAILURE. BNE 5$ ; GO HALT - MEMORY PROBLEM. ; NOT USED IN DHV11 MODE. INC R5 ; FLAG THAT ANOTHER LINE HAS FINISHED. BR TXINT 4$: RTI 5$: HALT ; MEMORY PROBLEM. 5$ BR DMAMES: .ASCII <15><12><7><7>/SYSTEM CLOSING DOWN NOW/ DMASIZ = .-DMAMES .EVEN ``` ## 3.4.3.4 Aborting a Transmission -- ``` ; THIS ROUTINE IS CALLED TO ABORT A TRANSMISSION (EITHER DMA OR ; FIFO) IN PROGRESS ON A SPECIFIED LINE. THIS ROUTINE MAKES THE ; (RATHER RASH) ASSUMPTION THAT THERE ARE NO OTHER TRANSFERS ; PROGRESS. ; ON ENTRY, RO CONTAINS THE NUMBER OF THE LINE TO BE ABORTED. TXABRT:: MOV RO,@#CXACSR ; POINT TO THE CHANNEL TO BE ABORTED. BIS #1,0#LNCTRL ; SET THE TRANSMIT ABORT BIT. 1$: MOV @#CXACSR,R1 ; WAIT FOR THE TX.ACT. BPL 1$ Rl ; CHECK IT IS OUR LINE. SWAB BIC #177760,R1 CMP RO,R1 BNE 1$ ; IGNORE IT IF IT IS NOT (OUR ; ASSUMPTION WAS WRONG!) BIC #1,@#LNCTRL ; CLEAR DOWN THE ABORT FLAG ; FOR NEXT TIME. RTS PC ; BUFFER COMPLETELY ABORTED, ; IF A DMA WAS IN PROGRESS, THE ; DMA REGISTERS REFLECT WHERE ; THE CXA16/CXB16 HAD GOT TO. ``` ## 3.4.4 Receiving ``` ; THIS ROUTINE PROCESSES RECEIVED CHARACTERS UNDER INTERRUPT CONTROL. ; IF AN XOFF IS RECEIVED, THE TRANSMITTER FOR THAT CHANNEL IS TURNED ; OFF. IF AN XON IS RECEIVED, THE TRANSMITTER IS TURNED BACK ON. ALL ; OTHER CHARACTERS ARE IGNORED. RXAUTO:: ; SET UP THE INTERRUPT VECTORS. VOM #RXINT,@#RXVECT ; INTERRUPT PRIORITY FOUR. #200,@#RXPSW MOV ; ENABLE ALL THE RECEIVERS, #16.,R0 MOV ; STARTING AT CHANNEL ZERO. CLR Rl 1$: R1,@#CXACSR ; SELECT THE LINE. MOVB ; ENABLE THIS RECEIVER. #4,@#LNCTRL BIS ; SET POINTER TO NEXT CHANNEL. INC Rl SOB RO,1$ ; SELECT CHANNEL ZERO. MOVB #0,@#CXACSR #20.,@#RXTIMR ; SET DELAY TO 20MS. MOV . ; NOT USED IN DHV11 MODE. ; ENABLE THE RECEIVER INTERRUPTS. MOVB #100,@#CXACSR RTS ; RETURN - PC INTERRUPTS DO THE RESET. ``` ``` ; INTERRUPT ROUTINE TO DO THE MAIN TASK. RXINT:: MOV R0,-(SP) ; SAVE CALLER'S REGISTERS. RXNXTC: MOV @#RBUFF,RO ; GET THE CHARACTER. BPL RXIEND ; IF NO DATA VALID, WE HAVE FINISHED. MOV. R0,-(SP) ; CHECK FOR ERRORS AND #107777,(SP)+ ; DIAGNOSTICS CODES. BIC BNE RXNXTC - JUST IGNORE THEM (BAD PRACTICE). BIC #170200,R0 ; REMOVE UNNECESSARY BITS. SWAB ; POINT TO THIS CHARACTER'S LINE. R0 #100,R0 ; (ADD THE INTERRUPT ENABLE BIT.) BIS MOVB RO,@#CXACSR SWAB R0 ; PUT CHARACTER BACK IN LOWER BYTE. #21,R0 ; WAS IT AN "XON"? CMPB BNE 1$ ; NO - GO CHECK FOR AN "XOFF" BISB #200,0#TBFAD2+1; ENABLE THE TRANSMITTER. RXNXTC BR ; GO CHECK FOR MORE CHARACTERS. 1$: ; WAS IT AN "XOFF"? CMPB #23,R0 BNE RXNXTC ; NO - GO CHECK FOR MORE CHARACTERS. BICB #200,0#TBFAD2+1; DISABLE THE TRANSMITTER. ; GO CHECK FOR MORE CHARACTERS. BR RXNXTC RXIEND: ; RESTORE THE DESTROYED REGISTER. MOV (SP)+R0 RTI ``` ## 3.4.5 Auto XON and XOFF ``` THIS PROGRAM SENDS A MESSAGE OUT ON EACH LINE OF THE CXA16/CXB16 AND HALTS THE MACHINE WHEN ALL TRANSMISSIONS HAVE COMPLETED. THE MESSAGES ARE TRANSMITTED USING DMA MODE, AND INTERRUPTS ARE USED TO SIGNAL TRANSMISSION COMPLETION. ; AUTOMATIC FLOW CONTROL IS ENABLED ON THE OUTGOING DATA. TXAUTO:: MOV #ATOINT,@#TXVECT ; SET UP THE INTERRUPT VECTORS. #200,@#TXPSW MOV ; INTERRUPT PRIORITY FOUR. #16.,R0 MOV ; SIXTEEN LINES TO START. CLR Rl ; START AT LINE ZERO. 1$: R1,@#CXACSR MOVB ; SELECT THE REGISTER BANK. BIS #24,@#LNCTRL ; ENABLE AUTOMATIC FLOW CONTROL ; ON THE TRANSMITTED DATA. MOV #AUTOSZ,@#TBFCNT ; SET LENGTH OF MESSAGE. MOV #AUTOMS, @#TBFAD1 ; SET LOWER 16 ADDRESS BITS. #100200,@#TBFAD2 MOV ; START DMA WITH TRANSMITTER ; ENABLED (ASSUME UPPER ADDRESS ; BITS ARE ZERO). INC Rl ; POINT TO NEXT CHANNEL. SOB R0,1$ ; REPEAT FOR ALL LINES. CLR ; R5 IS USED BY INTERRUPT ROUTINE. R5 #100,0#CXACSR+1 MOVB ; ENABLE TRANSMITTER INTERRUPTS. 2$: CMP #16.,R5 ; WAIT FOR ALL LINES TO FINISH. BNE 2$ 3$: HALT ; ALL DONE, SO STOP. BR 3$ ``` ``` ; TRANSMITTER INTERRUPT ROUTINE. ; R5 IS INCREMENTED AS EACH LINE COMPLETES. ATOINT:: ; GET LINE NUMBER OF FINISHED LINE. @#CXACSR,R0 VOM ; GO RETURN IF NO MORE TX.ACTIONS. 2$ BPL ; NOT USED IN DHV11 MODE ; CHECK FOR DMA FAILURE. #10000,R0 BIT ; GO HALT - MEMORY PROBLEM. BNE 4$ ; FLAG THAT ANOTHER LINE HAS FINISHED. INC R5 ; CHECK FOR MORE TX.ACTIONS. BR ATOINT ; NOT USED IN DHV11 MODE 2$: RTI 4$: ; MEMORY PROBLEM HALT 4$ BR AUTOMS: .ASCII <15><12><7><7>/SYSTEM CLOSING DOWN NOW/ .-AUTOMS AUTOSZ = .EVEN ``` ## 3.4.6 Checking Diagnostic Codes ``` ; THIS ROUTINE CHECKS THE DIAGNOSTICS CODES RETURNED FROM THE ON ENTRY, RO CONTAINS THE CHARACTER RECEIVED FROM THE ; CXA16/CXB16. ; CXA16/CXB16. ON EXIT, THE CARRY BIT WILL BE CLEAR FOR SUCCESS, ; SET FOR FAILURE. DIAG:: ; SAVE THE CODE FOR LATER. R0,-(SP) MOV ; CHECK THAT IT IS A DIAG. CODE. #107776,R0 BIC CMP #070001,R0 ; IF NOT, JUST EXIT NORMALLY. BNE DIAGEX ; GET THE CODE BACK. (SP),R0 MOV ; CHECK FOR ROM VERSION NUMBER. #200,R0 BITB DIAGEX BEQ ; SELF-TEST NULL CODE. #201,R0 CMPB DIAGEX BEO ; SELF-TEST SKIPPED CODE. #203,R0 CMPB DIAGEX BEQ ; CXA RUNNING CODE. #305,R0 CMPB DIAGEX BEO ; ALL THE REST ARE ERROR CODES. ; AN ERROR CODE WAS RECEIVED, SO SEC ; SET THE CARRY FLAG. DIAGXX BR DIAGEX: ; EVERYTHING OK, SO CLEAR CARRY. CLC DIAGXX: ; RESTORE THE CHARACTER/INFO. (SP)+R0 VOM RTS PC ``` #### 4.1 SCOPE This chapter explains how to isolate the cause of a communications problem between the CXA16/CXB16 and the equipment to which it is connected. #### 4.2 TROUBLESHOOTING #### 4.2.1 Preventive Maintenance No preventive maintenance is needed for this option. However, you should always ensure that all cables are clear of danger, and that all the connectors are secure. Make sure that all cables are clearly labeled, so that you can easily identify which channel number and which CXAl6/CXBl6 module are associated with each terminal. ## 4.2.2 Troubleshooting Procedures Troubleshooting procedures are to identify whether the problem is caused by: - The module - A terminal - The cabling. First decide whether the problem is associated with one channel, a group of 8 channels, or all 16 channels. If all channels are faulty, run the user diagnostics to test the module. Also check whether your software has a driver for the CXA16/CXB16. If a group of eight channels is faulty, check the BC16D-25 cables between the module and the cable concentrator. For single-channel problems: - 1. Check for loose cables and connectors. - 2. Verify that the terminal is working correctly. If necessary, swap it with another one. - 3. Verify that the signals from the terminal are reaching the CXA16/CXB16 by using the H3101 test connector. - Check which CXA16/CXB16 line is suspect and disconnect the appropriate 36-way connector at the CXA16/CXB16 bulkhead. #### NOTE This interrupts the other seven lines using that connection. - Connect the cable to the H3101 loopback connector (see Figure 4-1). - Type characters at the terminal connected to the suspect line. If characters are echoed back when the H3101 is connected, the cable and terminal are working. - 4. Rectify the cable or terminal fault, if there is one. If not, make sure that the user diagnostics for the module run correctly, and that the communication parameters selected for that channel match the terminals characteristics. Figure 4-1 Cable Loopbacks ## 4.3 INTERNAL DIAGNOSTICS Internal diagnostics run without intervention from the operator. There are two tests: the self-test and the background monitor program (BMP). #### 4.3.1 Self-Test The self-test starts immediately after the Q-bus or module has been reset. It performs a comprehensive internal logic test, but does not test the Q-bus interface or serial-line drivers and receivers. The self-test gives a GO/NO-GO indication via the DIAG.FAIL bit and the 'diagnostics passed' LED on the module. The self-test also reports error or status information to the host via the receive FIFO. The self-test has completed successfully if the LED is ON two seconds after the self-test has been initiated, either by powering up the module or by resetting the module through the program interface. The LED is turned off while the self-test sequencer is executing. The OFF period varies depending on whether DHVll or DHUll mode was selected, and on whether the self-test was invoked using the self-test skip feature of the program interface; but this will not exceed two seconds. Self-test provides a high level of confidence that the majority of the module logic is working. The user diagnostics must also be used to test the Q-bus interface and verify that the switch settings on the module switchpacks are correct. ## 4.3.2 Background Monitor Program (BMP) When the CXA16/CXB16 is not doing other tasks, the BMP carries out tests on the module. If an error is detected, the BMP reports to the host via the receive FIFO, and also switches OFF the 'diagnostics passed' LED. By writing codes to the line-parameter register, the host can cause the BMP to report the status of the device, even if an error has not been detected. This facility is used if the host suspects that the option is unavailable. #### NOTE More information on the self-test and BMP diagnostics is given in Chapter 3 of this manual. ## 4.4 MicroPDP-11 DIAGNOSTICS ## 4.4.1 User-Mode Diagnostics These tests can be used by an untrained operator to verify the basic operation of the option. User-mode tests do not cause any disruption to data networks or devices to which the CXA16/CXB16 may be connected. Such networks and devices do not have to be disconnected from the CXA16/CXB16 during the tests. The MicroPDP-11 system manuals describe how to load and run these diagnostics. - **4.4.1.1** Running User-Mode Tests -- All user-mode tests are run by selection from the test menu displayed when the user diagnostics are booted. See Chapter 2 for more details. - 4.5 MicroVAX II DIAGNOSTICS Diagnostics for MicroVAX II systems all run under the MicroVAX Maintenance System (MMS). The MicroVAX II system manuals describe how to load the MMS into the MicroVAX II, and how to run MMS diagnostics. All the tests can be run by selection from the test menus displayed when MMS is booted. ## 4.5.1 User-Mode Tests These tests can be used by an untrained operator to verify the basic operation of the option. User-mode tests do not cause any disruption to data networks or devices to which the CXAl6/CXBl6 may be connected. Such networks and devices do not have to be disconnected from the CXAl6/CXBl6 during the tests. See Chapter 2 for more details. ## 4.6 FIELD-REPLACEABLE UNITS (FRUS) The FRUS are: | | XA16 module | |------------|-------------------| | | XB16 module | | BC16D-25 3 | 6-wire cable | | H3104 C | able concentrator | # APPENDIX A CXA16/CXB16 Q-bus CONNECTIONS Table A-1 CXA16/CXB16 Q-Bus Connections | Category | Signal | Function | Pin | Number | |-----------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------|----------------------------------------| | Data/Address | BDAL0.L 1.L<br>BDAL2.L 15.L<br>BDAL16.L 17.L<br>BDAL18.L 21.L | Data/Address Lines | BE2<br>AC1 | AV2<br>BV2<br>AD1<br>BF1 | | Data Control | BDOUT.L<br>BRPLY.L<br>BDIN.L<br>BSYNC.L<br>BWTBT.L<br>BBS7.L | Data Output Strobe<br>Reply Handshake<br>Data Input Strobe<br>Synchronize Strobe<br>Write Byte Control<br>I/O Page Select | | AE2<br>AF2<br>AH2<br>AJ2<br>AK2<br>AP2 | | Interrupt Contro | BIRQ.L<br>BIAKI.L<br>BIAKO.L | Int. Req. Level 4 Int. Ack. Input Int. Ack. Output | | AL2<br>AM2<br>AN2 | | DMA Control System Control | BDMR.L<br>BDMGI.L<br>BDMGO.L<br>BSACK.L<br>BREF.L<br>BINIT.L | DMA Request DMA Grant Input DMA Grant Output Bus Grant Acknowledg Refresh and Block Mo Initialization Strob | de | AN1<br>AR2<br>AS2<br>BN1<br>AR1<br>AT2 | | Power Supplies | +5 V<br>+12 V | Dc volts<br>Dc volts | | DA2<br>, BD2 | | Grounds | GND<br>GND<br>GND<br>GND | Ground Connections<br>Ground Connections<br>Ground Connections<br>Ground Connections | AT1<br>AJ1 | | ## B.1 FLOATING DEVICE ADDRESSES On Q-bus systems a block of addresses in the top 4K words of address space is reserved for options with floating device addresses. This range is from 17760010(octal) to 17763776(octal). Options which can be assigned floating device addresses are listed in Table B-1. This table gives the sequence of addresses for both UNIBUS and Q-bus options. For example, the address sequences could be: DJ11 DH11 DQ11 DU11/DUV11 Having one list allows us to use one set of configuration rules and one configuration program. Table B-1 Floating Device Address Assignments | Rank | Device | Size<br>(Decimal) | Modulus<br>(Octal) | Address | |------|-----------------|-------------------|--------------------|----------| | 1 | DJll gap | 4 | 10 | 17760010 | | 2 | DH11 gap | 8 | 20 | 17760020 | | 3 | DQ11 gap | 4 | 10 | 17760030 | | 4 | DUll, DUV11 gap | 4 | 10 | 17760040 | | 5 | DUP11 gap | 4 | 10 | 17760050 | | 6 | LK11A gap | 4 | 10 | 17760060 | | 7 | DMC11/DMR11 gap | 4 | 10 | 17760070 | | 8 | DZ11/DZV11/ | | • | | | | DZS11/DZ32 gap | 4 | 10 * | 17760100 | | 9 | KMC11 gap | 4 | 10 | 17760110 | | 10 | LPP11 gap | 4 | 10 | 17760120 | <sup>\*</sup> The DZ11-E and DZ11-F are treated as two DZ11s. Table B-1 Floating Device Address Assignments (cont.) | Rank | Device | Size<br>(Decimal) | Modulus<br>(Octal) | Address | |------|--------------------------------|-------------------|--------------------|----------| | 11 | VMV2l gap | 4 | 10 | 17760130 | | 12 | VMV31 gap | 8 | 20 | 17760140 | | 13 | DWR70 gap | 4 | 10 | 17760150 | | 14 | RL11, RLV11 ga | p 4 | 10 * | 17760160 | | 15 | LPAll-K gap | 8 | 20 * | 17760200 | | 16 | KWll-C gap | 4 | 10 | 17760210 | | 17 | VSV21 gap | 4 | 10 | 17760220 | | 18 | RX11/RX211/<br>RXV11/RXV21 ga | p 4 | 10 * | 17760230 | | 19 | DR11-W gap | 4 | 10 | 17760240 | | 20 | DR11-B gap | 4 | 10 ** | 17760250 | | 21 | DMP11 gap | 4 | 10 | 17760260 | | 22 | DPV11 gap | 4 | 10 | 17760270 | | 23 | ISB11 gap | 4 | 10 | 17760300 | | 24 | DMV11 gap | 8 | 20 | 17760320 | | 25 | DEUNA gap | 4 | 10 * | 17760330 | | 26 | UDA50/RQDX1 ga | p 2 | 4 * | 17760334 | | 27 | DMF32 gap | 16 | 40 | 17760340 | | 28 | KMS11 gap | 6 | 20 | 17760360 | | 29 | VS100 gap | 8<br>2 | 20 | 17760400 | | 30 | TU81 gap | 2 | 4 | 17760404 | | 31 | KMVll gap | 8 | 20 | 17760420 | | 32 | DHV11/DHU11/<br>CXA16/CXB16 ga | p 8 | 20 | 17760440 | <sup>\*</sup> The first device of this type has a fixed address. Any extra devices have a floating address. <sup>\*\*</sup> The first two devices of this type have a fixed address. Any extra devices have a floating address. The address assignment rules are as follows. - 1. Addresses, starting at 17760010(octal) for Q-bus systems, are assigned according to the sequence of Table B-1. - 2. Option and gap addresses are assigned according to the octal modulus as follows. - Devices with an octal modulus of 4 are assigned an address on a 4(octal) boundary (the two lowest-order address bits = 0) - Devices with an octal modulus of 10 are assigned an address on a 10(octal) boundary (the three lowest-order address bits = 0) - Devices with an octal modulus of 20 are assigned an address on a 20(octal) boundary (the four lowest-order address bits = 0) - Devices with an octal modulus of 40 are assigned an address on a 40(octal) boundary (the five lowest-order address bits = 0) - 3. Address space equal to the device's modulus must be allowed for each device which is connected to the bus. - 4. A 1-word gap, assigned according to rule 2, must be allowed after the last device of each type. This gap could be bigger when rule 2 is applied to the following rank. - 5. A 1-word gap, assigned according to rule 2, must be allowed for each unused rank on the list if a device with a higher address is used. This gap could be bigger when rule 2 is applied to the following rank. If extra devices are added to a system, the floating addresses may have to be reassigned in agreement with these rules. ## B.2 FLOATING VECTORS Each device needs two 16-bit locations for each vector. example, a device with one receive and one transmit vector needs four words of vector space. The vector assignment rules are as follows: - Each device occupies vector address space equal to 'Size' words. For example, the DLV11-J occupies 16 words of vector space. If its vector were 300(octal), the next available vector would be at 340(octal). - There are no gaps, except those needed to align an octal 2. modulus. Table B-2 Floating Vector Address Assignments | Rank | Device | Size<br>(Decimal) | Modulus<br>(Octal) | | |------------------|------------------------|-------------------|--------------------|--| | 1 | DC11 | 4 | 10 | | | ī | TU58 | 4 | 10 | | | 1<br>2<br>2 | KL11 | 4 | 10 * | | | 2 | DL11-A | 4 | 10 * | | | 2 | DL11-B | 4 | 10 * | | | 2 | DLV11-J | 16 | 10 | | | 2<br>2<br>3<br>4 | DLV11, DLV11-F | 4 | 10 | | | วั | DP11 | 4 | 10 | | | 4 | DM11-A | 4 | 10 | | | 5 | DN11 | 2 | 4 | | | 6 | DM11-BB/BA | 2 | 4 | | | 7 | DH11 modem control | 2 | 4 | | | 8 | DR11-A, DRV11-B | 4 | 10 | | | 6<br>7<br>8<br>9 | DR11-C, DRV11 | 4 | 10 | | | 10 | PA611 (reader + punch) | 8 | 10 | | | 11 | LPD11 | 4 | 10 | | | 12 | DT07 | 4 | 10 | | | 13 | DX11 | 4 | 10 | | | 14 | DL11-C to DLV11-E | 4 | 10 | | | 15 | DJ11 | 4 | 10 | | <sup>\*</sup> If a KLll or DLll is used as the console, it has a fixed vector. Table B-2 Floating Vector Address Assignments (Cont.) | lank | Device | Size<br>(Decimal) | Modulus<br>(Octal) | | | |------------------|----------------------|-------------------|--------------------|-----|----| | 16 | DH11 | 4 | 10 | | | | 16<br>17 | VT40 | 8 | 10 | | | | 17 | VSV11 | 8 | 10 | | | | 18 | LPS11 | 12 | 10 | | | | 19 | DQ11 | 4 | 10 | | | | 20 | KW11-W, KWV11 | 4 | 10<br>10 | | | | 21 | DUll, DUV11 | 4 | 10 | | | | 22 | DUP11 | 4 | 10 | | | | 23 | DV11 + modem control | 6<br>4 | 10 | | | | 24 | LK11-A | 4 | 10 | | | | 0.5 | DWUN | 4 | 10 | | | | 25 | DMC11/DMR11 | 4 | 10 | | | | 26 | DZ11/DZS11/DZV11, | | | | | | 27 | DZ317/DZ311/DZV11/ | 4 | 10 | | | | 28 | KMC11 | 4 | 10 | | | | 26<br>29 | LPP11 | 4 | 10 | | | | 30 | VMV21 | 4 | 10 | | | | 31 | VMV31 | 4 | 10 | • • | ٠. | | 32 | VTV01 | 4 | 10 | | | | 33 | DWR70 | 4 | 10 | | | | 34 | RL11/RLV11 | 2 | 4 | * | | | 35 | TS11, TU80 | 2 | 4 | * | | | 35<br>36 | LPA11-K | 4 | 10 | | | | 30<br>37 | IP11/IP300 | 2 | 4 | * | | | 3 <i>1</i><br>38 | KW11-C | 4<br>2 | 10 | | | | 30<br>39 | RX11/RX211 | 2 | 4 | * | | | 39 | RXV11/RXV21 | | | | | | 40 | DR11-W | 2<br>2 | 4 | * | | | 41 | DR11-B | 2 | 4 | | | | 42 | DMP11 | 4<br>4<br>2 | 10 | | | | 43 | DPV11 | 4 | 10 | ** | | | 44 | ML11 | 2 | 4 | ~ ~ | | <sup>\*</sup> The first device of this type has a fixed vector. Any extra devices have a floating vector. <sup>\*\*</sup> MLll is a MASSBUS device which can connect to UNIBUS via a bus adapter. Table B-2 Floating Vector Address Assignments (Cont.) | Rank | Device | Size<br>(Decimal) | Modulus<br>(Octal) | | |----------|-------------------------|-------------------|--------------------|--| | 45 | ISB11 | 4 | 10<br>10 | | | 46 | DMV11 | 2 | 4 * | | | 47<br>48 | DEUNA<br>UDA50/RQDX1 | 2 | 4 * | | | 49 | DMF32 | 16 | 4 | | | 50 | KMS11 | 6 | 10 | | | 51 | PCL11-B | 4 | 10 | | | 52 | VS100 | 2 | 4 | | | 53 | TU81 | 2 | 4 | | | 54 | KMV11 | 4 | 10 | | | 55 | KCT32 | 4 | 10 | | | 56 | IEX | 4 | 10 | | | 57 | DHV11/DHU11/CXA16/CXB16 | 4 | 10 | | <sup>\*</sup> The first device of this type has a fixed vector. Any extra devices have a floating vector. C.1 OVERVIEW Flow control is the control of the flow of data along a communications line, to prevent an overspill of queues or buffers, or to prevent the loss of data which the receiver is unable to accept. The method of flow control adopted for the CXA16/CXB16 is datastream-embedded ASCII control characters. The control characters used are XOFF (octal 023) and XON (octal 021). XOFF stops transmission and XON starts transmission. The codes are transmitted in the opposite direction to that of the data they control. The CXAl6/CXBl6 has one mode of operation for transmitted data (received flow-control characters) and two modes of operation for received data (transmitted flow-control characters). Each mode can be enabled on a 'per channel' basis. Each direction of flow is discussed separately within this appendix. C.2 CONTROL OF TRANSMITTED DATA The transmitted-data mode of flow control is the simplest of the three flow-control modes of the CXA16/CXB16. When the CXA16/CXB16 receives an XOFF character for a particular channel, the TX.ENA bit for that channel is cleared. When this bit is clear the CXA16/CXB16 will not transmit any data on that channel; however, internally generated flow-control characters will still be transmitted. When an XON character is received, the TX.ENA bit for that channel is set. Figure C-1 illustrates the operation of the transmitted data flow control. Figure C-l Transmitted Data Flow Control Only characters without transmission errors are checked for XON and XOFF codes. The characters have their parity bit stripped before comparison. #### NOTE For the automatic flow control to operate correctly, the terminal must also recognize and respond to flow-control characters. The transmitted-data mode of flow control is enabled by setting OAUTO (bit 4 of the line-control register), and is disabled by clearing it. The default for this mode is disabled. The CXA16/CXB16 can alter the state of the TX.ENA bit, up to 50 microseconds after the program clears the OAUTO bit. Received flow-control characters are processed in the same way as normal characters, and are placed into the receive FIFO. This is not affected by OAUTO; but these characters can be filtered out by setting DISAB.XRPT. If DISAB.XRPT is set, you do not need a routine in your software driver to filter flow-control characters from the data stream. - C.3 CONTROL OF RECEIVED DATA Received data flow control is slightly more complicated than transmitted data flow control. Therefore the two modes of received data flow control are described separately. - C.3.1 Flow Control by the Level of the Receive FIFO Occasionally, the program may not be able to empty the receive FIFO as fast as the received data is filling it. Because the program does not know how full the receive FIFO is, it cannot take action to prevent data loss. To overcome this problem, the CXA16/CXB16 can be programmed on a 'per channel' basis. When the receive FIFO becomes three-quarters full, an XOFF is sent to the channels from which data is received. An XOFF character is then sent in response to every second received character, until the receive FIFO level drops below half full. An XON character is then transmitted. The operation of receive FIFO-level flow control is shown in Figure C-2. The receive FIFO-level flow-control mode is enabled by setting IAUTO (bit 1 of the line-control register), and disabled by clearing the bit. The default for this mode is disabled. If IAUTO is cleared after an XOFF is sent, but before the receive FIFO level drops below half full, an XON is still sent. #### NOTE FIFO.CRIT is set (T) when the receive FIFO contains 192 characters and is cleared (F) when the receive contains fewer than 128 characters. Figure C-2 Receive FIFO-Level Flow Control C.3.2 Flow Control by Program Initiation Occasionally, the program itself may need to invoke flow control automatically, for example, when internal buffers become full. To allow this, the CXA16/CXB16 has a FORCE.XOFF bit (bit 5 of the line-control register). When the FORCE.XOFF bit is set, the CXA16/CXB16 transmits an XOFF character for that channel. A further XOFF bit is transmitted for every second character received on the channel afterwards. An XON is sent when the FORCE.XOFF bit is cleared. Figure C-3 shows the operation of program-initiated flow control. Figure C-3 Program-Initiated Flow Control #### NOTE If the program sets the FORCE.XOFF bit and then immediately clears it, the XOFF code will not be transmitted immediately. This is because there is a delay before the sequencer sees the program request and acts on it. The FORCE.XOFF bit is cleared by a CXA16/CXB16 reset sequence. C.3.3 Mixing the Two Types of Received Data Flow Control To calculate the effect of using the two modes, they should be logically ORed together; an XON will not be sent until both sources are inactive. An XOFF will be sent when FORCE.XOFF is set, even if FIFO-critical mode is active and an XOFF has already been sent on that channel. If the receive FIFO critical mode becomes active whilst FORCE.XOFF is set, then another XOFF is sent in response to the next received character. D.1 SCOPE This appendix contains a glossary of terms used in this manual and in other DIGITAL technical manuals in this series. The terms are in alphabetical order for easy reference. D.2 GLOSSARY Asynchronous. A method of serial transmission in which data is preceded by a start bit and followed by a stop bit. The receiver provides the intermediate timing to identify the data bits. Auto-flow. Automatic flow control. A method by which the CXA16/CXB16 controls the flow of data using special characters within the data stream. Backward channel. A channel which transmits in the opposite direction to that of the usual data flow. Normally used for supervisory or control signals. Base address. The Q-bus address of the first (lowest) device register (CSR). BMP. Background Monitor Program. CCITT. Comite Consultatif International de Telephonie et de Telegraphie. An international standards committee for telephone, telegraph, and data communications networks. DMA. Direct Memory Access. A method which allows a bus master to transfer data to or from system memory without using the host CPU. Duplex. A method of transmitting and receiving on the same channel at the same time. EIA. Electrical Industries Association. An American organization with the same function as the CCITT. FCC. Federal Communications Commission. An American organization which regulates and licenses communications equipment. FIFO. First In First Out. The term describes a register or memory from which the oldest data is removed first. Floating address. An address assigned to an option which does not have a fixed address allocated. The address is dependent on other floating address devices connected to the bus. Floating vector. An interrupt vector assigned to an option which does not have a fixed vector allocated. The vector is dependent on other floating vector devices connected to the bus. FRU. Field-Replaceable Unit. IC. Integrated Circuit. I/O. Input/Output. LSB. Least-Significant Bit. Microcomputer. An IC which contains a microprocessor and peripheral circuitry such as memory, I/O ports, timers, and UARTs. MMJ. Modified Modular Jack. Modem. The word is a contraction of MOdulator DEModulator. A modem interfaces a terminal to a transmission line. A modem is sometimes called a dataset. MSB. Most Significant Bit. Multiplexer. A device which allows a number of inputs to share one common output. Null modem. A cable which allows two terminals which use modem control signals to be connected together directly. It is only possible over short distances. OCTART. A single IC containing eight UARTS. PCB. Printed Circuit Board. Protocol. A set of rules which define the control and flow of data in a communications system. PSTN. Public Switched Telephone Network. Q-bus. A global term for a specific DIGITAL bus on which the address and data are multiplexed. RAM. Random Access Memory. RFI. Radio Frequency Interference. ROM. Read-Only Memory. Split-speed. A facility of a data communications channel which can transmit data at a different speed from the received data. UART. Universal Asynchronous Receiver Transmitter. A device which converts between serial and parallel data, used for transmission and reception of serial asynchronous data on a channel. XOFF. A control code (23(octal)) used to disable a transmitter. Special hardware or software is needed for this function. XON. A control code (21(octal)) used to enable a transmitter which has been disabled by an XOFF code. #### INDEX ``` Active adapter, H3105, 1-11 Address, device, 2-2, 2-3, B-1, B-2, B-3 Background monitor program, 3-16, 3-39, 4-4 Baud rates, 1-2 BC16D-25 interconnecting cable, 1-3, 2-1, 2-9 Break, 3-23 Buffers, q-bus, 1-11 Bus grant continuity, 2-6 Cable, BC16D-25 interconnecting, 1-3, 2-1, 2-9 H3104, concentrator, 1-3, 1-11, 2-1, 2-9 lengths, 1-10, 1-11 Characteristics, electrical, 1-2 Concentrator, H3104 cable, 1-3, 2-1, 2-9 Conditions, environmental, 1-8 Configurations, 1-5, 1-6 Connections, Q-bus, A-1 Connector, H8521 passive, 1-11 Connectors, 1-3, 1-11, 1-13, 4-2 loopback test, 1-3, 2-1, 2-12 MMJ, 1-11 Continuity, bus grant, 2-6 Control chip, 1-4, 1-13, 1-14, 1-15, 3-37 flow, C-1, C-2 Data rates, 1-9 DEC422, 1-1, 1-10, 1-12 DEC423, 1-1, 1-10, 1-11, 1-12 Device address, 2-2, 2-3, B-1, B-2, B-3 DHU11 mode, 1-1, 1-2, 1-5, 1-15, 2-2, 2-3, 2-4, 3-19, 3-20 DHV11 mode, 1-1, 1-2, 1-5, 1-15, 2-2, 2-3, 2-4, 3-19, 3-20 Diagnostic programs, 1-3 Diagnostics, 2-7, 2-9, 2-10 DMA, 1-1, 1-15, 2-7, 3-6, 3-24, 3-25, 3-26, 3-27, 3-31, 3-44 EIA-232-D, 1-9, 1-10, 1-11 Electrical characteristics, 1-2 requirements, 1-8 Environmental conditions, 1-8 EOS/ESD, protection, 1-10, 1-12 FIFO, 64-character transmit, 1-1 receive, 1-2, 1-3, 1-15 Flow control, 1-2, C-1, C-2 ``` ``` Grant, bus, continuity, 2-6 H3104 cable concentrator, 1-3, 1-11, 2-1, 2-9 H3105 active adapter, 1-11 H8521 passive connector, 1-11 Installation, 2-2, 2-8 Interconnecting, BC16D-25, cable, 1-5, 2-1, 2-9 Interface, serial line, 1-2, 1-13 standards, 1-9 Interrupt request, 2-7, 3-33 vector, 2-5, B-5, B-6, B-7, B-8 Lengths, cable, 1-10, 1-11 Line receivers, 1-12, 1-13 serial, interface, 1-2, 1-13 transmitters, 1-12, 1-13 Loads, Q-bus, 1-8 Loopback test connectors, 1-3, 2-1, 2-12, 4-2, 4-3, 4-4, 4-5 Maintenance kit, 1-3 MicroVAX-II, 1-3, 2-11, 2-12, 4-5 MMJ connectors, 1-11 Monitor, background, program, 3-16, 3-39, 4-4 OCTART, 1-12, 1-15, 1-16, 3-23, 3-37 Parity, 3-15 Passive, H8521, connector, 1-11 PDP-11, 1-3, 2-11, 4-5 Program, background monitor, 3-16, 3-39, 4-4 Programs, diagnostic, 1-3 Protection, EOS/ESD, 1-10, 1-12 Q-bus, 1-1, 1-3, 1-5, 2-6, buffers, 1-13 connections, A-1 interface, 1-15 loads, 1-8 ``` Rates, baud, 1-2 data, 1-9 Receive FIFO, 1-2, 1-3, 1-15 Receivers, line, 1-12, 1-13 Registers, 3-1 Requirements, electrical, 1-8 RS-422-A, 1-1, 1-2, 1-9, 1-12 RS-423-A, 1-1, 1-2, 1-9, 1-10 Self-test, 1-2, 1-3, 1-5, 1-15, 2-9, 3-6, 3-8, 3-29, 3-37, 3-38, Serial line interface, 1-2, 1-13 Standards, interface, 1-9 Static, 1-2 Switchpacks, 1-5, 1-13, 2-2, 2-3, 2-4, 2-5 Throughput, 1-2, 1-3, 1-9 Transmit, 64-character, FIFO, 1-1 Transmitters, line, 1-12, 1-13 User-mode, 4-4 Vector, interrupt, 2-5, B-5, B-6, B-7, B-8 Xoff, 1-2, 1-3, 3-13, 3-22, 3-23, 3-24, 3-34, C-1, C-2 Xon, 1-2, 1-3, 3-13, 3-22, 3-23, 3-24, 3-34, C-1, C-2 .