VCB02 Hardware Manual (preliminary) Page missing from original document # CONTENTS | CHAPTER | 1 | GENERAL DESCRIPTION | | | | |---------|---------|-----------------------------------------|-----|---|---------| | | 1.1 | INTRODUCTION | | | | | | 1.2 | BASE MODULE | | • | 1-1 | | | 1.3 | FOUR-PLANE MODULE | | • | 1 - 3 | | | 1.4 | PRINCIPAL FEATURES | | | | | | 1.5 | OPERATIONAL DESCRIPTION | | | 1-6 | | | 1.5.1 | Multiplane Support | | • | 1-6 | | | 1.5.2 | Viewport Support | | • | 1-8 | | | 1.5.3 | Rasterops | | | 1-8 | | | 1.5.3.1 | Programmable Modes | | • | 1 - 8 | | | 1.5.3.2 | Programmable Modes | | | 1-9 | | | 1.5.3.3 | | | • | 1-9 | | | 1.5.4 | Private Memory | | | 1-10 | | | 1.5.5 | MicroVAX CPU To Address/Video Process | or | | | | | | Chip Interface | | | 1-10 | | | 1.5.5.1 | | | | 1-11 | | | 1.5.5.2 | | | | | | | 1.6 | APPLICATIONS | | | 1-13 | | | 1.6.1 | Text | • • | • | 1.13 | | | 1.6.1.1 | Font Storage and Access | • • | • | 1.13 | | | 1.6.1.2 | Normal Text | • • | • | 1.14 | | | 1.6.1.3 | Character Attributes | • • | • | 1 1 1 5 | | | | Craphics | • • | • | 1.16 | | | 1.6.2 | | • • | • | 1 16 | | | 1.6.2.1 | | • • | • | 1 16 | | | 1.6.2.2 | Fill Mode - Polygons | • • | • | 1 12 | | | | Polygon Flood | • • | • | 1-1/ | | | 1.6.2.4 | Objects | • • | • | 1-10 | | CHAPTER | 2 | CONFIGURATIONS AND INSTALLATION | | | | | | 2.1 | GENERAL | | | 2 - 1 | | | 2.2 | SYSTEM CONFIGURATION | | | 2 - 2 | | | 2.2.1 | | • • | • | 2 - 4 | | | | BA23 System Box | | | | | | 2.2.1.2 | BA123 System Box | | | 2 - 6 | | | 2.2.1.3 | | | | | | | 2.2.1.3 | | | | | | | 2.2.1.4 | | | | | | | 2.2.1.5 | <b>▲</b> | | | | | | | | | | | | | 2.2.1.6 | Mass Storage | • • | • | | | | 2.2.1.7 | • • • • • • • • • • • • • • • • • • • • | | | | | | 2.2.1.8 | | | | 2 - 9 | | | 2.2.1.9 | | | | | | | 2.2.1.1 | <b>-</b> | | | | | • | 2.2.1.1 | | • • | • | 2-10 | | | 2.2.2 | Options | • • | • | 2-10 | | | 2.2.2.1 | Additional Memory | | | 2-1( | | | 2.2.2.2 | Optional Tape Storage | • | • • | • • | 2-10 | |---------|---------------|--------------------------------|---------|-------|-----|--------| | | 2.2.2.3 | Digitizing Tablet | • | | | 2-11 | | | 2.2.2.4 | Printers | • | | | 2-11 | | | 2.2.2.5 | Communication Devices | | | | 2-11 | | | 2.3 | SYSTEM SPECIFICATIONS | | | | 2-11 | | | 2.3.1 | BA23 System Box | • | | | 2-11 | | | 2.3.1 | DA133 System BOX | • | • • | • • | 2-12 | | | 2.3.2 | BA123 System Box | • | • • | • • | 2 12 | | | 2.3.3 | Environmental | • | • • | • • | 2-12 | | | 2.3.4 | VCB02 Power Requirements | • | • • | • • | 2-13 | | | 2.4 | 7CB02 INSTALLATION | | | | 2-13 | | | 2.4.1 | Intermodule Connections | | | | 2-17 | | | 2.4.1.1 | Common Intermodule Connections | ; | | | 2-17 | | | 2 4 1 1 . 1 . | Electrical Interconnects . | | | | 2-17 | | | 2 / 1 1 | Mechanical Interconnects . | | | | 2-17 | | | 2 4 1 2 | Unique Intermodule Connections | | | | 2-19 | | | 2.4.1.2 | Unique intermodure connections | • | • • | • • | 2-19 | | | 2.4.1.2. | Electrical Interconnects . | • | • • | • • | 2 20 | | | | Mechanical Interconnects | • | • • | • • | 2-20 | | | 2.4.2 | I/O Interconnect | • | • • | • • | 2-20 | | | 2.4.2.1 | Electrical Interconnects | • | | | 2 - 20 | | | 2.4.2.2 | Mechanical Interconnects | | | | 2 - 20 | | | 2.4.2.3 | Bulkhead Connector | | | | 2-21 | | | 2.4.2.4 | Bulkhead Connector | | | | 2-21 | | CHAPTER | 3 | FUNCTIONAL DESCRIPTION | | | | | | | 3.1 | SUBSYSTEM OVERVIEW | | | | 3-1 | | | 3.2 | VCBO2 MODULES | | | | 3 - 2 | | | 3 2 1 | Base Module | | | | 3-2 | | | 3.2.1.1 | Instruction/Data Interconnect | | | | 3 - 2 | | | 3.2.1.1 | Chip Select Decoding | | | | 3-2 | | | 3.2.1.2 | Subsystem Timing Generation | | • • | • • | 3 - 4 | | | 3.2.1.2 | Subsystem liming deneration | • • | • • | | 3.1 | | | 3.2.1.3 | Video Output Logic | • • | • • | | 2 = | | | 3.2.1.3 | l Hardware Cursor | • • | • • | • • | 3-5 | | | 3.2.1.3 | 2 Synchronization and Blank | • • | • • | • • | 3-5 | | | 3.2.1.3 | 3 Video Upgrade Path | | | | 3-5 | | | 3.2.1.3 | | | | | 3 - 5 | | | 3.2.1.4 | I/O Devices | | | | 3-6 | | | 3.2.1.4 | 1 LK201 Keyboard | | | | 3 - 6 | | | 3.2.1.4 | <u>=</u> | | | | | | | 3.2.1.4 | | q De | evice | | 3-6 | | | 3.2.1.4 | _ | | | | | | | 3.2.1.4 | | | | | | | | 3.2.1.5 | | • | • • | | | | | | | | | | | | | 3.2.1.5 | | | | | | | | 3.2.1.6 | Control And Status Registers | ( C 2 ) | (2) | • | , J-10 | | | 3.2.1.6 | 1 I/O Page CSR | • • | • • | • | , J-IU | | | 3.2.1.6 | 2 Memory CSR | • • | • • | • | . 3-11 | | | 3.2.1.7 | Console Emulation | | • • | • | . 3-11 | | | 3.2.1.8 | Diagnostic Support | | | • | . 3-12 | | | 3.2.1.8 | 1 Diagnostic ROM | | | | . 3-12 | | | 3.2.1.8 | 2 Bitmap and Template Memory | Acc | ess | • | . 3-12 | | | 3.2.1.8 | | | | • | . 3-12 | | 3.2.2 | Four- | Plan | e M | odu | ıle | • | • | | | • | | • | | • | • | • | 3 - | 12 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|----------------|----------|----------|-----------------------------------------|------------------------------------------|----------------------------------------------------------------------| | 3.2.2.1 | Vid | leo M | lemo | rv | Str | uct | tur | е. | | | | | | | | | 3 - | 12 | | 3.3 AF | DRESS | AND | VI | DEC | PF | OCE | ESS | OR | OV | ERV | ΊE | W | | | | | 3 - | 13 | | | Hardv | | | | | | | | | | | | | | | | | | | 3.3.1.1 | Bus | ses | | | | | | | | _ | | _ | | | _ | _ | 3- | 15 | | 3.3.1.2 | Bit | | | | | | | | | | | | | | | | | | | 3.3.1.3 | | ning | | | | | | | | | | | | | | | | | | 3.3.2 | | | | | | | | | | | | | | | | | | | | 3.3.3 | Memor | | | | | | | | | | | | | | | | | | | | Subsy | | | | | | | | | | | | | | | | | | | 3.3.4 | Viewp | | | | | | | | | | | | | | | | | | | 3.3.4.1 | | olli | | | | | | | | | | | | | | | | | | 3.3.4.2 | Dra | ıggin | ıg. | • | | • | • | | • | • | • | • | • | • | • | • | 3 - | 22 | | 3.3.4.3 | Cle | arin | g a | Re | gio | n | • | | • | • | • | • | • | • | • | • | 3 - | 23 | | 3.3.4.4 | Dra | wing | in | th | ie S | cro | 11: | ing | R | egi | on | | | • | • | | 3 - | 23 | | 3.3.4.4.1 | Multi | index | ing | | | • | | | | | • | | | • | | | 3 - | 23 | | 3.3.5 | Multi | plan | e Š | upp | ort | | | | | | | | | | | | 3 - | 25 | | 3.3.5.1 | z | xis | Add | res | sir | a | | | | _ | _ | _ | _ | _ | | _ | 3. | 25 | | 3.3.6 | Basio | | | | | | | | | | | | | | | | • | | | 3.3.0 | Hardy | | | | | | | | | | | | | | | | 2 | 26 | | 3.3.6.1 | natuv | irocc | · - | • | • • • | | ·<br>·hi. | • • | | ٠. | • | • | • | • | • | • | ) · | 20 | | | Auc | lress | . FL | | 350 | י ב | -11 T Î | · | A | JUL | es | 51 | 119 | | • | • | 2 - | 20 | | 3.3.6.1.1 | , L | esti | nat | 100 | | KOT | at | or | ı . | • | • | • | • | • | • | • | 3 - | 28 | | 3.3.6.1.1. | . <u>1</u> | HOT | es | ano | l Di | ıpı ı | Lcai | tic | ns | • | • | • | • | • | • | • | 3 - | 29 | | 3.3.6.1.1. | . 2 | Bre | sen | ham | Er | roi | c Co | omp | ut | ati | on | | • | • | • | • | 3 - | 31 | | 3.3.6.1.2 | F | irst | So | urc | e - | S | cal: | ing | • | • | • | • | • | • | • | • | 3 - | 32 | | 3.3.6.1.3 | 7 | ast. | Mod | e. | | • | • | | | | • | | | | | | 3 - | 33 | | | | | | | | | | | | | | | | - | | | | | | 3.3.6.1.4 | | Secon | d S | our | ce | - 7 | rile | es | • | | • | | | • | | | 3 - | 33 | | 3.3.6.1.4 | 5 | Secon | d S | our | ce | - 7 | rile | es | • | • | • | | | • | | • | 3 - | 33 | | 3.3.6.1.4<br>3.3.6.2 | Vić | Secon<br>leo P | d S | our<br>ess | ce | - T | rile<br>ip | es<br>- D | at | a M | Ian | ip | ula | at | io | n | 3 -<br>3 - | 33<br>35 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1 | Vić<br>E | Secon<br>Neo P<br>Barre | d S<br>roc | our<br>ess<br>hif | ce<br>or<br>ter | Ch: | rile<br>ip<br>Bi | es<br>- D<br>t A | ata<br>Ali | a M<br>gnπ | Ian<br>Ien | ip<br>t | ula | at | i o | n<br>• | 3 -<br>3 -<br>3 - | 33<br>35<br>37 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2 | Vic<br>Vic<br>E | Secon<br>leo P<br>Barre<br>Logic | d S<br>roc<br>l S<br>Un | our<br>ess<br>hif<br>it | ce<br>or<br>ter | - 1<br>Chi | rile<br>ip<br>Bi<br>our | es<br>- D<br>t A<br>ce/ | ata<br>Alio<br>Ma: | a M<br>gnm<br>sk | Ian<br>Ien<br>Re | ip<br>t<br>gi | ula<br>ste | at | i o | n<br>• | 3 -<br>3 -<br>3 - | 33<br>35<br>37 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1 | Vic<br>Vic<br>E<br>I | Secon<br>leo P<br>Sarre<br>Logic<br>Contr | d S<br>roc<br>l S<br>Un | our<br>ess<br>hif<br>it<br>Sto | ce<br>or<br>ter<br>And | - 1<br>Chi<br>-<br>l Sc<br>RAN | rile<br>ip<br>Bit<br>oure | es<br>- D<br>t P<br>ce/<br>nd | ata<br>Alio<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct | lan<br>len<br>Re | ip<br>t<br>gi<br>n | ula<br>ste | at<br>er | io<br>s | n<br>· | 3 -<br>3 -<br>3 -<br>3 - | 33<br>35<br>37<br>37 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3 | Vic<br>Vic<br>I<br>I | Secon<br>leo P<br>Barre<br>Logic<br>Contr<br>Regis | d S<br>roc<br>l S<br>Un<br>ol<br>ter | our<br>ess<br>hif<br>it<br>Sto | ce<br>or<br>ter<br>And<br>ore | Chi | rile<br>ip<br>Bit<br>oure<br>1 ar | es<br>- D<br>t A<br>ce/<br>nd | ata<br>Alio<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct | lan<br>len<br>Re | ip<br>t<br>gi<br>n | ula<br>ste | at<br>er | io<br>s | n<br>· | 3 -<br>3 -<br>3 -<br>3 - | 33<br>35<br>37<br>37 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2 | Vic<br>F<br>I<br>C<br>Pro | Secon<br>Serre<br>Serre<br>Sontr<br>Regis | d S<br>roc<br>l S<br>Un<br>ol<br>ter | our<br>ess<br>hif<br>it<br>Sto<br>s<br>to | ce<br>or<br>ter<br>And<br>re<br>Bit | Chi | rile ip Bit oure f an | es<br>- I<br>ce/<br>nd<br> | Data<br>Ali<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct | lan<br>len<br>Re<br>io | ip<br>t<br>gi<br>n | ula<br>ste | at<br>er | io<br>s | n<br>• | 3 -<br>3 -<br>3 -<br>3 - | 33<br>35<br>37<br>37 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3 | Vic<br>F<br>I<br>Pro | Secon<br>leo P<br>Barre<br>Logic<br>Contr<br>Regis<br>Ocess | d S<br>roc<br>l S<br>Un<br>ol<br>ter | our<br>ess<br>hif<br>it<br>Sto<br>s<br>to | ce<br>for<br>And<br>re<br>Bit | Chi | Tile Ip Bit our I an p an | es<br>- I<br>t A<br>ce/<br>nd<br> | ata<br>Ali<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct | lan<br>Re<br>io | ip<br>t<br>gi<br>n | ula<br>ste | at<br>er | io<br>s | n | 3 -<br>3 -<br>3 -<br>3 - | 33<br>35<br>37<br>37<br>38 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3 | Vic<br>F<br>I<br>Pro | Secon<br>leo P<br>Barre<br>Logic<br>Contr<br>Regis<br>Ocess | d S<br>roc<br>l S<br>Un<br>ol<br>ter | our<br>ess<br>hif<br>it<br>Sto<br>s<br>to | ce<br>for<br>And<br>re<br>Bit | Chi | Tile Ip Bit our I an p an | es<br>- I<br>t A<br>ce/<br>nd<br> | ata<br>Ali<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct | lan<br>Re<br>io | ip<br>t<br>gi<br>n | ula<br>ste | at<br>er | io<br>s | n | 3 -<br>3 -<br>3 -<br>3 - | 33<br>35<br>37<br>37<br>38 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7 | Vic<br>Vic<br>E<br>I<br>Pro<br>Pro<br>Per<br>Appli | Secon<br>Neo Parre<br>Logic<br>Contr<br>Regis<br>Docess<br>Docess<br>Torm | d S<br>roc<br>l S<br>Un<br>ol<br>ter<br>or<br>anc | our<br>ess<br>hif<br>it<br>Sto<br>s<br>to<br>Tra<br>e | ter<br>And<br>Tex | Chi<br>Chi<br>RAM<br>mar | File<br>ip<br>Bit<br>our<br>f and<br>p and | es<br>- D<br>ce/<br>nd | Ali<br>Ma:<br>Fu | a M<br>gnm<br>sk<br>nct<br>tma | lan<br>Re<br>io | ip<br>t<br>gi<br>n<br>to | ula<br>ste | at<br>er | . io | · n | 3 - 3 - 3 - 3 - 3 - | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7<br>3.3.7.1 | Vic<br>Vic<br>F<br>Pro<br>Pro<br>Per<br>Appli<br>For | Secon<br>deo Parre<br>Sarre<br>Social<br>Social<br>Social<br>Secon<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>So | d S<br>roc<br>l S<br>Un<br>ol<br>ter<br>or<br>or<br>on | our<br>ess<br>hit<br>Sto<br>Tra<br>e to<br>ge | ter<br>And<br>Tex<br>and | Chi<br>RAM<br>mar<br>ers | rile ip Bit our our our our our our | es<br>- I<br>ce/<br>nd<br> | Alie<br>Ma:<br>Fur<br>Bi | a M<br>gnm<br>sk<br>nct<br>tma | lan<br>Re<br>io | ip<br>t<br>gi<br>n<br>.to | ula<br>ste | at<br>er | . io | • n | 3 - 3 - 3 - 3 - 3 - 3 - | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7<br>3.3.7.1<br>3.3.7.2 | Vic<br>Vic<br>F<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Non | Secon<br>leo Parre<br>Sarre<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>S | d S<br>roc<br>l S<br>Un<br>ol<br>ter<br>or<br>or<br>on<br>ora | our<br>ess<br>hif<br>it<br>sto<br>Tra<br>e<br>to<br>ge<br>t | ter<br>And<br>Tex<br>and | Chi<br>Chi<br>I So<br>RAM<br>mar<br>ers | File<br>Bit<br>our of<br>and<br>o and<br>coes | es F<br>- I<br>t A<br>ce/<br>nd<br> | Alie<br>Ma:<br>Fur<br>Bi | a M<br>gnm<br>sk<br>nct<br>tma | lan<br>Re<br>io | ip<br>t<br>gi<br>n<br>.to | ula<br>ste | at<br>er | . io | . n | 3-<br>3-<br>3-<br>3-<br>3-<br>3-<br>3- | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41<br>41 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7<br>3.3.7.1 | Vic<br>Vic<br>F<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Non | Secon<br>deo Parre<br>Sarre<br>Social<br>Social<br>Social<br>Secon<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>So | d S<br>roc<br>l S<br>Un<br>ol<br>ter<br>or<br>or<br>on<br>ora | our<br>ess<br>hif<br>it<br>sto<br>Tra<br>e<br>to<br>ge<br>t | ter<br>And<br>Tex<br>and | Chi<br>Chi<br>I So<br>RAM<br>mar<br>ers | File<br>Bit<br>our of<br>and<br>o and<br>coes | es F<br>- I<br>t A<br>ce/<br>nd<br> | Alie<br>Ma:<br>Fur<br>Bi | a M<br>gnm<br>sk<br>nct<br>tma | lan<br>Re<br>io | ip<br>t<br>gi<br>n<br>.to | ula<br>ste | at<br>er | . io | . n | 3 - 3 - 3 - 3 - 3 - 3 - | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41<br>41 | | 3.3.6.1.4<br>3.3.6.2<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7<br>3.3.7.1<br>3.3.7.2 | Vic<br>Vic<br>F<br>Pro<br>Per<br>Appli<br>For<br>Nor<br>Var | Secon<br>leo Parre<br>Sarre<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>S | d S<br>roc<br>l S<br>Un<br>or<br>or<br>or<br>ora<br>Tex | our<br>ess<br>hif<br>it<br>s<br>to<br>Tra<br>e<br>to<br>e<br>t to | ter<br>And<br>Tex<br>and | Chi<br>Chi<br>I So<br>RAM<br>mar<br>iers<br>it<br>I Ao | File<br>Bit<br>Dure<br>far<br>and<br>cees | es F | Datalio | gnm<br>gnm<br>sk<br>nct<br>tma | lan Renio | ip<br>t<br>n<br>to | . ula . ste | . at | . i o | . n | 3-<br>3-<br>3-<br>3-<br>3-<br>3-<br>3- | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41<br>41<br>41<br>43 | | 3.3.6.1.4<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7.1<br>3.3.7.1<br>3.3.7.2<br>3.3.7.3 | Vic<br>Vic<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Nor<br>Var<br>Rot | Secon<br>leo Parre<br>Sarre<br>Contr<br>Regis<br>Coess<br>form<br>Cati<br>It St<br>Tiabl | d S<br>roc<br>l S<br>Or<br>or<br>or<br>or<br>ora<br>Tex<br>l an | our<br>ess<br>hit<br>store<br>eoe<br>tit | ce<br>for<br>ter<br>And<br>re<br><br>Bit<br>nsf<br><br>Tex<br>and | Chi | rile ip Bit our f an coes coes | es Face/ the Acce/ and face/ fac | Alio | a M<br>gnm<br>sk<br>nct<br>tma | Ian nen Re | . ip t gi n . to | . ula | . at | . io | · n · · · · · · · · · · · · · · · · · · | 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41<br>43<br>43 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 | Vic<br>Vic<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Var<br>Rot<br>Cha | Secon<br>Neo Parre<br>Logic<br>Contr<br>Regis<br>Ocess<br>Form<br>Cati<br>Mal<br>Tiabl | d S<br>roc<br>l S<br>ter<br>or<br>or<br>ora<br>re P<br>l an | ourshit consider the constant of | ter<br>And<br>re<br>Bit<br>msf<br>and<br>cal | Chi<br>Chi<br>I So<br>RAM<br>imag<br>ers<br>it<br>I Ao<br>.:<br>cet | Bit and an arrangement of the control contro | es Description of the second o | Pati | a M<br>gnm<br>sk<br>nct<br>tma | Ian nen Re | ip<br>tgin.to | . ste | . at | . io | · n · · · · · · · · · · · · · · · · · · | 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · | 33<br>35<br>37<br>37<br>38<br>39<br>40<br>41<br>41<br>43<br>43 | | 3.3.6.1.4<br>3.3.6.2.1<br>3.3.6.2.2<br>3.3.6.2.3<br>3.3.6.3<br>3.3.6.4<br>3.3.7<br>3.3.7.1<br>3.3.7.2<br>3.3.7.3<br>3.3.7.4 | Vic<br>Vic<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Non<br>Rot<br>Cha | Secon<br>leo Parre<br>Sarre<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Social<br>Socia | d S<br>roc<br>l S<br>ol<br>or<br>or<br>or<br>or<br>an<br>e P<br>e an | ourshit cora coe to store to get id Ato | ter<br>And<br>Tex<br>and<br>th Tex<br>and<br>th Tex<br>and<br>Grail | Chi<br>Chi<br>I So<br>RAM<br>I map<br>iers<br>I Ao<br>I ed<br>oute | Bit Bit and Bi | es I Formation of the series o | Data<br>Main<br>Ma:<br>Fur<br>Bi | a M<br>gnm<br>sk<br>net<br>tma | Ian Ren Re io | ip<br>tgi<br>n<br>.to | . ste | . at | . i o | · n · · · · · · · · · · · · · · · · · · | 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · | 335<br>3737<br>3839<br>4041<br>4143<br>4345 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8 | Vice<br>Vice<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Non<br>Van<br>Rot<br>Cha | Secon<br>Beore<br>Barre<br>Bogic<br>Control<br>Coess<br>Coess<br>Coati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati | d S<br>roc<br>l S<br>ol<br>or<br>or<br>or<br>or<br>er<br>on<br>Sup | oursift consider the constant of | ter<br>And<br>Fiter<br>And<br>Tex<br>and<br>Crall | Chi | Bit Bit and an | es I A A Common Com | Data<br>Mai<br>Ma:<br>Fur<br>Bi | a M<br>gnm<br>sk<br>net<br>tma | Ian Ren Re io | . ip t gi n . to | . ula | . at | . i o | · n · · · · · · · · · · · · · · · · · · | 3-3-3-3-3-3-3-3-3- | 335<br>3737<br>3839<br>4041<br>411<br>433<br>4546 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8.1 | Vic<br>Vic<br>Pro<br>Pro<br>Per<br>Appli<br>For<br>Nor<br>Var<br>Rot<br>Cha<br>Appli<br>Graph | Secon<br>Barre<br>Barre<br>Contr<br>Regis<br>Cocess<br>Coati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati<br>Cati | d S<br>roc<br>l Un<br>ol<br>or<br>or<br>or<br>or<br>e an<br>er<br>on<br>Sup | ourshit consider the constant of | ter<br>And<br>Ter<br>Bit<br>Ter<br>and<br>the<br>Gra | Chi | File Bit Durch Bit American | es F<br>t P<br>ce/<br>nd · · · · · · · · · · · · · · · · · · · | Data<br>Alio<br>Mass<br>Fur<br>Bi | a M<br>gnm<br>sk<br>nct<br>tma | Ian Renio | . ip t i | . ula | . at | . i o | · n · · · · · · · · · · · · · · · · · · | 3-3-3-3-3-3-3-3-3- | 335<br>3737<br>3839<br>4041<br>411<br>433<br>4546 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8 | Vice<br>Vice<br>Proper<br>Per<br>Appli<br>For<br>Nor<br>Rot<br>Cha<br>Appli<br>Graph<br>Por<br>Sha | Secon Person Per | d S<br>rocs<br>ol Un<br>tor<br>or or or<br>or and<br>on Sup<br>and | oussift consider the constant of | ter And Present An | Chi | File Bit | es | Data Alio Mai Fur Bi | a Maria | Idan Ren Recio | ip gin . to | . ula | . at | . i o | · n · · · · · · · · · · · · · · · · · · | 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · | 33537<br>37<br>38<br>3940<br>411<br>443<br>445<br>466 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.1 3.3.7.5 3.3.7.5 3.3.8.1 3.3.8.1 | Vice<br>Vice<br>Proper<br>Proper<br>Port<br>Non<br>Var<br>Rote<br>Char<br>Appli<br>Graph<br>Port<br>Sha | Secon Personal Person | of Solor correction of Supplies | ourshit of a contract of the c | ce<br>for<br>And<br>Fe<br>Bit<br>Insf<br>and<br>Crall<br>Grad<br>Ctc | Chi | File Bit Durch Bit American | es I Proposed in the | Data Alic Mass Fun Bi and | a Managana<br>sk net<br>tma<br> | Idan Ren Re Lio Lp Llit Lnd | . ip gi n . to | . ste | . at | . i o | · n · · · · · · · · · · · · · · · · · · | 3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3- | 33537<br>37<br>38<br>39404<br>41443<br>4344<br>446<br>446<br>446 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.5 3.3.7.5 3.3.8.1 3.3.8.2 3.3.8.3 | Vice<br>Vice<br>Property<br>Per<br>Appli<br>For<br>Non<br>Var<br>Rote<br>Appli<br>Graph<br>Poi | Secon Peccon Pecco | od S<br>cl S<br>color<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concora<br>concor | oesift constitution of the | ce cor And | Chi | Bit | es I A Cond on the | Alio<br>Mac<br>Fur<br>Bi | a M<br>gnm<br>sk<br>tma<br>tma<br>Add | Idan Ren Re Lio | ip t gin . o | . ula | . at | . io . s | .n | 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · 3 · | 33537<br>37<br>38<br>3940<br>4141<br>4343<br>45<br>464<br>4650 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8.1 3.3.8.1 3.3.8.1 | Vice<br>Vice<br>Proper<br>Per<br>Appli<br>For<br>Nor<br>Var<br>Rot<br>Cha<br>Appli<br>Graph<br>Poi | Secon Pleo Person Pleo Person | d Scalar of Scal | oesift of a contract of the co | ce cor term And Cor term And Cor term C | Chicago RAM are served as a se | File Bit Durch Bit and Community Communi | es I A Condition of the | Dational Additional Ad | a M<br>sk t<br>nct<br>tma<br> | Idan Renico in Recipio in Control | ip tin o | . ula | . at | . io . s | ·n · · · · · · · · · · · · · · · | 3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3-3- | 335737 38 394414434345 466 48055 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8.3 3.3.8.1 3.3.8.2 | Vice<br>Vice<br>Proper<br>Per<br>Appli<br>For<br>Nor<br>Var<br>Rot<br>Cha<br>Appli<br>Graph<br>Por<br>Sha<br>Fill | Secon Person Per | d Scilor of the control contr | oesift of a contract of the co | ter And Fre Bit I and Fre and Fre and Fre Congress of the Cong | Chicago Cara Cara Cara Cara Cara Cara Cara Car | File Bit Durch Bit American | es I A Cond | Dational Alice Ali | a Maria | Iden Recio | ip gin o | . ula<br>. ste | . at er | . io . s | ·n · · · · · · · · · · · · · · | 3 · · · · · · · · · · · · · · · · · · · | 335737 38 390411443435 466 4805555 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.4 3.3.7.5 3.3.8.1 3.3.8.1 3.3.8.2 3.3.8.3 3.3.8.3.1 3.3.8.3.2 3.3.8.3 | Vice<br>Vice<br>Property<br>Per<br>Appli<br>For<br>Non<br>Rot<br>Cha<br>Appli<br>Graph<br>Por<br>Sha<br>Pat<br>Fill | Secon Personal Person | of School Sch | oussit of a contract of the co | ter And | Chicago Caracter Character Caracter Car | File Bit Durch and Control of American Sciences Control of American Sciences Control of Con | es I A Condition of the | Dational Alice Ali | a Maria | Iden Recio p · · · · · · · · · · · · · · · · · · | .ip in .o | . ula | . at | .io | ·n · · · · · · · · · · · · · · · · | 3 · · · · · · · · · · · · · · · · · · · | 335737 38 390411434345 466 48035555 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.5 3.3.7.5 3.3.8.1 3.3.8.1 3.3.8.2 3.3.8.3 3.3.8.3.1 3.3.8.3.2 3.3.8.4 3.3.8.5 | Vice<br>Vice<br>Property<br>Per<br>Appli<br>For<br>Non<br>Rote<br>Appli<br>Graph<br>Poi<br>Sha<br>Poi<br>Poi<br>Poi<br>Ob | Secon Personal Person | d Scalar of Scal | oussit consider the constant of o | ce ter And Texand Texand Confidence to the Confi | Chicago Character Characte | File Bit Durch Bit American | es I for the form of | Dational Control of the t | a Mana sa | Idan Renario Procession Processio | ip di | . ula | . at | . i o | ·n · · · · · · · · · · · · · · · · | 3 · · · · · · · · · · · · · · · · · · · | 335737 38 390411434345 466 48035555 | | 3.3.6.1.4 3.3.6.2.1 3.3.6.2.2 3.3.6.2.3 3.3.6.2.3 3.3.6.3 3.3.6.4 3.3.7.1 3.3.7.2 3.3.7.3 3.3.7.5 3.3.7.5 3.3.8.1 3.3.8.1 3.3.8.2 3.3.8.3 3.3.8.3.1 3.3.8.3.2 3.3.8.4 3.3.8.5 | Vice<br>Vice<br>Property<br>Per<br>Appli<br>For<br>Non<br>Rot<br>Cha<br>Appli<br>Graph<br>Por<br>Sha<br>Pat<br>Fill | Secon Personal Person | d Scalar of Scal | oussit consider the constant of o | ce ter And Texand Texand Confidence to the Confi | Chicago Character Characte | File Bit Durch Bit American | es I for the form of | Dational Control of the t | a Mana sk that a | Idan Renario Procession Processio | ip di | . ula | . at | . i o | ·n · · · · · · · · · · · · · · · · | 3 · · · · · · · · · · · · · · · · · · · | 335737 38 390411434345 466 48035555 | | | 3.4.1 | Address Processor Chip Registers and | | |---|-----------|---------------------------------------------------|--------| | | | Commands | . 3-57 | | | 3.4.1.1 | Address Processor Chip Registers | . 3-57 | | | 3.4.1.1.1 | Interface Control Registers | . 3-58 | | | 3.4.1.1.2 | | . 3-64 | | | 3.4.1.1.3 | | . 3-65 | | | 3.4.1.1.4 | | . 3-67 | | | | Screen Format Control Registers | 3-69 | | | 3.4.1.1.5 | Address Processor Chip Commands | 3-74 | | | 3.4.1.2 | Address Processor Chip Commands | 2 75 | | | 3.4.1.2.1 | Register Loading | . 3-73 | | | 3.4.1.2.2 | Rasterop Command | . 3-// | | | 3.4.1.2.3 | Processor to Bitmap or Bitmap to | 2 70 | | | | Processor Transfers | . 3-/8 | | | 3.4.1.2.3 | .1 X Mode PTB and BTP | . 3-78 | | | 3.4.1.2.3 | .2 Z Mode PTB and BTP | . 3-80 | | | 3.4.1.2.4 | Cancel Command | . 3-80 | | | 3.4.2 | | . 3-81 | | | 3.4.2.1 | Video Processor Chip Registers | . 3-81 | | | 3.4.2.2 | | . 3-88 | | | 3.4.2.2.1 | | | | | 3.4.2.2.1 | MicroVAX CPU | . 3-88 | | | 3.4.2.2.2 | | | | | 3.4.2.2.2 | Instructions | 3-89 | | | 2 4 2 | | 3-92 | | | 3.4.3 | Physical Configuration | 2.92 | | | 3.4.3.1 | Address Processor Chip Pins | . 3-74 | | | 3.4.3.1.1 | Processor Interface | . 3-94 | | | 3.4.3.1.2 | Memory Address and Video Processor Chip Interface | 2 02 | | | | Chip Interface | . 3-93 | | | 3.4.3.1.3 | I/D Bus (Interconnect) | . 3-94 | | • | 3.4.3.1.4 | Monitor Timing | . 3-95 | | | 3.4.3.1.5 | Clocks | . 3-95 | | | 3.4.3.1.6 | Power | . 3-95 | | | 3.4.3.2 | Video Processor Chip Pins | . 3-96 | | | 3.4.3.2.1 | | . 3-96 | | | 3.4.3.2.2 | | . 3-97 | | | 3.4.3.2.3 | • | . 3-97 | | | 3.4.3.2.4 | Clocks | . 3-97 | | | 3.4.3.2.5 | | 3-98 | | | 3.4.3.2.6 | | 3-98 | | | | | 3-98 | | | 3.4.3.2.6 | Clock Generation | 3-98 | | | 3.4.3.2.6 | .2 System Synchronization | . 3 90 | | | 3.4.3.2.7 | | . 3-99 | | | 3.4.3.2.7 | | 2 100 | | | | Devices | 3-100 | | | 3.4.3.2.8 | | 3-100 | | | 3.4.3.2.9 | | | | | 3.4.3.2.9 | 0.1 Memory Address Bit Assignments | 3-102 | | | 3.4.3.2.9 | 9.2 Memory Refresh | | | | 3.4.3.2.9 | 3.3 Memory Configuration | | | | 3.4.3.2. | | | | | 3.4.3.2. | | | | | 3.4.3.2. | | 3-105 | | | 3.4.3.3 | | | | | | -105 | |----------|-----------------------------------------------|-------| | 3.5.1 | | | | 3.5.1.1 | ROMENB Decode 3 | | | 3.5.1.2 | | -108 | | 3.5.1.3 | | -108 | | 3.5.1.4 | Gate Array Addresses 3 | -109 | | 3.5.1.5 | IOENB Decode 3 | -109 | | 3.5.2 | DMA Engine | -109 | | 3.5.2.1 | Processor To Bitmap Transfers 3 | -112 | | 3.5.2.2 | | | | 3.5.2.3 | Display List Transfers | | | 3.5.3 | Interrupt Controller 3 | | | 3.5.4 | Cursor Logic | | | 3.5.5 | Display List Data And Commands 3 | | | 3.5.5.1 | Display List Data | -116 | | 3.5.5.2 | Display List Data | -116 | | 3.5.5.3 | DTP NWORDS Command | 117 | | 3.5.5.4 | PTB NWORDS Command | 117 | | | | | | 3.5.6 | Register Descriptions | | | 3.5.6.1 | Control Status Register (REGISTER 0) . 3 | -118 | | 3.5.6.2 | DMA Address Counter (15:00) (REGISTER | | | | 1) | -122 | | 3.5.6.3 | DMA Address Counter (21:16) (REGISTER | | | | 2) | -123 | | 3.5.6.4 | DMA Byte Counter (15:00) (REGISTER 3) 3 | -123 | | 3.5.6.5 | DMA Byte Counter (21:16) (REGISTER 4) 3 | -124 | | 3.5.6.6 | FIFO Register (REGISTER 5) 3 | | | 3.5.6.7 | Cursor X Position Register (REGISTER 6) 3 | -126 | | 3.5.6.8 | Cursor Y Position Register (REGISTER 7) 3 | -128 | | 3.5.6.9 | Interrupt Register (REGISTER 8) 3 | -128 | | 3.5.6.10 | Memory Base Address Register 3 | -131 | | 3.5.7 | Signal Description 3 | -132 | | 3.5.7.1 | QBus Interface 3 | -134 | | 3.5.7.2 | | | | 3.5.7.3 | | -142 | | 3.5.7.4 | | -143 | | 3.5.7.5 | | -144 | | 3.5.7.6 | | -144 | | 3.5.7.7 | | -144 | | 3.5.7.8 | Miscellaneous Signals | | | 3.5.8 | | -146 | | 3.5.8.1 | Package Pin Numbering | | | 3.5.8.2 | Pin Signal Assignments | | | 3.5.9 | Input/Output Specifications | | | 3.5.10 | | | | 3.5.10.1 | Timing Diagrams | | | | | -153 | | 3.5.10.1 | | -153 | | 3.5.10.1 | | -154 | | 3.5.10.1 | · · · · · · · · · · · · · · · · · · · | , , , | | 2 - 10 - | Write Cycle | -154 | | 3.5.10.1 | | | | 3.5.10.3 | <pre>1.5 Address Processor Read Cycle 3</pre> | -156 | | | 3.5.10.1. | 6 Address Processor Read, Template RAM | | |---------|-----------|--------------------------------------------|-----------| | | | Write Cycle | 3-157 | | | 3.5.10.2 | QBus Timing | 3-158 | | | 3.5.10.2. | 1 Slave To Master Transition | 3-159 | | | 3.5.10.2. | 2 Master To Slave Transition | 3-159 | | | 3.5.10.2. | .3 Master DIN Cycle | 3-160 | | | 3.5.10.2. | .4 Master DOUT Cycle | 3-161 | | | 3.5.10.2. | 4 Master Door Cycle | J 101 | | | | | | | | 4 5 | PROGRAMMING INFORMATION | | | CHAPTER | 4 F | PROGRAMMING INFORMATION | | | | 4 3 - | PROGRAMMING THE VCB02 VIDEO SUBSYSTEM | 4 - 1 | | | | PROGRAMMING THE VCBUZ VIDEO SUBSISIEM | 4-1 | | | 4.1.1 | Hardware Support | 4-1 | | | 4.1.2 | Bitmap Memory Organization | 4-4 | | | 4.1.3 | Overview of Rasterops | 4-5 | | | 4.1.4 | Overview of Scrolling | 4-8 | | | 4.1.5 | Coordinate Systems and Mapping | 4 - 9 | | | 4.1.5.1 | Interactions Between Rasterops and | | | | | Scrolling | 4 - 14 | | | 4.1.5.1.1 | The Effect of Scrolling on Screen and | | | | | Region Mapping | 4-14 | | | 4.1.5.1.2 | 2 Collisions Between Rasterops and | | | | 1.1.0.1 | Scrolling | 4-15 | | | 4.1.6 | Additional Operations on Bitmap Data | 4-16 | | | 4.2 | Video Processor and Address Processor Chip | | | | | | 1-17 | | | | Architecture | 4-17 | | | 4.2.1 | | 4-10 | | | 4.2.2 | Address Processor Chip Interface to the | 4 10 | | | | QBus | 4-19 | | | 4.2.3 | | 4 - 20 | | | 4.2.3.1 | Dataflow For Scrolling And Screen | | | | | Refresh | 4 - 20 | | | 4.2.3.2 | Rasterop Data Flow | 4 - 20 | | | 4.2.3.2. | 1 Video Processor Chip Operand Fetch | 4 - 22 | | | 4.2.3.2. | | 4 - 24 | | | 4.2.3.2. | 3 Masking and Clipping Logic | 4-25 | | | 4.2.3.2. | | 4-26 | | | 4.2.3.2. | | | | | 4.2.3.2. | | | | | | I/D Interconnect Protocol | 4-27 | | | 4.2.4 | The Protect Process | 1.20 | | | 4.2.5 | The Rasterop Process | 4 20 | | | 4.2.5.1 | Raster Scanning Algorithm | . 4-23 | | | 4.2.5.2 | Specification of Operands for a Rasterog | ) 4-30 | | | 4.2.5.2. | 1 The Destination Operand | . 4-31 | | | 4.2.5.2. | | . 4-31 | | | 4.2.5.2. | | | | | | Operand | , 4-32 | | | 4.2.5.2. | 2.2 Linear Pattern Generation | . 4-35 | | | 4.2.5.2. | | | | | 4.2.5.2. | | . 4-37 | | | 4.2.5.3 | Model of Raster Operations | . 4-38 | | | 4.2.6 | | 4-40 | | | 1 2 6 1 | Polygon Fill Model | 4-41 | | | 4.7.7.1 | TOTAGOII FITT MORET | , , , , , | | | 4.2.0.2 | | 4 - 42 | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | | 4.2.7 | Processor/Bitmap Transfers | 4-46 | | | 4.2.7.1 | Single-Plane Bitmap to Processor | | | | | Transfers | 4 40 | | | 4.2.7.2 | Processor to Ditmon Cinal and | 4-40 | | | 4.2.1.2 | | | | | | Transfers | 4 - 50 | | | 4.2.7.3 | Z-Axis Processor/Bitmap Transfers | 4 - 54 | | | 4.2.7.3 | .1 Z-Axis Bitmap to Processor Transfers . | 4 - 54 | | | 4.2.7.3 | .2 Z-Axis Processor to Bitmap Transfers . | 1 - 5 / | | | 4.3 | | 4 - 54 | | | 4.3.1 | | 4 - 54 | | | | Coordinate Systems | 4 - 55 | | | 4.3.2 | | 4-55 | | | 4.3.2.1 | Rasterop Command | 4-56 | | | 4.3.2.1 | .l Rasterop Protocol | 4-57 | | | 4.3.2.2 | Processor/Bitmap Transfers | 4 50 | | | 4.3.2.2 | Processor To Pitman Single Plans | 4-50 | | | 4.3.2.2 | | | | | | Command | 4 - 58 | | | 4.3.2.2 | .2 Bitmap to Processor Single Plane | | | | | Command | 4 - 59 | | | 4.3.2.2 | .3 Z-Axis Processor To Bitmap Command | 1 60 | | | | A 7-Avis Ritman To Drossess Command | 4-00 | | | 4.4 | -4 Z-Axis Bitmap To Processor Command | 4 - 61 | | | | | 4-61 | | | 4.4.1 | Z-Axis Addressing Mode | 4-61 | | | 4.4.2 | Z-Axis Register Loads | 4 - 63 | | | | | | | | | | | | CHAPTER | 5 | DIAGNOSTICS | | | CHALLEN | J | DIAGNOSTICS | | | | | | | | | | | | | | 5.1 | OVERVIEW | 5-1 | | | 5.1<br>5.2 | OVERVIEW | 5-1<br>5-1 | | | | OPERATION | 5-1 | | | 5.2<br>5.3 | OPERATION | 5-1<br>5-2 | | | 5.2<br>5.3<br>5.3.1 | OPERATION | 5-1<br>5-2<br>5-2 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2 | OPERATION | 5-1<br>5-2<br>5-2<br>5-2 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3 | OPERATION | 5-1<br>5-2<br>5-2<br>5-3 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4 | OPERATION | 5-1<br>5-2<br>5-2<br>5-3<br>5-3 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3 | OPERATION | 5-1<br>5-2<br>5-2<br>5-3<br>5-3 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-4 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-4<br>5-7 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned | 5-1<br>5-2<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-4<br>5-7 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data | 5-1<br>5-2<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-8 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select | 5-1<br>5-2<br>5-2<br>5-3<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6<br>5.5.2.7 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable Chip Select | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable Chip Select FIFO, DMA Operations, And DMA Interrupts | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9<br>5-11 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6<br>5.5.2.7 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable Chip Select FIFO, DMA Operations, And DMA Interrupts | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9<br>5-11 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6<br>5.5.2.7<br>5.5.2.8<br>5.5.2.9 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable Chip Select FIFO, DMA Operations, And DMA Interrupts Video Synchronization Pulses | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-9<br>5-11 | | | 5.2<br>5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.4<br>5.5<br>5.5.1<br>5.5.2<br>5.5.2.1<br>5.5.2.2<br>5.5.2.3<br>5.5.2.4<br>5.5.2.5<br>5.5.2.6<br>5.5.2.7 | OPERATION IMPLEMENTATION Performance Compatibility Error Processing OPERATIONAL REQUIREMENTS FUNCTIONAL DESCRIPTION Assumptions Power Up Self-test Parameters Passed And Returned VCB02 Lights Register Access And Data Template RAM Address Processor Chip Update Video Processor Enable Chip Select Bitmap Memory Update Video Processor Scroll Enable Chip Select FIFO, DMA Operations, And DMA Interrupts Video Synchronization Pulses | 5-1<br>5-2<br>5-2<br>5-3<br>5-4<br>5-7<br>5-7<br>5-7<br>5-9<br>5-11<br>5-12 | | | 5.5.2.12 | | ar un | | | | | | | | | | | | | | | |----------|----------|--------|----------------|------|------------|-----|-----|-----|-----|-----|---|---|---|---|---|---|-------| | | | Tr | ansmi | tter | (DU | ART | ') | • | | • | | • | • | • | • | • | 5-14 | | | 5.5.2.13 | Ma | nual | Inpu | ıt De | vic | es | | | | | | • | | | | 5-15 | | | 5.5.2.14 | Ca | lling | Sec | ruenc | е | | | | | | | | | | | 5-15 | | | 5.6 | CONSOL | E INP | UT/C | UTPU | T S | UPE | POR | г. | | | | | | | | 5-16 | | | 5.6.1 | | Chara | | | | | | | | | | | | | | | | | 5.6.1.1 | Ca | lling | Sec | nenc | _ | · | Ĭ | | Ī | • | | Ť | • | Ī | Ť | 5-16 | | | 5.6.2 | Dit | Chara | ctar | - | • | • | • | • • | • | • | • | • | • | • | • | 5-16 | | | 5.6.2.1 | Ca | Chara<br>lling | 200 | | • • | • | • | • • | • | • | • | • | • | • | • | 5-16 | | | 5.6.3 | Cat | Chara | 250 | iuenc<br>- | _ | • | • | • • | • | • | • | • | • | • | • | 5 17 | | | | Get | Chara | Ccer | • | • • | • | • | • • | • | • | • | • | • | • | • | 5-17 | | | 5.6.3.1 | Ca | lling | Sec | luenc | е | • | • | • • | • | • | • | • | • | • | • | 2-1/ | | | 5.6.4 | Cons | ole R | eset | • | • • | • | • | • • | • | • | • | • | • | • | • | 2-10 | | | 5.6.4.1 | Ça | lling | Sec | luenc | е | • | • | • • | • | • | • | • | • | • | • | 2-18 | | | 5.6.5 | | | | | | | | | | | | | | | | | | | 5.6.5.1 | Ca | lling | Sec | quenc | е | • | • | | • | • | • | • | • | • | • | 5-18 | | | | | | | | | | | | | | | | | | | | | APPENDIX | | Q22 BU | c cor | CTET | ር ልጥ T | ΟN | | | | | | | | | | | | | AFFENDIA | | Q22 D0 | J JFL | CILI | CALL | OIV | | | | | | | | | | | | | | A.1 | GENERA | L DES | CRIE | PTION | | • | • | | | | | | | | | A-1 | | | A.1.1 | Mast | er/Sl | ave | Rela | | | | | | | | | | | | | | | A.2 | Q22 BU | S SIG | NAL | ASSI | GNM | EN: | rs | | | | | | | | | A - 3 | | | A.3 | DATA T | RANSF | ER E | sus c | YCL | ES | | | | | _ | | _ | | _ | A - 5 | | | A.3.1 | | Cycle | | | | | | | | | | | | | | | | | A.3.2 | | ce Ad | | | | | | | | | | | | | | | | | A.4 | DIRECT | | | | | | | | | | | | | | | | | | A.4.1 | | Proto | | | | | | | | | | | | | | | | | | | k Mod | | | | | | | | | | | | | | | | | A.4.2 | | | | | | | | | | | | | | | | | | | A.4.2.1 | | TBI | • • | • • | • • | • | • | • • | • | • | • | • | • | • | • | A-10 | | | A.4.2.2 | | TBO | • • | • • | | • | • | • • | • | • | • | • | • | • | • | A-19 | | | A.4.3 | DMA | Guide | line | es | | • | • | • • | • | • | • | • | • | • | • | A-21 | | | A.5 | INTERR | UPTS | • | | | • | • | | • | • | • | • | • | ٠ | • | A-21 | | | A.5.1 | Devi | ce Pr | iori | ity | | | • | | • | • | • | • | • | • | • | A-22 | | | A.5.2 | Inte | rrupt | Pro | otoco | 1 | | • | | • | • | | | | | • | A-22 | | | A.5.3 | Q22 | Bus F | our- | -Leve | 1 1 | int | err | upt | | | | | | | | | | | | Conf | igura | tion | ns | | | | | | | | | | | | A-26 | | | A.6 | CONTRO | - | | | | | | | | | | | | | | A-27 | | | A.6.1 | Memo | ry Re | fres | sh . | | | | | | | | | | | | | | | A.6.2 | Halt | _ | | | | | | | | | | | | | | A-27 | | | A.6.3 | | ializ | | | | | | | | | | | | | | A-27 | | | A.6.4 | | r Sta | | | | | | | | | | | | | | | | | A.6.3 | BDCC | | | | | | | | | | | | | | | A-28 | | | A.6.6 | BPOK | | | | | | | | | | | | | | | A-28 | | | | | | | | | | | • • | | | | | | | | | | | A.6.7 | | r-Up/ | | | | | | | | | | • | ٠ | • | | A-28 | | | A.7 | Q22 BU | | | | | | | | ГІС | S | | ٠ | • | • | | A-29 | | | A.7.1 | | l Defi | | | | | | | | • | | | • | | | A-29 | | | A.7.2 | | Ohm Q | | | | | | | | | | | | | | A-29 | | | A.7.3 | | Drive | | | | | | | | | | | | | | A-30 | | | A.7.4 | | Recei | | | | | | | | | | | | | | | | | A.7.5 | Bus | Termi | nat: | ion | • | | | | • | • | • | • | • | • | • | A-31 | | | A.7.6 | Bus | Inter | coni | necti | ing | Wi | rin | ġ | | | | | | | | A-32 | | | A.7.6.1 | | ckpla | | | | | | | | | | | | | | | | | A.7.6.2 | | ıtra-B | | | | | | | | | | | | | | | | A.7.6.3 | Power and Ground | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | n.0 | SISIEM CONFIGURATIONS x 33 | | A.8.1 | LOWEL SUBDIA TOSGING 7 35 | | A.9 | MODULE CONTACT FINGER IDENTIFICATION A-37 | | | | | APPENDIX B | LK201 KEYBOARD SPECIFICATION | | B.1 | CENERAL DESCRIBETON | | B.2 | GENERAL DESCRIPTION | | B.3 | PHYSICAL DESCRIPTION | | B.3.1 | BLOCK DIAGRAM DESCRIPTION B. A | | B.3.2 | Revocato Scanning | | | control of Audio Transducer and Indicators B.5 | | B.3.3 | 1 | | B.3.3.1 | or by by by be come centeral | | B.3.3.2 | Processor Instructions | | 5.3.3.2 | - Joe of Office at | | в.3.3.3 | Processor Instructions | | B.4 | | | B.4.1 | Keyboard Matrix Scanning | | B.4.2 | | | B.4.3 | The state of s | | B.4.4 | | | B.4.4.1 | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | | B.4.4.2 | Keyboard Receive Mode | | B.4.5 | | | B.4.6 | Hardware Keyboard Identification (ID) | | B.4.7 | Voltage Supplies | | B.5 | | | B.5.1 | Keyboard Layout and Key Identification . B-13 | | B.5.2 | Modes | | B.5.2.1 | Special Considerations Regarding | | B.5.2.2 | Auto-Repeat B-19 | | D.J.2.2 | -Forma complactations redaining DOWN VIID | | B.5.2.3 | Mode B-21 Auto-Repeat Rates B-21 | | B.5.3 · | Keyboard Peripherals | | B.5.3.1 | Audio | | B.5.3.2 | Indicators (LEDs) | | B.5.4 | Keyboard-to-System Module Protocol B-22 | | B.5.4.1 | Keycode Transmission | | B.5.4.2 | Special Code Transmission | | B.5.4.3 | Power-Up Transmission | | B.5.5 | System Module to Keyboard Protocol B-25 | | B.5.5.1 | Commands | | B.5.5.2 | Parameters | | B.5.5.3 | Peripheral Commands | | B.5.5.4 | Mode Set Commands | | B.5.6 | Special Considerations | | B.5.6.1 | Error Handling | | B.5.6.2 | keyboard Locked Condition | | B.5.6.3 | Reserved Code | | B.5.6 | .4 Test Mode | |------------|------------------------------------------------| | в.5.6 | | | B.5. | | | в.6 | SPECIFICATIONS | | B.7 | | | B.7. | | | B.8 | | | | | | В.9 | DISPLAYING CHARACTERS | | APPENDIX C | MOUSE SPECIFICATION | | c.1 | | | C.1. | | | C.1. | | | C.1. | Connector | | C.1. | | | C.2 | | | C.2. | | | C.2. | | | C.3 | | | C.4 | MOUSE SPECIFICATIONS | | C.5 | ELECTRICAL INTERFACE | | c.5. | Interface Signal Levels | | C.6 | MOUSE OPERATION | | C.6. | | | C.6. | | | | | | C.6. | | | c.6. | | | C.6. | | | C.6. | • • | | C.6. | | | C.7 | COMPATIBILITY CONSIDERATIONS | | C.7. | <u> - </u> | | C.8 | PROGRAMMING GUIDELINES | | C.8. | | | C.8. | —————————————————————————————————————— | | C.8. | Button Use | | C.8. | Tablet Support | | APPENDIX D | TABLET SPECIFICATION | | D.1 | GENERAL DESCRIPTION | | D.2 | ELECTRICAL SPECIFICATIONS (POWER RATING) D- | | D.3 | | | D.3. | . Serial Interface | | D.3. | | | D.3. | | | D.4 | | | D.4. | | | | Baud Rate Command D- | | | Request Point Mode | | D.4.4 | Incremental Stream | D-5 | |-------|--------------------|-----| | D.4.5 | Self-Test | D-5 | | D.4.6 | Default Conditions | D-6 | | D.4.7 | | D-6 | | D.4.8 | m | D-6 | | D.4.9 | | D-6 | | D.5 | | D-7 | | D.5.1 | m | D-7 | | D.5.2 | • | D-7 | | D.5.3 | | D-7 | | D.5.4 | 5 · · · · | D-7 | | D.5.5 | | D-8 | | D.6 | | D-8 | | D.6.1 | <b></b> | D-8 | | D.6.2 | | D-8 | | D.6.3 | | D-9 | # GLOSSARY INDEX # FIGURES | Figure | | Page | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 1-1<br>1-2<br>1-3<br>1-4<br>1-5 | VCB02 Base Module (M7169) | .1-3<br>.1-4<br>.1-4 | | 2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>2-6<br>2-7 | VCB02 Video Subsystem 4-Plane Configuration | .2-2<br>.2-5<br>.2-6<br>.2-14<br>.2-15 | | 3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-10<br>3-11<br>3-12<br>3-13<br>3-14<br>3-15<br>3-16<br>3-17<br>3-18<br>3-19<br>3-20<br>3-21<br>3-22<br>3-23<br>3-24 | Scroll Chip Select Load Format-Command 140H Scroll Chip Select Load Format-Data. Update Chip Select Load Format-Command 160H Jpdate Chip Select Load Format-Data. Color Map Data Format QBus I/O Page QBus Memory Space Register Mapping. I/O Page CSR Read VCB02 ID Code Format Write Memory Base Register Format. Memory CSR Read Video Readback Register Format. Memory CSR Write Format For The Control Write Register. VCB02 Video Subsystem Block Diagram Memory Cycles During One Scan Region Configuration Example. Address Processor Chip Data Path Diagram. Example Destination Rasters. Example Of Fast And Slow Vectors That Duplicate Pixels. Example Of Fast And Slow Vectors That Leave Holes. Tiled Areas Video Processor Rasterop Block Diagram Text Scaling And Rotation Examples. Vector Types Vector Shading. | .3-3<br>.3-3<br>.3-3<br>.3-6<br>.3-7<br>.3-8<br>.3-9<br>.3-10<br>.3-11<br>.3-15<br>.3-21<br>.3-29<br>.3-30<br>.3-31<br>.3-32<br>.3-36<br>.3-36<br>.3-36 | | 3-25<br>3-26<br>3-27 | Polygon Fill Example | .3-55<br>.3-77 | | 3 - 28 | I/D Bus Z-Axis Video Processor Register Load Command Format | .3-78 | | | Pa | ge | |-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | I/D Bus External Register Load Command Format | .3- | 79 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | . 3 - | 92 | | | | | | | | | | | | | | Z Axis Read Instruction Format | . 3 - | 94 | | | | | | | | | | | | | | | | | | | | | | | | | | | | 122 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | DMA Gate Array Pin Diagram (Bottom View) | . 3 - | 154 | | | | | | | | | | | _ | | | | . 3 - | 160 | | Address Processor Write Cycle Timing Diagram | .3. | 161 | | Address Processor Read Cycle Timing Diagram | . 3 - | 162 | | | | | | • | . 3 - | 163 | | | | | | | | | | QBus Timing Diagram-Master DIN Cycle | .3. | 165 | | QBus Timing Diagram-Master DOUT Cycle | .3- | 166 | | | Rasterop Command Format. Processor To Bitmap X Mode Command Format. Bitmap To Processor X Mode Command Format. Processor To Bitmap Z Mode Command Format. Bitmap To Processor Z Mode Command Format. Cancel Command Format. Video Processor Chip Register Load Instruction Format. Video Processor Chip Z Axis Register Load Instruction Format. No Operation Instruction Format. Z Axis Write (Two Interleaved Instructions) Format. Z Axis Read Instruction Format. Active Cycle For Memory Read Instruction Format. Active Cycle For Read-Modify-Write Address Counter Register 1 Bitmap | Rasterop Command Format | | Figure | | Page | |--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------| | Figure 4-1 4-2 4-3 4-4-5 4-6 4-7 4-8 4-10 4-12 4-13 4-15 4-16 4-17 4-18 4-17 4-18 4-20 4-21 4-22 4-23 4-24 4-25 4-28 4-31 4-31 4-31 4-31 4-31 4-31 4-31 4-31 | VCB02 Video Subsystem Block Diagram. Multiplane Bitmap Memory Organization. Offscreen And Visible Memory. Rasterop Functional Model. Rasterop Operand Flow. Viewports And Scrolling Regions. Screen To Memory Mapping. Scrolling Region. Address Indexing. Address Translation. Source 2 Address Computation (Tiling Disabled). Index Registers For Two Pixel Down Scroll. Address And Video Processor Chips Functional Diagram. Address Processor Chip Data Flow. Video Processor Data Flow (Screen Refresh/Scrolling). Dataflow For Rasterops. Operand Routing Functions. Logic Unit Block Diagram. Masking And Clipping. Raster Scanning. Simple Rasterop. Rasterop With Rotation. Scaling Up The Source By Two. Source Scaled Down By A Factor Of Two. Linear Pattern. Mapping Of Source 2 To Destination. Simplified Rasterop Model. Polygon Fill. Polygon Fill Model. Edge Vectors Before Fill Filled Area. Filled Area Continuation To Show Doubling. Diverging Edge Vectors. Filled Area With Diverging Edges Source To Destination Alignment. Bitmap To Processor Mapping (General Case). | .4-3<br>.4-4-5<br>.4-10<br>.4-10<br>.4-112<br>.4-14-123<br>.4-14-14-14-14-14-14-14-14-14-14-14-14-14 | | 4 - 38<br>4 - 39 | Processor To Bitmap Mapping | .4-51 | | 4-40<br>5-1 | Z Axis Addressing Memory Configuration Before Power Up Self-Test | .4-62 | | A-1<br>A-2<br>A-3<br>A-4 | DATI Bus Cycle DATO Or DATOB Bus Cycle Timing. DATO Or DATOB Bus Cycle Timing. | .A-8<br>.A-9<br>.A-11 | | Figure | | Page | |------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | A-5<br>A-6<br>A-7<br>A-8<br>A-9<br>A-10<br>A-11<br>A-12<br>A-13<br>A-14<br>A-15<br>A-16<br>A-17<br>A-18<br>A-19 | DATIO Or DATIOB Bus Cycle DATIO Or DATIOB Bus Cycle Timing DMA Protocol DMA Request Grant Timing DATBI Bus Cycle Timing DATBO Bus Cycle Timing Interrupt Request/Acknowledge Sequence Interrupt Protocol Timing Position Independent Configuration Position Dependent Configuration Power Up Power Down Timing Bus Line Terminations Single Backplane Configuration Multiple Backplane Configuration Typical Pin Identification System | A-13<br>A-14<br>A-16<br>A-17<br>A-19<br>A-20<br>A-23<br>A-25<br>A-26<br>A-27<br>A-29<br>A-35<br>A-35<br>A-36<br>A-37 | | A-20 | Quad-Height Module Contact Finger Identification | A-38 | | B-1<br>B-2<br>B-3<br>B-4<br>B-5<br>B-6<br>B-7<br>B-8<br>B-10<br>B-11<br>B-12<br>B-13<br>B-14<br>B-15<br>B-16<br>B-17<br>B-19<br>B-20<br>B-21<br>B-22 | Keyboard Cable Connections Simplified Block Diagram Of LK201 Keyboard Circuitry. Simplified Block Diagram Of Matrix Scanning Circuit. Example Of Ghost Key Generation LK201 Keyboard Layout Audio Transducer (Beeper) Control Circuit. Indicator (LED) Control Circuit. Keyboard Transmit And Receive Character Format. System Module To Keyboard Protocol Indicator (LED) Parameter Indicator (LED) Layout Audio Volume Parameter Setting Key Transmission Mode. Setting Auto-Repeat Rate Buffer Association. Setting Auto-Repeat Rate Buffer Values. DEC Multinational Character Set. Character Set Designations. Character Set Selection. Character Generator ROM Displayable Characters. Keyboard Output Processing. | B-3<br>B-4<br>B-7<br>B-11<br>B-11<br>B-12<br>B-26<br>B-30<br>B-30<br>B-31<br>B-32<br>B-33<br>B-33 | | C-1<br>C-2<br>C-3<br>C-4<br>C-5 | Three-Button Mouse | C-1<br>C-3<br>C-4<br>C-7 | Page Figure | D-1<br>D-2<br>D-3<br>D-4 | Digitizing Tablet | |---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | TABLES | | Table | Page Page | | 2-1<br>2-2<br>2-3<br>2-4<br>2-5<br>2-6<br>2-7 | BA23/BA123 System Box Workstation Configuration. 2-3 H9278-a Backplane Slot Assignments. 2-4 Switchpack Function Settings. 2-17 Common Intermodule Connections. 2-18 Intermodule Connections (First 4-Plane Module) 2-19 Intermodule Connections (Second 4-Plane Module) 2-19 Input/Output Interconnect Signals. 2-21 | | 3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6<br>3-7<br>3-8<br>3-9<br>3-10 | Multiplexed MEMAD<10:0> Bits | | 5-1<br>5-2<br>5-3<br>5-4<br>5-5<br>5-6<br>5-7 | Console Page Configuration | | A-1<br>A-2<br>A-3<br>A-4 | Signal Assignments | | B-1<br>B-2 | Keyboard Matrix (LK201-AA)B-9 Keyboard Functional DivisionsB-14 | # TABLES (Continued) | Table | | Page | |-----------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------| | B-3<br>B-4<br>B-5<br>B-6<br>B-7<br>B-8<br>B-9<br>B-10<br>B-11<br>B-12 | Keycode Translation Table | B - 23<br>B - 24<br>B - 26<br>B - 30<br>B - 32<br>B - 36 | | C-1<br>C-2 | Mouse Connector Pin Assignments/Functions Mouse Command Summary | | | D - 1<br>D - 2 | Tablet Cable Connector Signal Assignments Summary Of Tablet Commands | | This VCB02 VIDEO SUBSYSTEM TECHNICAL MANUAL provides detailed technical information on the features, specifications, configurations, installation, functions, logic, programming, and diagnostics of the VCB02 video subsystem in a MicroVAX Workstation system environment and is intended for use by Original Equipment Manufacturers (OEMs) and internal/external corporate end users. The VCB02 video subsystem consists of a Base Module and one or two 4-Plane Modules (dependent on 4 or 8-plane subsystem selected) for use in black/white or color graphics workstation configurations. This technical manual contains a comprehensive description of the logical, physical, functional, and programming characteristics of the VCB02 video subsystem implementation. This technical manual is organized into a preface, five chapters, four appendixes, a glossary, and an index which are briefly described below. - PREFACE Contains the purpose of the manual, its targeted audience, the manual's content, related supplementary documentation, and a documentation procurement source. - Chapter 1 GENERAL DESCRIPTION provides an overview of the VCB02 video subsystem, including its features and specifications. - Chapter 2 CONFIGURATIONS AND INSTALLATION describes the VCB02 video subsystem implementation in a MicroVAX color graphics workstation configuration and includes an installation section. - Chapter 3 FUNCTIONAL DESCRIPTION contains the functional characteristics of major logic elements in the VCB02 video subsystem. Descriptions of the Address/Video Processor chips, timing generator, bitmap memory, DMA gate array (CMOS), Template RAM, keyboard/mouse/tablet input circuitry, QBus interface, and video output path. System block diagrams and other illustrations are included. - Chapter 4 PROGRAMMING INFORMATION describes the implementation of common drawing operations using the VCB02 video subsystem (e.g. text, graphics, functions, and windowing). Examples are included wherever needed. Also, the VCB02 drawing modes, DMA use, and program input (mouse/tablet support) are discussed. - DIAGNOSTICS describes the applicable diagnostic Chapter 5 programs for VCB02 video subsystem fault isolation, a summary of error types, indicator locations, display message, and suggested remedial actions. - Appendix A Q22 BUS SPECIFICATION profiles the Q22 Bus which interfaces the VCB02 video subsystem. - Appendix B LK201 KEYBOARD SPECIFICATION supplies information on the device, characteristics, and programming the keyboard. - Appendix C MOUSE SPECIFICATION provides characteristics of the supplied 3-button circular mouse. - Appendix D TABLET SPECIFICATION provides the characteristics of the optional ll inch square digitizing tablet accompanied by the 2-button stylus and 4-button cursor. Important terms used in this guide are defined. Glossary Index List of terms and topics with their page location(s). #### RELATED DOCUMENTATION The following documents provide additional information which may be of interest to VCB02 module set users. #### DOCUMENT DOCUMENT NUMBER #### HARDWARE BA123 PREPARATION AND VERIFICATION EK-BA023-SP Contains planning information for system installation. The guide includes space, power, and environmental suggestions. VAXstation XX OWNER'S MANUAL, AZ - GNGAA - MN BA123 ENCLOSURE Describes operational, installation, hardware options, troubleshooting, and diagnostic information related to the BA123 enclosure. VAXstation XX OWNER'S MANUAL. AZ-GNIAA-MN BA23 ENCLOSURE Provides operational, installation, hardware options, troubleshooting, and diagnostic information related to the BA23 enclosure. VAXstation XX TECHNICAL MANUAL, AZ-GNHAA-MN BA23 ENCLOSURE Supplies detailed information on the VAXstation XX hardware. VAXstation XX TECHNICAL MANUAL, AZ-GNFAA-MN BA123 ENCLOSURE Contains detailed information on the VAXstation XX hardware. VR290 COLOR VIDEO MONITOR EK-VR290-IN INSTALLATION/OWNER'S GUIDE Describes color monitor installation, operating instructions, troubleshooting procedures, and specifications. VR260 INSTALLATION/OWNER'S GUIDE EK-VR260-IN Provides monochrome monitor installation instructions, operating information, troubleshooting techniques, and specifications. MOUSE INSTALLATION SHEET EK-VSXXA-IN Describes device set up. TABLET INSTALLATION GUIDE EK-VSXXB-IN Describes device set up. KA630-A CPU MODULE USER'S GUIDE EK-KA630-UG Contains internal operation details of MicroVAX KA630-A CPU. MicroVAX II MAINTENANCE AZ-GM3AA-MN (part INFORMATION KIT of ZNA3X-C3) Provides maintenance procedures for self-servicing system users. VMS SOFTWARE o MicroVMS Workstation Release (insert number) o MicroVMS Workstation User's (AV-EZ24C-TN) Guide o MicroVMS User's Primer (AA-Z210B-TE) o MicroVMS User's Manual (AA-Z209B-TE) o MicroVMS User's Pocket Reference (AA-Z211B-TE) o MicroVMS Workstation Graphics (AA-Gl10A-TN) Programming Guide o MicroVMS Workstation Video (AV-DY65C-TE) | | Device Driver Manual | | |------------|---------------------------------------------|-----------------------------------------| | 0 | MicroVMS FORTRAN Programmer's | (AA-Z213A-TE) | | | Primer | | | 0 | _ · · · · · · · · · · · · · · · · · · · | (AA-Z212A-TE) | | | Manual | | | 0 | , , , , , , , , , , , , , , , , , , , , | (AA-DC87B-TE) | | | Manual | (88 70148 ME) | | 0 | | (AA-Z214A-TE) | | _ | Reference | (insert number) | | 0 | VAXstation XX Documentation Guide | (Insert induber) | | | Guide | | | III.TRTX-3 | 2w SOFTWARE | | | | VAXstation XX Documentation | (insert number) | | • | Guide, ULTRIX | , | | 0 | | (insert number) | | | Technical Summary | | | 0 | ULTRIX Workstation Software | (insert number) | | | Installation and Management | | | | Guide | | | 0 | | (insert number) | | | ULTRIX Workstation Software | | | | Window System | | | 0 | ULTRIX QDSS/VCB02 Device | (insert number) | | | Driver Programming | (incorp number) | | 0 | ULTRIX QDSS Interface Library | (insert number) | | _ | Programming Guide ULTRIX Workstation Client | (insert number) | | 0 | Application Programming | (Insert number) | | | Reference | | | 0 | | (insert number) | | 0 | | (insert number) | | 9 | Reference | (====================================== | | 0 | | (insert number) | | J | Master Index | , | | | | | The above listed related documentation can be ordered from: Digital Equipment Corporation Accessories and Supplies Group Cotton Road P.O. Box CS2008 Nashua, NH 03061 Attn: Documentation Products CHAPTER 1 GENERAL DESCRIPTION #### 1.1 INTRODUCTION The VCB02 Video Subsystem consists of a Base Module and one or two 4-Plane Modules which provide a high performance, high resolution, full page DMA color video subsystem based on the Q22 bus. This raster scan video subsystem is capable of four or eight plane color video memory display on a MicroVAX workstation. Both MicroVMS and ULTRIX-32w operating systems support is provided. The MicroVAX workstation is a single-user, stand alone, 32-bit workstation. A standard system includes 1 megabyte of memory, a 19-inch color or monochrome monitor, a mouse, a keyboard, a loading device, and a fixed disk drive. Each of two versions (BA23 or BA123 system box) of the MicroVAX workstation includes a VCB02 video subsystem of either 4-plane (2 boards) or 8-plane (3 boards) which provides 1024 Horizontal by 864 Vertical pixel resolution of displayed graphics and text. The two-module 4-plane VCB02 video subsystem allows 16 simultaneous colors or shades of gray. The three-module 8-plane VCB02 video subsystem allows 256 simultaneous colors or shades of gray. The Base Module and 4-Plane Module communicate through a cabling scheme to provide a basic configuration of 4-planes (16 colors from a palette of 16.7 million) with an upgrade path to 8-planes (256 colors from a palette of 16.7 million). ## 1.2 BASE MODULE The Base Module (DEC Part Number M7169) shown in Figure 1-1 provides the hardware for the system interface, the user I/O interface, and the full page color video support for 4- or 8-planes of video memory. Figure 1-2 shows a block diagram of the Base Module's major hardware components which are listed below: - 1. Address Processor (DC323) chip - 2. DMA Gate Array - 3. Template RAM for Display List and Cursor support - 4. QBus Interface Tranceivers - 5. Serial I/O Bus and Address Interface - 6. Console Em:lation/Diagnostic ROM - 7. Subsystem Timing Generator - 8. Color Bitmap 8-plane video output path - 9. Digital to Analog (D/A) Converters - 10. Video Shifter and Cursor Multiplexer - 11.Cable Connector for I/O interface and Memory Upgrade - 12.Communications input (keyboard/mouse/tablet) Figure 1-1 VCB02 Base Module (M7169) Figure 1-2 VCB02 Base Module Block Diagram #### 1.3 FOUR-PLANE MODULE The 4-plane Module (DEC Part Number M7168) shown in Figure 1-3 provides the hardware for 4-planes of full page video memory which is connected to the Base Module by a 50-pin flat ribbon cable. There are two versions of this cable to allow the base module to be connected to one or two 4-plane modules for a 4-plane or 8-plane color MicroVAX workstation using the BA123 system box. Figure 1-4 shows a block diagram of the 4-plane module's major hardware components which are listed below: - 1. Four Video Processor (DC322) chips - 2. 4-planes of video memory with 2 pages per plane - 3. Subsystem support logic - 4. Video Shifter - 5. Cable Connector for Base Module interface Figure 1-3 VCB02 Four-Plane Module (M7168) Figure 1-4 VCB02 Four-Plane Module Block Diagram #### 1.4 PRINCIPAL FEATURES - 1. A bitmap display provides variable character size or positioning and inherent graphics capability. - The display provides about 850 thousand pixels refreshed on the screen at 60 Hertz, avoiding flicker and smear of an interlaced display. - 3. Arbitrary rectangular regions support multiple viewports on the screen. Each region can be smooth scrolled both vertically and horizontally at various speeds. Incoming data is clipped to the region boundaries. New data can be added to a region even though scrolling is in progress. - 4. Return of clipping results can be used by the local processor to assist editing, windowing and picking algorithms. - 5. The interface with the local processor supports either direct local processor access to the video system or passing of commands through a DMA controller. - 6. Multiple bitmap planes (4 or 8) support applications requiring gray scale, color or control planes. All planes can be manipulated simultaneously. - 7. Z axis addressing allows an alternate form of memory access that transfers the bits from each plane (or sub-plane) that correspond to one pixel, instead of adjacent X bits from one plane. This can also be used to easily program all planes for a color to be written. - 8. Text attributes may be extended with additions like: arbitrary character size, arbitrary angle, italics, sub/superscript and variable pitch fonts. - 9. Rasterops are provided that transform a rectangular source to a parallelogram destination of any size or orientation. Halftone tiles or another image may be combined with any destination. Scaled or rotated rasterops (single source) operate at about 0.5 million pixels/sec; normal rasterops operate at about 8 million pixels/sec. - 10. Rasterop mode allows creation of two-dimensional linear patterns of any cell size. Linear patterns orient to follow the drawing path. - 11. Rasterop mode also allows the area between a series of vector pairs to be filled with a solid color, tile pattern or an image at about 8 million pixels/sec. # 1.5 OPERATIONAL DESCRIPTION The VCB02 video subsystem contains operational elements which are diagrammed in Figure 1-5 and described as follows: - o Address Processor Chip (DC323) - Responsible for functions that are common to all planes, such as: local processor interaction, all rasterop computations, bitmap address generation, clipping, screen refresh, scroll control and monitor synchronization generation. The address processor chip controls the bitmap address bus (providing all addresses for screen refresh, scrolling and updates) and the Instruction/Data (I/D) interconnect to configure and control the Video Processor chips. - o Video Processor Chip (DC322) - Provide the data path and control elements that are unique to each plane, such as: data FIFOs for refresh and scrolling, a barrel shifter for bit alignment, a logic unit with data and mask registers for memory modification, Z axis address logic, and a control store RAM to define Video Processor chip operations during rasterops. The Video Processor chips are controlled by the I/D interconnect, exchange data with the bitmap memories on the memory bus and provide screen refresh data on the video output bus. - o Bitmap Memory - Each plane consists of lKxlKx2 pixels. This allows both on-screen and off-screen drawing to occur. - o Video Output - Provide a color map, video shift circuits registers and digital to analog converters for driving the monitor. - o Timing Circuits - Provide required system and memory clocks. ## 1.5.1 Multiplane Support The VCB02 video subsystem uses the multiple Video Processor chips and bitmap memories to provide multiple memory planes for color without any performance penalty for additional planes. It also has several other provisions to support manipulation of multiple planes. A chip select mechanism controls which Video Processor chips (planes) will participate in bitmap update operations; a related mechanism controls participation in scrolling. 2. Z-axis (color variations) data transfers are provided to allow data to be exchanged between the CPU and the bitmap on the basis of a color value for each pixel, rather than exchanging the data for each plane separately. This form of data transfer can also be used to simultaneously load the color registers in all Video Processor chips. Z-axis transfers accommodate the use of low resolution planes. Figure 1-5 VCB02 Video Subsystem Block Diagram ## 1.5.2 Viewport Support The VCB02 video subsystem provides scrolling and clipping support for rectangular viewports. Scrolling is coupled to screen refresh and moves all of the data in an arbitrary rectangle (limited to four pixel boundaries, horizontally) up, down, left or right by 1 to 15 pixels, or more, in a single frame time. The incoming edge of the scrolled region is filled with a programmable color; or a mode is available that clears the entire region to a color. Scrolling uses memory cycles that would otherwise be available for updating the bitmap; therefore, the speed of rasterops drops to about a third of its non-scrolling value when the whole screen is being scrolled. Down scrolling actually moves all of the non-scrolling image (which is outside of the scrolling rectangle) up, followed by offsetting of the entire screen to compensate; when down scrolling of any region is in progress, rasterops are slowed to one third speed, as if the whole screen were scrolling. Clipping prevents updates from writing outside of an arbitrary rectangle (same horizontal limitation as above pending pass 3 Address Processor results). This rectangle may be the same as or different from the scrolling rectangle. Updates may occur concurrently with scrolling; this is facilitated by the addition of an index value to all update addresses. Indexes are changed with scrolling to represent where data has moved to in the bitmap which allows new updates to follow the scrolling image already in the bitmap. #### 1.5.3 Rasterops All updates to the bitmap memory are performed by basic rasterops or various special rasterop modes. During rasterops the Address Processor chip provides all memory address calculation and the Video Processor chips provide all data modification. If no scaling, rotation or reflection of the horizontal axis of the source is required in a rasterop, the VCB02 video subsystem will automatically operate in fast mode. In fast mode, multiple pixels along the X direction are operated on simultaneously. Otherwise, the VCB02 video subsystem will operate in slow mode, processing only one pixel at a time. Fast mode operates 16 times faster than slow mode. ### 1.5.3.1 Programmable Modes Processor/bitmap transfers (not actually modes, but commands) transfer images between the MicroVAX CPU bus and the bitmap. These transfers work very much like rasterops, except that there is either a source or a destination in the bitmap, but not both; and the data transferred to/from the MicroVAX CPU bus is a stream of words through a read/write I/O register which may be accessed by the MicroVAX CPU or DMA. There are two transfer modes: X-mode transfers each word (size depends on memory configuration) to/from a single plane with the adjacent bits in a word representing adjacent pixels in the X direction. This type of transfer always operates in fast mode. Full indexing and shifting are available when transferring from the bitmap; but, data must already be aligned with bitmap memory words when data is transferred to the bitmap from the CPU bus, because there is no shifter in the Address Processor chip. 2. Z-mode (color variation) transfers each word containing the bits representing the color of each pixel to/from the bitmap. This type of transfer always operates in slow mode, but writes all planes at the same time. Indexing is always available in this mode. # 1.5.3.2 Video Processor Data Manipulation The Video Processor chips contain the data path for each plane of bitmap. During source reads from the bitmap, a shifter aligns the data with the pixels in the destination. This shifter is controlled automatically by the Address Processor chip. Data read during source reads may be broadcast to other Video Processor chips or the Address Processor chip on the I/D interconnect (one Video Processor may broadcast), or the data may be retained in the Video Processor chip. Data retained in the Video Processor chip or received from the I/D interconnect may be stored in any of three registers for use during a destination cycle. The source register provides one input to a 16 function logic unit; the other input is the old destination data. The output of the logic unit selects, on a pixel for pixel basis, a foreground or background color to form new destination data. The new destination data is masked by the combined outputs of the two mask registers, which, like the source register, are loaded with a constant or during a source read. Masked bits return the old destination data to the bitmap instead of the new data. Either of the masks can be complemented; and the combined outputs are adjusted so that only complete groups of bits are changed in low resolution planes. A complementer and resolution logic are available for the source register. Data manipulations are controlled by two sets of indirect registers that are selectable from the Address Processor chip. The control store RAM specifies the data transfers that occur on each source or destination cycle. There are four logic function registers that specify the logic and mask operation to be performed during the destination cycle. Four function registers allows two orthogonal functions to be preprogrammed in the Video Processor chips. ## 1.5.3.3 Performance Destination only and single source/destination rasterops are compute bound at one cycle every 2 usec. A cycle writes either one pixel (if in slow mode) or a word (in fast mode, a word is 16 bits; therefore, 500K pix/sec are written in slow mode and 8M pix/sec are written in fast mode. ## 1.5.4 Private Memory To achieve rasterop performance, parallel multiplane operation and to support scrolling, the bitmapped memory operated upon by the VCB02 video subsystem must be on a private bus accessible to the processor only through the chipset. As much off screen memory as displayable memory in the VCB02 video subsystem address space is provided in each plane to support occluding viewports. With DMA assisted processor to bitmap and bitmap to processor transfers in either X or Z mode; the need for direct processor access to the bitmap is diminished. ## 1.5.5 MicroVAX CPU To Address/Video Processor Chip Interface The MicroVAX CPU controls the Address/Video Processor chips through the MicroVAX CPU bus on the Address Processor chip. This bus consists of 16 bi-directional data lines, 6 address lines and some control lines. The Address Processor chip has 58 registers (mostly write only) that can be accessed directly by the MicroVAX CPU. Alternatively, the registers can be loaded through an indirect register address counter. Address Processor chip registers are manipulated directly. The following operations are also provided: - 1. Video Processor chip registers are loaded with explicit I/D interconnect instructions. The chip select register must be loaded to select the Video Processor chips that are to receive the data; this register is the I/D interconnect. - To invoke a rasterop, the MicroVAX CPU loads the required Video Processor and Address Processor chip registers (unless unchanged from previous use) and starts the update with a rasterop command. - Processor/bitmap transfers are similar to rasterops, except that the data to, or acceptance of data from, the Address Processor chip. - 4. The cancel command will terminate any update operation in progress and clear all rasterop status. - 5. Scrolling is started by loading the Address Processor chip scroll constant register. All Address Processor and Video Processor scroll parameter registers must have been previously loaded. Separate I/D command, data and chip select registers are provided for loading scroll parameters in the Video Processor chips without disturbing any update that might be in progress. A status register reports the progress of various processes in the #### GENERAL DESCRIPTION Address Processor chip. Any or all of the status bits can be enabled to generate a request on either of two pins (one pin is reserved for a DMA requests and the second is used for interrupts). Scroll status provides a top of frame flag to load scroll parameters, a programmable flag that will be set when the refresh/scroll process passes any point on the screen to synchronize region updates, and a bottom of frame flag to start any vertical blank activities. Rasterop and I/D status indicate when various parameters and data may be loaded to minimize waiting. Clipping status will report when some rasterops are clipped or when some rasterops are not clipped. # 1.5.5.1 Address Processor Chip Registers The following control, scroll, rasterop parameter, and configuration registers of the Address Processor Chip are listed below: 1. CONTROL REGISTERS - Indirect access to Address Processor Address Counter registers used during DMA - Readable scroll, rasterop, I/D and Status clipping status - Status bit masks for interrupt outputs Request Enable Interrupt Enable - Data transfer register I/D Data Update command register Command 2. SCROLL REGISTERS Most of the scroll parameter registers are double buffered to allow a whole frame time to load new scroll data. - Scroll region boundaries Scroll X Min Scroll X Max Scroll Y Min Scroll Y Max - Programmable frame position status return Pause Y Scroll Constant - Vertical scroll control Y Offset - I/D path for scroll control I/D Scroll Data I/D Scroll Command 3. RASTEROP PARAMETER REGISTERS Pending X Index - Index values for update control while scrolling New X Index New Y Index Old X Index #### GENERAL DESCRIPTION Old Y Index Clip X Min - Update region boundaries Clip X Max Clip Y Min Clip Y Max Mode - Rasterop mode control Fast Source 1 DX - Source 1 rectangular extent Slow Source 1 DY Source 1 X Origin - Source 1 origin Source 1 Y Origin Destination X Origin - Destination origin Destination Y Origin Fast Destination DX - Destination parallelogram extent Fast Destination DY Slow Destination DX Slow Destination DY Fast Scale - Source 1 destination scale factors Slow Scale Source 2 X Origin - Source 2 origin Source 2 Y Origin Source 2 Height and - Source 2 rectangular extent (powers of Width two, only) Error 1 - Optional error control for vector Error 2 generators 4. CONFIGURATION REGISTERS X Scan Configuration - (8) frame timing and memory configuration Y Scan Configuration - (4) frame timing and memory configuration X Limit - Limit of visible (scrollable) screen Y Limit 1.5.5.2 Video Processor Chip Registers The following scroll, rasterop, and configuration registers of the Video Processor Chip are listed below: 1. SCROLL REGISTERS All of the scroll parameter registers are double buffered to allow a whole frame time to load new scroll data. Scroll Constant - Horizontal scroll control # GENERAL DESCRIPTION Fill - Background fill color for scrolling Left Scroll Boundary - Subword scroll edges Right Scroll Boundary 2. RASTEROP REGISTERS Logic Unit Function - 4 Indirect selection of logic function Control Store RAM - 6 Indirect selection of data transfers Mask 1 - Rasterop data masks Mask 2 Source - Data input to logic unit Foreground Color - Writing colors selected by logic function Background Color unit 3. CONFIGURATION REGISTERS Bus Width - Memory bus width (screen size) Plane Address - Z mode bit address Resolution Mode - Subplane mode #### 1.6 APPLICATIONS The following applications provide examples of implementing common drawing operations using the VCB02 video subsystem. #### 1.6.1 Text Normal rasterops are used to write characters. Common text procedures are described below. ## 1.6.1.1 Font Storage and Access Fonts are stored in an undisplayed portion of the bitmap. Ordinarily, a font is stored only in one plane and is transmitted from that plane to itself and others when a character is written. This will result in writing characters in the bitmap that are monochromatic (all of one foreground color and one background color), as is normally desired. If multi-colored or gray-scale (for anti-aliasing) characters are desired, then the fonts can be stored across many planes. Fonts will normally be stored in the off screen portion of the VCB02 bitmap. #### 1.6.1.2 Normal Text The display of unrotated, unscaled, fixed-pitch text could use the following example settings in the Address Processor and Video Processor chips; only those settings actually changing between characters need to be updated following initialization: - 1. The update region is initialized with clipping limits, indexes and resolution mode. - The Video Processor chip control store RAMs are set to enable broadcast of the character data from the plane containing the font to all other planes. - 3. The Address Processor chip mode register and the Video Processor chip logic functions, foreground, and background and registers are set for some of the desired character attributes. - 4. The source l origin (X and Y) is set to the start of the first character to be transferred. - 5. The destination origin (X and Y) is set to the desired screen location for the first character. The destination edge vectors are set parallel to the X and Y axes. - 6. The scale registers are set for scale factors of one. The following operations can now be performed to write each character in a string: - The MicroVAX CPU loads the command register in the Address Processor chip to start a source l/destination rasterop. - 2. After waiting for the Address Processor chip to finish the initialization phase of the rasterop (but while the character is still being written), the local processor can reload the source and destination origins and the command so that the next character can start immediately upon completion of the first. - 3. This process is repeated until the text is exhausted or an attribute change is required. Adjusting the destination position (and possibly width) will produce variable pitch text (proportional spacing). #### 1.6.1.3 Character Attributes To set the character attributes, appropriate Address and Video Processor chip registers are loaded; only the registers for those attributes that actually change between strings need to be loaded. The following list describes the intended implementation of attributes: - 1. Reverse Reverse is a specific case of a more general class of attributes that modifies the logic function being performed on the destination data. Two bits are provided in the Address Processor chip command word to address one of the four logic unit function registers in the Video Processor chips. - 2. Underline Underlines can be drawn as a vector of the desired thickness, and linear pattern mode can be used if a dashed or other patterned underline is desired. - Overstrike Overstrike may be accomplished by appropriate loading (or not loading) of the destination origin and the use of "OR" logic functions. - 4. Invisible The pen up bit in the Address Processor chip mode register may be used to disable writing, or the local processor can just skip any text strings that are invisible. If erasure of the invisible area is desired, this must be performed explicitly. - 5. Intensity, Color and Blink These are Z axis (color variation) parameters and are implemented through the color map. To enable writing the appropriate color in the bitmap planes, a Z axis load of the Video Processor chip foreground and/or background registers would be performed. Source data would then be passed through a Video Processor chip mask register to accomplish overstrike writing, or through the source register to accomplish replace mode writing. Alternately, blink may be performed by periodic writing to the bitmap. - Subscript and Superscript These character offsets are obtained by appropriate loading of the destination origin registers. - 7. Size, Italics and Rotation Any size, italic slope or rotation is available by setting the destination edge vectors and the scale factors, and providing appropriate destination origin update. ## 1.6.2 Graphics Most graphics functions use basic rasterops. Linear patterns, polygon fill and flood use the additional rasterop modes. #### 1.6.2.1 Vectors Solid color vectors are plotted as specific parallelograms, without any source operations. The foreground/background registers in the Video Processor chips are loaded with constants according to the desired color. The start point is loaded into the destination origin registers, one edge vector is set to the DX and DY of the desired vector, the other edge vector is set to the width of the desired vector (and perpendicular to the first edge), and the rasterop command is loaded. Curves must be formed from a string of straight vectors or points. Vectors may be shaded in one of two ways: - Inclusion of a first source set for linear pattern mode will provide linear patterns (like dashed lines, bullets or stripes) that align themselves with the direction of a vector. - 2. Inclusion of a second source set for tile mode will provide tile patterns that are "uncovered" under the path of the vector. #### 1.6.2.2 Fill Mode · Polygons In general, a fill operation places a solid or textured object on the screen whose shape is described mathematically, such as by a list of vertices. This is contrasted to a flood operation which is described below. To fill polygons, the various fill modes are used. Polygons may only be filled with solid colors (destination only), or with tile patterns or images from off screen (source 2 and destination). To fill a whole polygon: - It may need to be subdivided into pieces that will be intersected by any line that is parallel to the fill axis exactly twice; this is less restrictive than simply requiring a convex polygon. - 2. The Address and Video Processor chips are configured for fill mode with the appropriate source and destination operations - 3. The vertices of the polygon are divided into two "sides" (such as "left" and "right", from the upper most point to the lower most point). - 4. The rasterop origin registers are loaded with the top of the polygon, - 5. The first pair of edge vectors (starting at the first vertex from each side) is loaded into the rasterop extent registers. - 6. The Address Processor chip command register is then loaded with a rasterop command, including a source 2 if needed. - 7. The space between the two vectors is filled by the hardware parallel to the X (or Y) axis as the vectors are advanced synchronously in Y (or X). - 8. When the Address Processor chip signals for more data, the MicroVAX CPU loads the vector associated with the next vertex in the list of vertices and then loads the Address Processor chip command register again, continuing with the previous step until all required vectors are plotted, A simplified fill mode is provided that fills from a single vector to either a horizontal or vertical baseline. Only a single vector path is required and the path is allowed to reverse the direction of its component that is parallel to the baseline (not allowed with two-line mode). This mode is provided for compatibility; however, the space between two lines that converge on a point from the same quadrant is difficult to fill in this mode. # 1.6.2.3 Polygon Flood A flood operation colors or textures the interior of an area whose outline is previously described in the bitmap. This is contrasted to a fill operation described in the previous section. No explicit support for a polygon flood function is provided by the Address Processor chip. This function requires the path of writing in the bitmap to be conditional on the previous contents of the bitmap. In the hardware, the path of writing is controlled by the Address Processor chip, but only the Video Processor chips see the memory data. Flood can be implemented using the following commands: - The local processor/bitmap transfer facility is used to read a scan of the bitmap. - Each returned pixel value is checked for a match with a set of boundary colors and a count is maintained of the pixels received. - 3. When a match is found, the processor/bitmap transfer is terminated by loading a cancel command to the Address Processor chip. - 4. A vector is commanded to write the desired pixels on the scan with a color or pattern in the normal fashion. 5. The flood algorithm would then step to a point on the next scan or continue at a previous seed point, in the normal manner. ## 1.6.2.4 Objects Ordinary rasterops can be used to move objects or windows on the screen. In a multiplane environment, rectangles can be copied by moving the pixels in all planes, in parallel, to new locations in the same planes. To move just an object, that is, to alter only the destination pixels within the boundary of the object, it is necessary for the hardware to distinguish between object and background. This can be done by defining the foreground of the object in one plane. The area of this plane within the rasterop rectangle is then transmitted to the other planes during the rasterop for use as a mask that prevents the alteration of background pixels. Alternatively, the second source (with fill mode, if desired) can be used to copy an object from off screen, with "clipping" to the destination shape. The previous two paragraphs assumed the movement of color objects (objects defined in more than one plane). It is also possible to move monochromatic objects (ones specified by just a foreground shape), assigning a color to them at the time that they are moved. This type of operation has already been described for the writing of text. ## CHAPTER 2 # CONFIGURATIONS AND INSTALLATION #### 2.1 GENERAL This chapter describes the configuration and installation of the VCB02 video subsystem installed in a MicroVAX workstation. With the VCB02, the workstation can display graphics and text with 1024 Horizontal x 864 Vertical pixel resolution on a 19-inch monitor in color or in shades of gray. The VCB02 video subsystem consists of two modules: the Base Module and the 4-Plane Module which are shown interconnected in Figure 2-1. The open end modular design of the VCB02 allows expansion to an 8-plane video subsystem by adding another 4-plane module as shown in Figure 2-2. Figure 2-1 VCB02 Video Subsystem 4-Plane Configuration Figure 2-2 VCB02 Video Subsystem 8-Plane Configuration #### 2.2 SYSTEM CONFIGURATION The VCB02 video subsystem is installed a MicroVAX graphics workstation which uses either a BA23 or BA123 system box. The two systems boxes have some common features. Both use the MicroVAX II CPU module that includes the Flointing Point Unit (FPU) and one megabyte of memory. Each system is capable of using the MS630 series of memory which allows up to 9 megabytes of memory to be configured. The RQDX3 controller interfaces various diskette and hard disk storage devices and a VR260 Black/White monitor or a 19-inch VR290 color monitor is supplied with either workstation system that includes the LK201 keyboard and VSXX-AA serial mouse. The BAl23 system box will include one of the following versions of the VCB02 video subsystem: the 4-plane VCB02-B or the 8-plane VCB02-C. The BAl23 system box offers a 12-slot H9278-a backplane that allows for additional system options. In the BA23, only the 4-plane VCB02-B is supplied because of power limitations. In the BAl23, there is storage device cavity capacity for four 5.25 inch full height disk drives. Table 2-1 lists the configuration elements of a BA23/BA123 system box color graphics workstation system. However, refer to the PREFACE for the appropriate system technical manual for complete configuration rules and procedures. Table 2-1 BA23/BA123 System Box Workstation Configuration | Description | BA23 | BA123 | |----------------------|-------------------------|---------------------------------------------| | | | | | | | *** 620 | | MicroVAX II FPU/1 MB | KA630-AA | KA630-AA | | MEMORY EXPANSION MOD | MS630-AA(1 MB) | MS630-AA(l MB)Supplied | | MEMORI EXPANSION MOD | 110030 121(1 110) | MS630-BA(2 MB)Optional | | | t | MS630-CA(4 MB)Optional | | VCB02 BASE MODULE | M7169 \$3940 | M7169 (see Note 1) | | VCB02 4-PLANE MODULE | M7168 \$2380 | M7168 | | VCB02 4-PLANE MODULE | Unavailable | M7168 | | | DEONA VD | DEONA KB | | ETHERNET INTERFACE | DEQNA - KP | DEQNA - KP | | DRIVE CONTROLLER | RQDX3-AA | RQDX3-BA | | FLOPPY DISKETTE | RX50Q-AA | RX50Q-BA | | HARD DISK | RD53Q-AA | RD53Q-BA | | | 4 | | | SERIAL MOUSE | VSXXX-AA + 175 | VSXXX-AA | | KEYBOARD | LK201-AA \$200 | | | MONITOR | VR260/VR290 | VR290 (see Note 2)<br>BC18Z-10 (see Note 2) | | MONITOR CABLE | - BC18Z-10/<br>BC18P-10 | BC102-10 (See Note 2) | | | DCTOL-IO | | | | | 17-01058-52 725.F+ | | • | NOTES | | - 1. Both systems shown have color video capability. The VS265 has 4-plane VCB02-B option, while the VS270 has an 8-plane VCB02-C option. - 2. The VR260 and BC18P-10 cables can be substituted. When used with the 4-plane or 8-plane VCB02 options, the VR260 will display shades of gray. ## 2.2.1 System Components The BA23 and BA123 system boxes contain the system board components within the H9278-a backplane which are slot-assigned as indicated in Table 2-2. Table 2-2 H9278-a Backplane Slot Assignments | SLOT | MODULE | DESCRIPTION | ROWS | TYPE | |------|----------|--------------------------------|-------|-----------| | 1 | M7606-AA | MicroVAX II CPU (KA630-AA) | A-D | Quad | | 2 | M9047 | Grant Card | A - B | Dual | | | M7608-AA | 1 MByte Memory (MS630-AA) | C-D | Dual | | 3 | M9047 | Grant Card | A - B | Dual | | 4 | M7504 | DEQNA Ethernet Interface | A - B | Dual | | 5 | M7169 | VCB02 Base Module (see Note 3) | A - D | Quad | | 6 | M7168 | VCB02 4-Plane Module (see Note | 3)A-D | Quad | | 7 | M7168 | VCB02 4-Plane Module (see Note | 3)A-D | Quad | | 8 | M7513 | RQDX3 Disk Controller | C-D | Dual | | 8-12 | | Option Slots | | Dual/Quad | | | | | | | | 13 | M9058 | Signal Distribution Board | C-D | Dual | | | | Reserved for Future Use | A-B | Dual | The following configuration NOTES apply equally to the BA23 and BA123 system boxes. #### NOTES - 1. KA630-AA The KA630-AA (MicroVAX II with FPU and l MByte of memory) is a quad height board which requires the first slot in the backplane with QBus in A/B sections and CD interconnect in the C/D sections. - 2. MS630-AA The MS630-AA (1 MByte memory) is a quad height board which requires a full slot in the backplane. The slot must have the CD interconnect available and be adjacent to the MicroVAX CPU which limits the memory module to slot 2. - 3. VCB02 The video subsystem modules can be inserted in slots 5 through 8 (12 slots in the BA123 backplane), but must be placed in adjacent slots because of intermodule cable length. - 4. RQDX3 The RQDX3 interface module is a dual height board which requires a QBus slot in the backplane. # 2.2.1.1 BA23 System Box The BA23 system box supports the monochrome/4-plane color graphics MicroVAX workstation and is described as follows: - o H7864 230 Watt power supply - o H9278-a 8-slot Backplane - o Supports two full height 5.25 storage units - o Rear I/O distribution panel - o Front control panel and assembly The BA23 backplane of 8-slots accommodates the configuration shown in Figure 2-3 (see Table 2-2 NOTES above): | H9278-a Backplane D C B A | | |----------------------------|--------| | M7606AA ( KA630-AA ) | slot l | | M7608AA (MS630-AA) 1MB | slot 2 | | M9047 Grant Empty | slot 3 | | M7169 VCB02 Base Module | slot 4 | | M7168 VCB02 4-Plane Module | slot 5 | | M7504 DEQNA M7513 RQDX3 | slot 6 | | | slot 7 | | | slot 8 | | T = | | Figure 2-3 BA23 System Box Configuration # 2.2.1.2 BA123 System Box The BAl23 system box supports the 4- or 8-plane monochrome/color graphics MicroVAX workstation and is described as follows: - o H\*\*\*\* 460 Watt power supply - o H9278- 12-slot Backplane - o Supports four full height 5.25 inch storage units - o Rear I/O distribution panel - o Front control panel and assembly The BAl23 backplane of 12-slots accommodates the configuration show in Figure 2-4 (see Table 2-2 NOTES above): | H9278-a Backplane<br>D C B A | | | |-------------------------------|------|----| | M7606AA (KA630-AA) | slot | 1 | | M7608AA (MS630-AA) Quad 1 MB. | slot | 2 | | M9047 Grant Empty | slot | 3 | | M7504 DEQNA | slot | 4 | | M7169 VCB02 Base Module | slot | 5 | | M7168 VCB02 4-Plane Module | slot | 6 | | M7168 VCB02 4-Plane Module | slot | 7 | | M7513 RQDX3 | slot | 8 | | | slot | 9 | | | slot | 10 | | | slot | 11 | | | slot | 12 | | | | | | M9058 Reserved | slot | 13 | Figure 2-4 BAl23 System Box Configuration # 2.2.1.3 KA630-AA CPU The KA630-AA Processor module is summarized as follows: - o A Single Quad height module - o MicroVAX II Processor chip - o Floating Point Unit chip - o Q22 bus interface (see Appendix A) - o Q22 Map for DMA transfers - o 1 MB of on-board memory - o Addresses up to 16 megabytes of physical memory - o 1 serial line unit - o 64 kilobytes boot PROM - o 10 ms interval timer interrupts enabled by Internal Processor Register The KA630-AA supports the following subset of the VAX data types: byte, word, longword, quadword, character string, and variable length bit field. A floating point unit will support ffloating, dfloating, and gfloating. Support for the remaining VAX data types can be provided via macrocode emulation. The KA630-AA implements the following subset of the VAX instruction set: integer and logical, address, variable length bit field, control, procedure call, miscellaneous, queue, MOVC3/MOVC5, and operating system support. Floating point is implemented with an optional floating point chip. The remaining VAX instructions implemented via macrocode emulation (the MicroVAX CPU chip provides microcode assists for the emulation of the character string, decimal string, EDITPC and CRC instructions). A demand paged memory management unit is provided in the KA630-AA which is fully compatible with VAX memory management. # 2.2.1.4 MS630 · Memory Expansion Module The MS630- series of memory modules use the local memory interconnect which consists of the CD interconnect and a cable to create a direct path with the MicroVAX II CPU. This allows much faster memory access, since the memory responds directly to the CPU instead of routing through the QBus. These modules contain parity control and self identification logic. The MS630-requires the next slot (CD interconnect required) after the CPU or other MS630 option in the backplane. A maximum of two MS630-modules are allowed. For detailed information, refer to the system manual (AZ-GNFAA-MN). The MS630- comes in 3 variations which are used in various combinations on each system. - 1) MS630-AA 1 MByte dual height board - 2) MS630-BA3) MS630-CA 2 MByte quad height board - 4 MByte quad height board # 2.2.1.5 VCB02 Video Subsystem The VCB02 video subsystem is available in two versions: and 8-plane. Both versions are capable of monochrome and color operation. The BA23 system box workstation system will support 4-plane VCB02 video subsystem. The BA123 system box workstation system will support both the 4- and 8-plane versions. Each video subsystem supports two RS232 serial ports. One port is used by the LK201 keyboard and the other port is used by the VSXXX-AA mouse or the optional VSXXX-AB digitizing tablet. The VCB02-B module set option uses a Base Module and 4-Plane Module (two quad height boards). The BC18Z-10 cable is used for color operation and connects the system box to the VR290 color monitor. The BC18P-10 cable is used for gray shade operation and connects the system box to the VR260 monochrome monitor. The VCB02-C module set option contains the Base Module and two 4-Plane Modules (3 quad modules total). The BC18Z-10 cable is used for color operation and connects the system box to the VR290 The BCl8P-10 cable is used for gray shade color monitor. operation and connects the system box to the VR260 monochrome monitor. - 2.2.1.5.1 VCB02 Video Interfaces The VCB02 subsystems are QBus options. Performance is enhanced by the use of the VCB02 DMA Gate Array which allows data to be transferred quickly between the host system and the VCB02 bitmap. - o Base Module The VCB02 Base Module supports the system/user interface and either 4 or 8-planes of full page video memory. - o 4-Plane Module The VCB02 4-Plane Module contains 4-planes of video memory which is connected to the Base Module with a 50-pin flat ribbon cable. There are two versions of this cable to allow the Base Module to be connected to one or two 4-Plane Modules for 4- or 8-plane color systems. A separate 20-pin cable is used for control signals between the 4-Plane Module and the Base Module. ## 2.2.1.6 Mass Storage The following mass storage devices can be used in configuring the color graphics workstation system. - o RQDX3 Controller The RQDX3 controller is a dual height module and is the interface to the RX floppy diskette and RD Winchester disk drives. The controller is a Direct Memory Access (DMA) interface and uses the Mass Storage Control Protocol (MSCP). - o RX50-M The RX50-M is a dual 5 1/4 inch floppy diskette drive. Each diskette is capable of storing 400KByte of data. For further information, refer to the system technical manual (AZ-GNFAA-MN). - o RD53 Disk Drive The RD53 is a 5.25 inch Winchester drive with 71 MByte formatted capacity. For further information, refer to the system technical manual (AZ-GNFAA-MN). - o TK50 Tape Drive The TK50 is a streaming tape system with approximately 100 MByte formatted density. ## 2.2.1.7 Ethernet Controller (DEQNA) The DEQNA is a dual height module which provides an interface between the Print Station and the Ethernet network. This allows data packets (ranging from 46 to 1500 bytes) to be transferred over the Ethernet at a rate of 10 MBytes per second. #### 2.2.1.8 Monitors There are two types of system monitors offered with the MicroVAX workstations: the VR260 monochrome and the VR290 color monitors. - o VR260 Monochrome Monitor The VR260 monitor is a 19 inch diagonally measured monitor which is capable of displaying 1024 horizontal by 864 vertical pixels on the screen. The monochrome video BNC input is connected via the BC18P-10 monitor cable to the VCB02 patch panel in the BA23 system box. The VR260 is available as 100-120/220-240 volt 50/60 Hz AC unit and should need less than 65 watts of power. - o VR290 Color Monitor The VR290 monitor is a 19 inch diagonally measured monitor which is capable of displaying 1024 horizontal by 864 vertical pixels on the screen. The red, green and blue BNC inputs are connected to the BA123 system box by the BC18Z-10 color cable. The VR290 is available as a 100-120/220-240 volt 50-62 Hz AC unit. The VR290 should use less than 150 watts of power. #### 2.2.1.9 Monitor Cables There are two cables which can be used in configuring the two versions of the MicroVAX workstations (using BA23 or BA123 system boxes) which are: - o BC18P-10 Monochrome Video Monitor Cable is 10 feet long and connects the system box to the VR260 monochrome monitor. - o BC18Z-10 Color Video Monitor Cable is 10 feet long and connects the system box to the VR290 color monitor. # 2.2.1.10 LK201 Keyboard The LK201 keyboard uses the full duplex RS232 serial port on the VCB02 option. The 105-keys of the entire keyboard contains four groupings of keys (typing, editing, numeric keypad, and special function keys), a small speaker, four Light Emitting Diodes (LEDs), and associated electronic circuitry. A 1.9 m (6-foot) coiled cable connects the keyboard to a dedicated 4-pin MICRO-DIN connector on the monitor's rear panel. Refer to Appendix B for keyboard specifications. #### 2.2.1.11 Mouse The VSXXX-AA 3-button circular mouse is a hand held, ergonomically designed input device that is connected to the monitor by a 5-foot cable. The mouse signals are passed to the RS232 serial port on the VCB02 Base Module for display on the monitor screen. Refer to Appendix C for mouse specifications. ## 2.2.2 Options #### 2.2.2.1 Additional Memory Additional memory can be added to the system by using a combination of the MS630 series of memory option modules. The MS630-AA, BA, BB offer respectively 1 MBytes, 2 MBytes, and 4 MBytes of memory. # 2.2.2.2 Optional Tape Storage The TK50 allows a removable streaming tape with a capacity of 100 MBytes to be used on the MicroVAX workstation systems. On the BA23 system box workstation, the TK50 can be subsituted for the RX50, with Digital Software/Diagnostics available to support the system. The BA123 system box workstation may use the TK50 in addition to the RX50, allowing the system to use both methods of removable media. 2.2.2.3 Digitizing Tablet The VSXXX-AB digitizing tablet option consists of an 11 inch square tablet, a 4-button cursor, and a 2-button stylus. The tablet is connected by its 5-foot power/signal cable to the monitor's RS232 serial port, replacing the mouse cable connection. Refer to Appendix D for tablet specifications. # 2.2.2.4 Printers There are three types of printers offered as options for the MicroVAX workstation, which are: - o The LA50 is a 50 character per second impact printer. - o The LA210 is a 100 character per second impact printer. - o The LN03-AA is a 333 character per second 8 page per minute laser printer. Refer to the system technical manual (AZ-GNFAA-MN) for configuration procedures to be followed in interfacing the above printers. # 2.2.2.5 Communication Devices - o DZQll Asynchronous Multiplexer This dual height module has - This dual height module has four asynchronous serial lines which conform to RS232 and RS423-A interface standards. The DZQll can be used to support printer options and full duplex modem operations. - o DMVll Synchronous Controller - The DMVll is a quad height module which supports full and half duplex operations, point-to-point, multipoint communications, and DMA. ## 2.3 SYSTEM SPECIFICATIONS # 2.3.1 BA23 System Box ELECTRICAL Input voltage 88 - 128 VAC 176 - 256 VAC Frequency 47 - 63 Hz. Power consumption 320 watts (max.) 4.4 A @ 120 VAC. 2.2 A @ 240 VAC. # 2.3.2 BA123 System Box ELECTRICAL Input voltage 87 - 128 VAC 174 - 256 VAC Frequency 47 - 63 Hz. Power consumption 640 watts(max.) 8.8 A @ 120 VAC. 4.2 A @ 240 VAC. # 2.3.3 Environmental DEC Std 102 class A Temperature range 15 - 32 degrees C (59 - 90 degrees F) Humidity 20 - 80 % non condensing with a maximum wet bulb of 25 degrees C (77 degrees F) and a minimum dewpoint of -26 degrees C (6 degrees F). Note The recommended operating range is 18 - 24 degrees C (65 - 75 degrees F), 40 - 60% RH. Altitude 0 - 3 kilometers (0 - 10,000 feet). DEC Std 103 EMI Radiation limits will be within FCC class "A" # 2.3.4 VCB02 Power Requirements | | Supply<br>Voltage | Typical<br>Operating<br>Current | | |----------------|------------------------------|---------------------------------|--| | Base Module | 5V (+/- 5%)<br>12V (+/- 10%) | 5.8 amps<br>0.7 amps | | | 4-Plane Module | 5V (+/- 5%) | 3.4 amps | | #### 2.4 VCB02 INSTALLATION The VCB02 video subsystem is shipped as an integral part of the assembled MicroVAX workstation system and therefore requires no customer installation procedure. However, in the event the VCB02 is an add-on to an existing workstation system or requires servicing or replacement, the specific disassembly/reassembly procedures for accommplishing either task should be consulted in the appropriate BA23 or BA123 Enclosure Maintenance Guide. The VCB02 interconnections, backplane slot insertion, and switchpack (M7169 on VCB02 Base Module) settings are provided in this section to augument the previously referenced maintenance procedures. The cable interconnections for the VCB02-B video subsystem (4-planes) are shown in Figure 2-5. Figure 2-5 VCB02-B Cable Interconnections The cable interconnections for the VCB02-C video subsystem (8-planes) are shown in Figure 2-6. Figure 2-6 VCB02-C Cable Interconnections Figure 2-7 shows the interconnections for an 8-plane configured system when installed in the H9278-a backplane of a BA123 system box. #### NOTE Consult the disassembly/reassembly procedures in the appropriate System Maintenance Guide prior to attempting servicing or replacement of the VCB02 video subsystem. Figure 2-7 Interconnected VCB02 In BA123 System Box The VCB02 Base Module switchpack (see Figure 1-1) functions are set as indicated in Table 2-3. Table 2-3 Switchpack Function Settings | Switch | Function | Switch S | etting | |-------------|------------------------------|----------|--------| | Sl | Selects Address Line 3 | On=0 | Off=1 | | s2 | Selects Address Line 2 | On=0 | Off=1 | | <b>\$</b> 3 | Selects Address Line 1 | On=0 | Off=1 | | S4 | Selects size of Template RAM | On=8K | Off=2K | | | NOTE | | | | | S1 through S3 selects addres | ss lines | | Sl through S3 selects address lines for the I/O Page CSR #### 2.4.1 Intermodule Connections The VCB02 Base Module and the VCB02 4-Plane Module are connected by a cabling scheme that attaches to the top of the modules. The interconnect signals are sorted into two categories: - o Interconnect signals common to both 4-Plane Modules in an 8-plane system - o Interconnect signals unique to each of the 4-Plane Modules in an 8-plane system - 2.4.1.1 Common Intermodule Connections These interconnect signal subsets are listed in Table 2-4. - 2.4.1.1.1 Electrical Interconnects There will be two versions of a 50-signal flat ribbon cable with ground plane which are: one to support 4-plane systems and one to support 8-plane systems with daisy chaining capability between the three modules. - 2.4.1.1.2 Mechanical Interconnects There are 50-pin Berg headers mounted on the edge of the quad modules and aligned in the same location on each module. Table 2-4 Common Intermodule Connections | MEMORY SIGNALS | ••••••••••••••••••••••••••••••••••••••• | |-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | RAS CAS MEMOE LATCH CNTROL WSTB MWE0:MWE3 MAD0:MAD7 MAD9 ADDCLK | <ul> <li>(1) - Memory row address strobe</li> <li>(1) - Memory column address strobe</li> <li>(1) - Memory output enable</li> <li>(1) - External memory latch controller</li> <li>(1) - Memory write from Timing Generator</li> <li>(4) - Memory write enables from Address Processor</li> <li>(8) - Memory addresses from Address Processor</li> <li>(1) - Memory address from Address Processor</li> <li>(1) - Address pipeline strobe</li> </ul> | | | 19 Total | | SYSTEM CLOCKS | | | PHI1<br>PHI2<br>ALPHA<br>SYNC<br>SHIFT30<br>CLK30 | <pre>(1) - VCB02 video subsystem clock (1) - VCB02 video subsystem clock (1) - Video output clock (1) - System synchronization (1) - Video synchronizer (1) - Control synchronizer 6 Total</pre> | | VIDEO PROCESSOR | ••••• | | 128/-16 RD/-WR LTCLK ID0:ID7 SCROLL FORCE IDCTL WRSCR WRUCS | <pre>(1) - Cycle control (1) - Cycle control (1) - Video Processor latch clock (8) - Instruction/Data Bus (1) - Scroll Control (1) - Scroll Control (1) - Chip Select Control (1) - Scroll chip select write strobe (1) - Update chip select write strobe 16 Total</pre> | | | 16 Total | 2.4.1.2 Unique Intermodule Connections Signals between the VCB02 Base Module and the first VCB02 4-Plane Module are shown in Table 2-5. Table 2-5 Intermodule Connections (First 4-Plane Module) | VIDEO SIGNALS | | |----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | PlVIDO, PlVID1<br>P2VIDO, P2VID1<br>P3VIDO, P3VID1<br>P4VIDO, P4VID1 | (2) | | STATUS | | | OPT1 PRES<br>SELECT | <ul><li>(1) - Option 1 present</li><li>(1) - Defines 4-Plane Module Video</li><li>Processors to be low order</li></ul> | | | 10 Total | Intermodule signals between the Base Module and the second 4-Plane Module are shown in Table 2-6. Table 2-6 Intermodule Connections (Second 4-Plane Module) | VIDEO SIGNALS | | |----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------| | P5VIDO, P5VID1<br>P6VIDO, P6VID1<br>P7VIDO, P7VID1<br>P7VIDO, P7VID1 | (2) | | STATUS | | | OPT2 PRES<br>SELECT | <ul><li>(1) - Option 2 present</li><li>(1) - Defines 4-Plane Module Video</li><li>Processors to be high order</li></ul> | | | 10 Total | 2.4.1.2.1 Electrical Interconnects - Two different lengths of 20 signal flat ribbon cable with alternating signals and grounds are provided. The shorter cable is for the low order 4-Plane Module which will be configured adjacent to the Base Module, but on the opposite side from the QBus arbitrator (CPU Board). The longer cable will connect to the high order 4-Plane Module which is configured in the QBus backplane (next to the low order 4-Plane Module). This scheme allows the two identical 4-Plane Modules to appear electrically unique. 2.4.1.2.2 Mechanical Interconnects - The 4-Plane Module has one 20-pin Berg header located on the upper edge of the quad module. The Base Module has two 20-pin Berg headers; each aligned with the 4-Plane Modules, but with the low order connector on the edge of the quad module and the high order header located directly below it. This configuration supports the electrical interconnect described above. ## 2.4.2 I/O Interconnect An I/O interconnect is provided on the Base Module to route the user I/O interface signals to a bulkhead on the system box. The cabling scheme will connect to the top of the VCB02 module and terminate at the system box bulkhead. The path of the cable within the system box must be known before the length of the cable can be determined. The I/O signals are listed in Table 2-7. ## 2.4.2.1 Electrical Interconnects The electrical characteristics of the I/O cable are currently undetermined and will be supplied at a later date. #### 2.4.2.2 Mechanical Interconnects The 26-pin Berg header is located at the upper edge of the Base Module. The bulkhead side of the cable will terminate into a 15-pin D-Sub connector. Table 2-7 Input/Output Interconnect Signals | KEYBOARD PORT 1 | <br>K60 | FIN | | |-------------------------------------------------------------------------------------|----------------------------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------| | Transmit to k80 Receive Frank82 Power +12 Ground | (1) 4 /6 | 19 19 19 19 19 | · <b></b> · · · · · · · · · · · · · · · | | AUXILIARY PORT 2 | Mouse. | | 20 PM DVAL | | Transmit to 5N Receive from 5'N Power +5 Ground -12 V VIDEO SIGNALS | (1) 9 470<br>(1) 1 404<br>(1) (1) | (FROM MC 3438) 40 SUART FW7 PING | 13 5 7 9 H 13 15 17 7<br>2 4 6 8 10 12 14 10 18 20<br>15 FIN EIA<br>2 3 4 5 6 7 8<br>9 10 11 12 13 14 15 | | Red Video<br>Red Ground<br>Green Video<br>Green Ground<br>Blue Video<br>Blue Ground | (1) 16<br>(1) 15<br>(1) 18<br>(1) 17<br>(1) 20<br>(1) 19 | 12. | | | | · | MC3HBB = 9636A = 423<br>(S | 1232 GRIVER | ## 2.4.2.3 Bulkhead Connector The 15-pin D-Sub to D-Sub connector mounted on the system box is currently undetermined and will be supplied at a later date. # 2.4.2.4 System I/O Interconnect The system I/O cable is currently being defined and will be supplied at a later date. CHAPTER 3 FUNCTIONAL DESCRIPTION #### 3.1 SUBSYSTEM OVERVIEW This chapter describes the hardware functions of the VCB02 video subsystem. The VCB02 video subsystem is a Q-22 bus compatible, full page bitmapped graphics video subsystem designed to support either the VR260 monochrome or VR290 color monitors. A DMA Gate Array chip (DC7035) provides the VCB02 with a specialized DMA engine that interfaces the Q-22 bus with the VCB02's video logic. The video logic is based on the Address Processor (DC 323) and Video Processor (DC322) The Address Processor chip is responsible for all bitmap memory address calculations, CRT control, and video datapath control. The Video Processor chip is responsible for all data manipulations to and from bitmap memory and data output to the video refresh stream. Each VCB02 video subsystem has one Address Processor chip and one DMA Gate Array. One Video Processor chip is used for each plane of bitmap memory in the VCB02 video subsystem. The VCB02 video subsystem is designed to support either 4 or 8 planes of bitmap memory. color monition a 4 plane system can display 16 colors (shades of gray for a black and white monochrome monitor) from a palette of 16.7 An 8 plane VCB02 video subsystem can display 256 million colors. colors (shades of gray) from a palette of 16.7 million colors. resolution of 1024 horizontal by 864 vertical pixels is provided by both the 4 and 8 plane versions of the VCB02 video subsystem. Each VCB02 video subsystem has a Base Module that provides the Q-22 bus interface, diagnostic ROM, two asymnchronous communication ports, the Address Processor, color maps, and video timing and output logic. A 4 plane VCB02 video subsystem also has one 4-Plane Module that provides four Video Processor chips, four planes of bitmap memory, and chip select registers for the Video Processors. In addition to the Base Module, an 8 plane VCB02 has two 4-Plane Modules for a total of 8 planes of bitmap memory and 8 Video Processor chips. An 8 plane VCB02 video subsystem is a three module set, while a 4-plane VCB02 video subsystem is a two module set. The Base Module communicates with the 4-Plane Module(s) over cables. A 4-plane VCB02 video subsystem can be upgraded to an 8-plane system by adding a second 4-Plane Module and changing the module communication cables. ## 3.2 VCBO2 MODULES #### 3.2.1 Base Module The Base Module (M7169) contains the hardware which processes address calculations, interfaces the DMA to the QBus, accesses display lists using the Template RAM, controls cursor movement, accepts serial I/O bus input from attached keyboard/mouse/tablet devices, self test/diagnose malfunctioning module components using LED indicators, emulate consoles, supply subsystem timing generation, and provides an 8-plane video output path for its color bitmaps. The Base Module is shown in Figure 1-1 and a block diagram of the module is presented in Figure 1-2. In Chapter 2, additional information is supplied on: configuring the Base Module and 4-Plane Module in a workstation system box, a tabulation of each module's power requirements, the various intermodule connections, and instructions on module installation/servicing. # 3.2.1.1 Instruction/Data Interconnect The I/D interconnect is a byte wide synchronous interconnect between the Address Processor, Video Processor, and Chip Select Registers. The I/D interconnect is synchronized to the system PHIl and PHI2 clocks which are further divided into PHILA, PHILB, PHILA, and PHILB. Instructions are transferred on the A clocks and data is transferred on the B clocks. 3.2.1.1.1 Chip Select Decoding - The Base Module generates either a scroll or update chip select strobe when a chipselect instruction is decoded. The Video Processor chip selects are decoded from the I/D interconnect. To accomplish this, A and B clocks and decode logic provided on the Base Module and either a scroll chip select write strobe (WRSCR) or an update chip select write strobe (WRUCS) are generated if a chip select instruction is decoded. These two signals are cabled to the 4-Plane Module through the module interconnect and strobe the data into registers on the I/D interconnect. The external chip select load commands are shown in Figures 3-1 through 3-4. #### FUNCTIONAL DESCRIPTION 8 15 | X | X | X | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | X | X | X | X | X | X +--+--+--+--+--+--+---+---+---+---+---+---+---+---+---+---+---+---+---+---+ X - don't care Figure 3-1 Scroll Chip Select Load Format - Command 140H 8 7 15 <del>+</del>---<del>+</del>---+--++--+ | x | x | x | x | x | x | x | x | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 +--+--+--+--+--+--+---+---+ <8:1> - Video Processor plane that will be chip selected by this bit ('l' = asserted) X - don't care Figure 3-2 Scroll Chip Select Load Format - Data 8 7 15 +---+---+---+---+---+---+ | X | X | X | O | O | O | O | 1 | O | 1 | 1 | X | X | X | X | X | X X - don't care Figure 3-3 Update Chip Select Load Format - Command 160H 15 8 7 +---+---+---+---+---+---+---+ +--+--+--+--+--+--+--+--+ <8:1> - Video Processor plane that will be chip selected by this bit ('l' = asserted) X - don't care Figure 3-4 Update Chip Select Load Format - Data # 3.2.1.2 Subsystem Timing Generation The timing needed to run the VCB02 video subsystem fall into three categories which are system clocks, memory strobes, and video clocks. The pixel clock (69.1968 MHz) is used as the main divide down frequency. The inputs and the outputs of the timing generator are listed below. ``` INPUTS - all sourced by the Address Processor Sync Request Next Cycle Next Rd/-Wr Force SYSTEM CLOCKS - PHIL PHI2 PHI3 PHI4 ALPHA 128/-16 RD/-WR SYNC LTCLK MEMORY STROBES RAS CAS WSTB MEMOE LATCH CNTRL ADDCLK VIDEO TTL/ECL 15 H TTL/ECL 30 H TTL/ECL 30 L CONV H CONV L ``` Note that on power-up, memory and system clocking will not begin until POK has been received so that the system will power on in a consistent manner. ## 3.2.1.3 Video Output Logic The devices that source data for the video output are the Video Processors, with bitmap data, and the DMA Gate Array, with cursor data. Video data from all sources is presented to the video output logic in 4 bit nibbles. The four main functions provided by the video logic are hardware cursor support, mapping of the video data through a color look up table (LUT), converting the digital video information into RS-170 voltage levels (not timing) for output to the monitor, and looping back the video output for diagnostic readback and self test. #### FUNCTIONAL DESCRIPTION The following subsections described the operation of the hardware cursor, the color map loading, and the video loopback register. The digital to analog conversion is not accessible to the programmer. - 3.2.1.3.1 Hardware Cursor The two plane hardware cursor will be used to multiplex the video information to the pixel level in the following way: - Cursor plane A data is "0" The cursor is transparent and bitmap data will appear on the screen. Note that this will be the general case any time the cursor positioning logic is not outputing cursor data. - Cursor plane A data is "1" This can occurr only when the positioning logic is outputing cursor data. In this case, cursor plane B data will control data to the screen in the following way: - Cursor plane B data is "1" Location [255] of the color map will be accessed. This location will always be considered foreground cursor color, but may be accessed by bitmap data as well. - Cursor plane B data is "0" Location [254] of the color map will be accessed. This location will always be considered background cursor color, but may be accessed by bitmap data as well. - 3.2.1.3.2 Synchronization and Blank Video synchronization and blank are programmable by the Address Processor on any rising PHI3 or PHI4 clock (57 ns interval nominal). They must then be synchronized to the video timing and shifted, so that their pipeline is equivalent to that of the video output path. Video blank can also be enabled by setting a bit in the Memory CSR. - 3.2.1.3.3 Video Upgrade Path When only one 4-Plane Module is installed, the upper 4 bits of the video data path are disabled. - 3.2.1.3.4 Color Map Loading Color Map Loading pertains only to the Base Module. In a 4-plane configuration, only the low 16 addresses need to be loaded in each map, except for locations [254] and [255] (used by the hardware cursor). In an 8-plane configuration, all 256 locations should be loaded. The Red, Green, and Blue color maps are accessed independently (256 locations for each map). Figure 3-5 shows the format for the color map data. | 15 | | | | | | | 8 | 7 | | | | 0 | |----|---|---|------------|---|---|---|---|-------|-----------------|------|------|-----| | ++ | | + | + | + | + | + | + | ++ | · + - <i></i> + | ++ | + | -++ | | X | X | X | X | X | X | X | X | MSB : | COLOR MAR | DATA | BYTE | LSB | | ++ | | + | <b>+</b> - | + | + | + | + | ++ | + + | ++ | + | -++ | X - not loaded # Figure 3-5 Color Map Data Format Color maps should be loaded only during vertical blank time, so that no glitches are noticed on the screen. If that is not possible, a bit is provided in the CSR which will force the video to a blank state while the maps are being loaded. ## 3.2.1.4 I/O Devices The VCB02 video subsystem will have two serial, EIA RS-232 compatible ports that can be addressed. One port will always be reserved for the LK201 keyboard and the other port can be used for any other serial device, but will probably be used for either a mouse or a tablet. For programming information concerning these ports consult Appendix B, C, and D, respectively. NOTE The serial ports are RS-232 voltage compatible only. - 3.2.1.4.1 LK201 Keyboard The LK201 keyboard is the keyboard interface to the VCB02 video subsystem. A double buffered UART in the QBus I/O space provides the send/receive port to the 4800 baud serial device. A switch closure on the keyboard causes an interrupt to the QBus to be serviced by reading the value of the UART receive register at the CSR address specified in the map. The LK201 keyboard is described in Appendix B. - 3.2.1.4.2 Mouse The 3-button circular mouse is supplied with the MicroVAX workstation and is RS-232 compatible using standard serial input device protocols. The mouse is described in Appendix C. - 3.2.1.4.3 Tablet Or Alternate Pointing Device The optional digitizing tablet will respond at the address found in the CSR map. It is capable of interrupting the MicroVAX workstation to service either position changes or external events. The tablet is described in Appendix D. An alternate pointing device, such as a plotter can be substituted. - 3.2.1.4.4 Serial Device Protocols The protocols for serial devices are discussed in the respective appendix for the device herein: Appendix B LK201 keyboard, Appendix C 3-button circular mouse, and Appendix D optional digitizing tablet. - 3.2.1.4.5 Monitors The monitors specified for the VCB02 module set are the VR260 for monochrome applications and the VR290 for color applications. - 3.2.1.5 System Support The system support provided by the VCB02 module set will include console emulation, multiple VCB02 terminal support, and full diagnostic support. - 3.2.1.5.1 VCB02 Address Map Each VCB02 video subsystem has one register in the QBUS I/O Page (see Figure 3-6). Switches on the Base Module will select one of eight possible addresses for this register as listed below. When read, this register will provide an Identification Code for VCB02. Data written to this register selects the VCB02 Memory Base Address (on a 64 kb boundry). Figure 3-7 shows the QBus memory space. | | QBUS I/O PAGE | |---------------------------|---------------| | | ++ | | VAX ADDRESS = | | | QBUS I/O PAGE BASE + 1E8x | + | Figure 3-6 QBus I/O Page # VCB02 Terminal Mapping scheme: Figure 3-7 QBus Memory Space # FUNCTIONAL DESCRIPTION Register Mapping is diagrammed in Figure 3-8. All registers are accessed on word boundaries. | BASE + E000 | (Hex) | + | |-------------|-------|---------------------------| | | | Reserved | | BASE + D000 | (Hex) | Green Color Map | | BASE + CE00 | (Hex) | ++ | | | | Blue Color Map | | BASE + CC00 | (Hex) | Red Color Map | | BASE + CA00 | (Hex) | + | | | | CSR Registers | | BASE + C800 | (Hex) | Communication Device 2 | | BASE + C600 | (Hex) | ++ | | | | Communication Device 1 | | BASE + C400 | (Hex) | Cohe Doron (DCD) | | BASE + C200 | (Hex) | Gate Array (DGA) | | | | Address Processor | | BASE + C000 | | ++ | | | Fi | gure 3-8 Register Mapping | 3-9 3.2.1.6 Control And Status Registers (CSRs) The VCB02 video subsystem has two control and status registers, one is located in the QBUS I/O Page and the other is located in QBUS memory space. Both registers are read and write and their bit assignments are as follows: 3.2.1.6.1 I/O Page CSR - The format for the I/O page CSR read VCB02 identification code is shown in Figure 3-9. | 15 | 8 | 7 | | 0 | |--------------------------------------------------------------------------------------------|---|-----|----------|-------| | + | + | + | · + + · | ÷++ | | $\mathbf{x}$ $\mathbf{x}$ $\mathbf{x}$ $\mathbf{x}$ $\mathbf{x}$ $\mathbf{x}$ $\mathbf{x}$ | X | X 6 | 5 X X | 2 1 0 | | ++ | + | + | <b>+</b> | +++ | Bit 6 : Option 2 Present ('0' = asserted) Bit 5 : Option 1 Present ('0' = asserted) Bit 2 : Full Page System Configuration ('1' = asserted) Bit 1 : Half Page System Configuration ('1' = asserted) Bit 0 : Quarter Page System Configuration ('1' = asserted) X : not defined Figure 3-9 I/O Page CSR Read VCB02 ID Code Format The value written into the Memory Base register selects the starting address or base address of a 56 kb block of addresses that will be decoded by the VCB02 DMA Gate Array. The base address is always on a 64 kb boundary in the QBUS memory address space as selected by bits 00 through 05 of the Memory Base Register. Bits 05 through 00 are compared with the signal pins A(21:16) H during the address portion of QBUS memory cycles. The Write Memory Base format is shown in Figure 3-10. Figure 3-10 Write Memory Base Register Format **3.2.1.6.2** Memory CSR - The Memory CSR Read Video Readback Register format is shown in Figure 3-11. ``` Bit 3 : Sync Detect ('0' = asserted) Bit 2 : Blue > Red ('0' = asserted) Bit 1 : Green > Blue ('0' = asserted) Bit 0 : Red > Green ('0' = asserted) ``` Figure 3-11 Memory CSR Read Video Readback Register Format The Memory CSR Write format for the Control Write Register is shown in Figure 3-12. ``` Bit 5 : CSR Blank ('0' = asserted) ``` Bit 4 : CSR Video Readback ('l' = asserted) Bit 3 : CSR Sync Enable ('l' = asserted) Bit 2 : LED for high order Memory Upgrade failure ('0' = asserted) Bit 1 : LED for low order Memory Upgrade failure ('0' = asserted) Bit 0 : LED for Base Subsystem failure ('0' = asserted) Figure 3-12 Memory CSR Write Format for the Control Write Register #### 3.2.1.7 Console Emulation The VCB02 video subsystem supports console emulation through interactions of the MicroVAX CPU, the MicroVAX Boot ROM, and the VCB02 ROM which will be mapped in the VCB02 address space. The VCB02 video subsystem is the Alternate Console device and will support Micro/ODT by providing an ASCII interface to the system when in console mode. The VCB02 ROM will be word addressable to allow direct MicroVAX CPU reads. For a more detailed discussion of the VCB02 Diagnostic requirements, refer to Chapter 5. 3.2.1.8 Diagnostic Support 3.2.1.8.1 Diagnostic ROM - The VCB02 ROM will provide code for both diagnostics and console emulation. For further information on the VCB02 ROM, consult Chapter 5. - 3.2.1.8.2 Bitmap and Template Memory Access The memory on the VCB02 4-Plane Module can be divided into 3 categories: - 1. Bitmap memory - 2. Template RAM - 3. Video Look Up Table (LUT) All bitmap memory can be accessed through Processor to Bitmap and Bitmap to Processor transfers which are executed through the Address Processor and Video Processor chips. Template RAM memory is directly accessible through QBus transfers. The LUT which can be written directly is read back indirectly through the Memory CSR as described in the following subsection. 3.2.1.8.3 Video Readback - The Video Readback path is accessed through the Memory CSR. There are three readable bits that correspond to comparisons of the outputs of the video digital to analog converters. By comparing the three outputs to each other and incrementing through the different voltage levels, a high degree of confidence can be gained in the integrity of the video output data path. The resolution of this comparison is expected to be 20 mV. A fourth CSR bit is provided that shows the comparison of the synchronization pulse voltage level on the green gun to a known reference voltage. This test will help diagnostics determine if there is an error on the VCB02 module or if it is a monitor/cabling problem. The reference voltage will be set at 0.1 V and the comparison resolution is expected to be 20 mV. #### 3.2.2 Four Plane Module The 4-Plane Module (M7168) contains the hardware which provides the 4-plane, full page memory to the Base Module. Chapter 1 lists the 4-plane module's hardware and includes an illustration and block diagram. For configuration, power requirements, intermodule connections, and installation information, refer to Chapter 2. 3.2.2.1 Video Memory Structure The VCB02 video subsystem provides for each 'onscreen' page of memory within a plane an equal amount of 'offscreen' memory. 'Onscreen' refers to the memory that is used for screen refresh. The VCB02 video subsystem presents to the programmer a block of memory that is (1024H) x 2048V). # 3.3 ADDRESS AND VIDEO PROCESSOR OVERVIEW This section presents an overview of the features and operation of the Address and Video Processor chips as implemented on the VCB02 Video Subsystem. The Address Processor chip (DC323) is the controller for all video operations the VCB02 video subsystem. The DMA gate array on the VCB02 Base Module controls the register interface of the Address Processor using a 16-bit private data bus, a 6-bit address bus, and control signals. Internal to the Address Processor is a register structure through which all commands to, and information to and from, the video chips must pass. Communication between the Address Processor and Video Processor chips occurs on a byte wide Instruction/Data bus (I/D bus). The Address Processor chip registers can be classified into scroll, rasterop parameter, and four categories: control, configuration registers. Once these registers have been properly loaded, the Address Processor chip will synchronize all internal address calculations, CRT control, and external memory cycles with the Video Processor chip's data manipulations using control signals and the I/D bus. The Video Processor chip (DC322) is the bitmap datapath for all VCB02 video subsystem transactions. The Video Processor chip is controlled by signals from the Address Processor chip and by 20 programmable registers that can be loaded from the I/D bus. These registers can be classified into three categories: scroll, rasterop, and configuration registers. Once properly loaded, the Video Processor is capable of sourcing and receiving data on the I/D bus, logical operations on bitmap data, barrel shifting, and sourcing data to the output video bus. The I/D bus is a byte wide synchronous interconnect between the Address Processor, Video Processor and chip select registers. The I/D bus is sychronized to the system PHI1, and PHI2 clocks which are further divided into PHI1A, PHI1B, PHI2A, and PHI2B. Instructions are transferred on the A clocks and data is transferred on the B clocks. # 3.3.1 Hardware Support A block diagram for the VCB02 Video Subsystem is shown in Figure 3-13. The Address Processor chip is responsible for functions that are common to all bitmap planes, such as: all rasterop computations, bitmap address generation, clipping, screen refresh, scroll control and monitor synchronization generation. The Video Processor chip (DC322) provides the data path and control data FIFOs for refresh and scrolling, a barrel shifter for bit alignment, a logic unit with data and mask registers for memory modification, Z-axis address logic, and a control store RAM to define Video Processor chip operations during rasterops. Figure 3-13 VCB02 Video Subsystem Block Diagram # 3.3.1.1 Buses The Address Processor chip communicates on three buses: - 1. The private data bus is controlled by six control and six address lines and has 16 bi-directional data lines that transfer data to/from internal registers in the Address Processor chip. These registers may be addressed in two ways: - a. The six address lines are provided for direct access by the MicroVAX CPU through its normal memory or I/O addressing modes - b. An address counter in the Address Processor chip allows the DMA logic in the DMA gate array to pass data and control words to sequential Address Processor chip registers via a single register (address). - 2. The bitmap address bus provides 11 bits each of multiplexed row and column address to the bitmap RAM. The VCB02 uses 8 row and 9 column addresses to access 128 Kwords (2 Mbits) of bitmap memory. All addresses for screen refresh, scroll write back, and bitmap read and update are provided on this bus. - 3. The instruction/data (I/D) bus (interconnect) controls the Video Processor chips and provides for all data flow between Video Processor chips and the MicroVAX CPU (via the Address Processor chip). Each cycle of the 8 bit I/D bus has four states that provide a 16 bit instruction from the Address Processor chip to the Video Processor chips and 16 bits of data from one I/D bus device to the others. These cycles are used to configure the Video Processor chip registers, to regulate data transfers during rasterops, and to load the chip select registers on the I/D interconnect. The chip select registers external to the Video Processor chips and controlled by the I/D bus are used to enable one or more Video Processor chips to perform a transfer. The Video Processor chips use three buses: - The I/D bus (interconnect) described above. - The 16 bit memory data bus is used in the transfer of all data into or out of the memories during screen refresh, scroll write back and memory update. - 3. The video output bus supplies the bit stream for each plane as successive 4 bit nibbles. These nibbles are externally processed by the color map, video shift registers and D/As to provide the video signal to the monitor. #### 3.3.1.2 Bitmap Memory Each plane of bitmap memory is configured as eight $64K \times 4$ dynamic RAMs. A total of 2 Mbits is provided for each plane with 864 Kbits used for screen refresh (1024 horizontal by 864 vertical pixels). The remainder is used for offscreen storage of fonts and bitmap data. # 3.3.1.3 Timing Hardware timing refers to a nominal pixel period of 15 nsec (14.45 nsec actual). All bus timing, with the exception of the video output bus, and is based on multiples of a 30 nsec clock. The 4 bit wide video bus operates at 60 nsec. The register interface on the Address Processor chip is asynchronous to the rest of the video hardware because its timing is controlled by the DMA gate array. There are two kinds of bitmap memory cycles. A major cycle (960 nsec nominal) is used to read or write 8 words (128 bits) to or from the Video Processor chip for screen refresh or scrolling. Any unused major cycle is subdivided into two minor cycles (also called update cycles, 480 nsec nominal) during any of which either a read or a read-modify-write of a word may occur to accomplish bitmap update. Refresh of the dynamic bitmap memory is accomplished every 593 usec (except during vertical retrace, which is less than 677 usec) by the screen refresh reads (worst case refresh time = 1.263 msec). Figure 3-14 shows an example of a scan which has been divided into 16 major cycles, 7 of which are used for screen refresh, 7 may be used for scroll writeback, if any of their words are contained in a scrolling region, and the remaining 2, plus any unused scroll cycles, are divided into minor cycles for updates or NOPs. The address bus provides one row and eight column addresses during a major cycle, and one row and one column address during a minor cycle. The data bus to the Video Processor chips operates concurrently to transfer 8 words (128 bits) during a major cycle, and to read and return a modified word (16 bits) during a minor cycle. Figure 3-14 Memory Cycles During One Scan In the VCB02 each scan is programmed to last 10 major cycles (8 are used for screen refresh). The positioning and width of horizontal blank and synchronization are programmable with respect to memory cycles (they are set to those required by the VR260 and VR290 monitors). The number of scans per frame is programmed to 901 (including vertical retrace time); the number of displayable scans is 864. The position and width of vertical blank and synchronization are programmable (they are set to those required by the VR260 and VR290 monitors). The I/D bus operates continually at the minor cycle rate (480 nsec nominal), whether major or minor cycles are in progress and in sync with the memory cycles, during which two instruction bytes and two data bytes are transferred. The computation cycle of the Address Processor chip is two major cycles (1920 nsec, nominal). During this time, all source and destination address computations occur for one step of a rasterop. This step may be either one pixel or, if the rasterop is progressing parallel to the X axis and is not scaling the source, a whole bitmap bus word. Four additional compute cycles are required to initialize a rasterop. Computation can occur with or without available update cycles and there is a small amount of buffering of results (6 addresses, e.g.: 3 sources and 3 destinations, 6 destinations, etc.). This allows optimum use of update cycles. No source and one source operations are compute bound, when no scrolling is in progress; any other operations may be memory cycle bound. In general, the time to load data and start the next rasterop is in addition to the rasterop execution time, although the rasterop origins may be loaded during rasterop execution, so that sequential text characters may be written to the bitmap without wasting time between characters. # 3.3.2 Memory Organization The Address Processor chip provides one large rectangular bitmap memory of fixed dimensions for the storage of data. Any address to this memory consists of an X and a Y component. All bit map space must be allocated two dimensionally. The bitmap memory is not directly accessible by the MicroVAX CPU, and the Address Processor chip does not perform rasterop manipulations in the MicroVAX CPU's memory; but, requests may be made for data exchange between processor memory and the bitmap. The DMA gate array can be used to DMA bitmap data to/from the MicroVAX CPU's memory. The memory is divided into an on screen and an off screen portion. The on screen memory is a rectangle starting at the address [0,0] to (but not including) the address $[X \ limit = 1024, \ Y \ limit = 864]$ (these limits are programmable in the Address Processor chip); this includes all memory that is read (but not necessarily displayed) by the screen refresh process. #### 3.3.3 Subsystem Control The hardware is controlled by the MicroVAX CPU through the loading of command and data registers in the Address Processor chip. Registers control the configuration of the Address Processor and Video Processor chips for: screen format, video synchronization, scrolling, and rasterops. The MicroVAX CPU can load any of the writable registers directly. Several status bits can be read by the MicroVAX CPU to verify the readiness of the Address Processor chip to accept (or provide) data; these include: rasterop initialization complete, rasterop computation complete, address buffer empty, pause complete (programmable frame synchronization), scroll service required, and vertical blank (fixed frame synchronizations), I/D bus data ready, and various clipping occurrences. Any of these status bits may be enabled to assert an interrupt request pin on the Address Processor chip (connected to the interrupt logic in the DMA gate array). To allow decoupling of the MicroVAX CPU from Address Processor chip execution, an interface to a DMA controller (in the DMA gate array) has been provided. A request pin may be programmed to assert, on any of the same conditions, that are available as flags or interrupts to the MicroVAX CPU. This pin will request the next data word from the DMA gat array. When loading data and command registers, the DMA gate array writes to a special address in the Address Processor chip that is associated with an internal address counter. If the MSB of the data word is clear, the counter addresses the Address Processor chip register to which data is to be transferred; the counter incremented after each word is transferred. If the MSB of the data word is set, the address counter is loaded with the low six bits of the data word. Only the I/D bus data registers contain 16 significant bits of data; to allow arbitrary data to be loaded to these addresses. The MSB does not cause the address counter to be loaded, if it is pointing to either of the I/D data registers (the addresses of these registers are preceded by reserved register addresses, so that no register load will cause the address counter to be inadvertently left pointing to an I/D data register). The register addresses are assigned, such that common repetitive functions only need access one group of consecutive registers, in addition to the command register. A group of special instructions have also been implemented in the DMA gate array to futher assist in the execution of commands. # 3.3.4 Viewport Support To assist the implementation of multiple viewports on the screen, the VCB02 chips provide clipping to and scrolling or dragging of rectangular regions (the term "region", refers to the implementation of viewports in the hardware). The top and bottom of a region may be set to any pixel, the left and right edges must lie on a multiple of 4 pixels from the left side of the screen. Figure 3-15 shows examples of possible region configurations. There is one clipping (update) #### FUNCTIONAL DESCRIPTION region and one scrolling region at any instant, but the two are independent of each other, so that writing and scrolling may be active in different regions at the same time. Any part of the screen not currently contained, in either the clipping or scrolling region, cannot be modified and will continue to contain any data placed in it, when it was previously contained in a region. The whole update region may be either scrolling or not, but a region should not be updated if only part of it is scrolling (eg. region 11 should not be updated if region 5 is being scrolled). When updating a region, clipping allows the image outside of the region to still be computed, but with writing disabled. The Address Processor chip provides status to the MicroVAX CPU to indicate if any rasterop was completely or partially clipped while writing or whether any rasterop was not completely clipped (to aid a picking algorithm). These clipping status bits are accumulated as rasterops progress and may be read or cleared at any time, but the results are only predictable if they are read or cleared between rasterops. To the greatest extent possible, the regions are allowed to be independent. In some ways, this is not possible. The scrolling resource must be allocated to only one region per frame time (and an additional frame time is normally required to change regions). All regions must share one color map and agree on the resolution mode settings. Unless large amounts of extra bitmap are provided, regions share the off screen areas used for symbol and data storage. Obviously, overlapping regions cannot be independent of each other. Figure 3-15 Region Configuration Example # 3.3.4.1 Scrolling Scrolling movement can be up, down, left or right (not diagonally) at a rate from 0 to 15 pixels/frame (or faster for vertical scrolls). The part of the region vacated by the moving image is simultaneously filled with any solid color. Scrolling uses part of the memory time that would otherwise be available for writing; but, even when the whole screen is in motion, about 30-40 percent of the non-scrolling update time is still available for source/destination operations, depending on screen format (50-80 percent of non-scrolling time is available for destination only or source only operations because these operations are primarily compute bound, when not scrolling). #### NOTE Actually, the distance that may be moved during an upward scroll is limited only by the number of scan times allowed for vertical retrace, as this time is used to write the fill color back into the vacated memory (if the region extended to the bottom of the screen). The distance of a downward scroll is subject to the memory limitation described below. Scrolling is accomplished by moving all of the scrolling data from its old position in memory to a new position. The normal screen refresh process reads and displays the existing memory data; and additional memory write cycles are used where necessary to return scrolling data to new locations. This is the only technique that allows any size region, including the whole screen, to be scrolled in one frame time; but there are two unpleasant side effects. First, only one region can be in motion during a frame time, because two regions might want to write portions of the same word to more than one memory location. Second, down scrolling cannot be accomplished in the obvious way because this would require writing data into memory locations not yet read by the refresh/scrolling process, thereby destroying screen data. Instead, down scrolling moves all of the data outside the scrolling region up, and then offsets the memory address at which screen refresh starts reading the bitmap, thereby creating the illusion that the scroll region moved down. (Proper synchronization is maintained so that the data outside the region does not move). This creates four bad effects: - Some scans of memory must be reserved (and not displayed) to prevent data at the bottom of the screen from being overwritten by data from the top. The number of scans required is equal to the maximum distance, in pixels, to be down scrolled in one frame time. - The consumption of writing time is as if the whole screen were up scrolling. Scroll writing must occur throughout the frame so that all data can be moved up in planes where scrolling is "disabled". - 3. Diagonal scrolling is not possible because different data must be moved for the downward and sideways motion of a region. - 4. Management of the Y Offset adds extra work for the MicroVAX CPU. To synchronize scrolling commands with screen refresh, most of the scroll related registers in both the Address Processor and Video Processor chips are double buffered. In the Address Processor chip, the index registers are only buffered to the extent required for the continuation of scrolling in one region (see NOTE below). The pending half (top level) of any of the buffered registers is addressable by the MicroVAX CPU and is loaded at any time during a frame; between frames, the Address processor chip transfers the data from all pending registers to the active registers and then sets the flag that requests more scroll data. To prevent interference between the loading of Video Processor chip registers for scrolling and for update, a separate I/D command and data path (including chip select control for the Video Processor chips) is provided for scrolling; this allows a scroll service routine to act without regard to the state of update service. The scroll and update services must avoid using each other's registers. #### NOTE . To conserve die area in the Address Processor chip, scroll registers are only buffered to the extent required to sustain scrolling or dragging of a single region. Extra buffering of the index registers would be needed to scroll different regions in successive frames. This function is not considered important because its only use would be in trying to simulate simultaneous scrolling of two separate regions; however, a smooth effect cannot be achieved by this technique, anyway, so it should not matter if the abruptness of jump scrolling of the two regions is increased. If the MicroVAX CPU can service an interrupt request to load four registers in 200-500 usec then it will be possible to scroll different regions in successive frames without the extra buffering of the index registers. (Normally, the MicroVAX CPU may take an entire frame time to load any buffered register.) #### 3.3.4.2 Dragging The scroll function can be used to smoothly drag a region to a different place on the screen. For each increment of motion, the scroll boundary registers are set for the current region location, but with the region size increased in the direction of motion by the distance to be moved; this allows the whole region to be moved, without the normal truncation, and leaves the fill color in the "wake" of the region. Because the region boundaries can only be defined on four pixel increments in the horizontal direction, horizontal dragging must stop on four pixel boundaries; however, it is possible to move the region at any valid scroll speed during the drag. If desired, the area to be covered by the moving region may be saved prior to each movement; and the area vacated may be restored following each movement. A region cannot be updated, while it is scrolling, because there is no way to synchronously change the clipping boundaries; the clipping boundaries are NOT double buffered like the boundaries. 3.3.4.3 Clearing a Region The Address Processor chip has a provision to allow a region to be cleared to the fill color in one frame time, using the bulk scrolling hardware. This action will be linked to one frame time in the same way that scrolling is. While small regions (less than one sixth of the screen) can be cleared more quickly with a rasterop and without waiting for the next frame time, use of the erase mechanism will provide a very clean appearance, because it is synchronized to occur between two display frames. 3.3.4.4 Drawing in the Scrolling Region The blank space that is created by scrolling needs to be filled with new data. It is desirable to draw while scrolling continues, so that The indexing the smooth effect of the scroll is not disturbed. mechanism of the Address Processor chip allows data to be drawn to the correct screen location without regard to how scrolling is moving the Typically, the update process draws the display list (or selected portions of it) repeatedly to keep filling in the scroll region as more blank space is created. The clipping region stands still during scrolling to prevent data from being written outside the However, this means that the clipping region cannot be used as a "drawing function" to control the shape or extent of objects being drawn into a moving region, because the clipping region does not move with the objects as they are drawn. Also, clipping cannot be used to prevent multiple writes of data when the same display list segments are repeated during scrolling; this would require the clipping region to follow a particular set of blank pixels as they move on the screen. Multiple writes will create problems for display lists that contain segments drawn in complement mode or drawn with the painter's algorithm (in which successive elements replace previous elements). To enable synchronizing the update process with scroll commands, (to fill the blank areas created by scrolling), the pause register and the interrupt or request enable bits can be set to interrupt the MicroVAX CPU or request further data from the DMA gate array (during DMA) when a specific point on the screen has been passed by screen refresh. Normally, the pause would be set, by the scroll service routine to allow the update process to continue after the top or bottom of the scroll region has been displayed; this allows a full frame time to fill the top or bottom edge of a region that is up or down scrolling, before the blank space would become visible. 3.3.4.4.1 Indexing - To allow updating from the MicroVAX CPU or DMA gate array into a region that is scrolling (or has scrolled) without requiring the MicroVAX CPU to change the coordinate values in its display list, there are index registers in the Address Processor chip that are added to the first source and destination coordinates to match the new position of data that has been moved in the memory by scrolling. There are six index registers: old X and Y, new X and Y, and pending X and Y. The old values are the indexes that apply to data that has not yet moved during the current frame; the new values are the indexes that apply to data that has already been moved; the pending values will become the new values at the start of the next frame. Between frames, the Address Processor chip transfers the value stored in the new register to the old register, and from the pending register to the new register, thus starting the new frame with the correct indexes. The index values apply to the region that is being updated. Ordinarily, if the update region is also being scrolled, the new and old indexes will differ by the scroll constant (X or Y) for the current frame (loaded in the previous frame); and if the update region is not being scrolled the new and old values are the same. The index values must be changed by the update process between updates to different regions. Also, if the update region is being scrolled, the scroll process must update the index values between frames, so that updates will stay locked to the scroll movement when they extend beyond the end of one frame time. Because both the update and scroll processes modify the index registers and the update process must use the most recent values provided by the scroll process, a very tight interlock must be maintained between these two processes. This interlock is maintained by the MicroVAX CPU, if the DMA driven update process has not changed the update region to one that is scrolling; because a frame may end between the time that the MicroVAX CPU index values in the data list for the DMA controller and the time that these values are loaded into the Address Processor chip. It is best not to send region changes via DMA. When the MicroVAX CPU changes the update region, the following interlock with the scroll process is recommended: - The MicroVAX CPU always executes the scroll process and the part of the update process that changes regions (no DMA controller). - 2. The update process must be interruptable by the scroll process when the update process is changing regions (note exception below), unless the latency caused by disabling interrupts during index loading is acceptable to the system. - During a region change, the update process loads a memory location that tells the scroll process what region is now being updated. - 4. The update process copies the correct index values for that region from a table maintained by the scroll process to the Address Processor chip registers. The index registers must be loaded in the order: pending, new and then old. If the instruction(s) that is used to move each index value to the Address Processor chip is interruptable, it is necessary to #### FUNCTIONAL DESCRIPTION disable interrupts (at least for the priority of the scroll service interrupt) while each index value is copied. - 5. If a new frame is started, the scroll process will be awakened by the scroll service interrupt from the Address Processor chip. The scroll process must run to completion before returning to the update process. The scroll process updates the index table entries for the region being SCROLLED, so that new values will be available to the update process. - 6. The scroll process should load all six index registers in the Address Processor chip with the new values for the region being UPDATED. If the update region is NOT the same as the scroll region, the registers need not be loaded. If the scroll process is certain that the index values in the Address Processor chip corresponded to the region being scrolled BEFORE the end of the frame that caused the scroll interrupt (perhaps there is only one region on the screen or only the scroll region has been updated since the last scroll), then only the pending index registers need to be loaded. - 7. Update processing may now continue. # 3.3.5 Multiplane Support The use of multiple Video Processor chips (data path chips) allows the simultaneous manipulation of data in many planes of memory. The Video Processor chips are controlled by and exchange data on the I/D bus as previously above. The registers for data transfers and the logic functions to be performed may be independently programmed for each Video Processor chip in a system. #### 3.3.5.1 Z Axis Addressing Z axis operations allow the exchange of data between the Address Processor and Video Processor chips on the I/D bus by using the 16 bits of a data word to transfer one bit to/from each of 16 planes. This can be used for both the exchange of data between the MicroVAX CPU and the bitmap, and the loading of appropriate Video Processor chip data registers. Each Video Processor chip can be programmed with a six bit plane address; the lower four bits specify the bit within an I/D bus data word to which a Video Processor chip will respond during a Z axis operation; and the upper two bits specify the Z block (should be set to 00 for the VCB02). No two planes may have the same address (this must be ensured by the MicroVAX CPU). During processor to bitmap (PTB) or bitmap to processor (BTP) data exchanges, data in a normal rectangle from the bitmap is transferred from/to the MicroVAX CPU memory by the DMA logic in the DMA gate array or the MicroVAX CPU. If Z mode transfers are requested, each word transferred will be the color of one pixel. Since a VCB02 Video Subsytem can have a maximum of 8 planes, the DMA gate array can be used to pack/ unpack data as it is transferred to/from the MicroVAX CPU memory. Compressing the data reduces the memory required to store and image and reduces the bus bandwidth required to transfer the data. A Z axis I/D bus cycle can be commanded directly, with an I/D command, to load either the source, foreground, background or scroll fill data registers in the Video Processor chips. The source register is one input to the logic units in the Video Processor chip, the foreground and background registers are selected on a bit-for-bit basis by the output of the logic unit and loading them with a Z axis command can program the Video Processor chips for the colors with which subsequent elements will be drawn. The fill registers in the Video Processor chips define the color that will be written into the new areas of scrolled regions. #### 3.3.6 Basic Address Calculation and Data Path Hardware The Address Processor and Video Processor chips contain bitmap manipulation hardware to execute the commands provided by the MicroVAX CPU. All manipulations are based on rasterops, which can select pixels from an area of the screen (a source) and combine them with pixels selected from another area (a destination). The Address Processor chip handles all word and bit addressing, clipping, and control. The Video Processor chip provides bit alignment, data exchange and logical combinations. There are three rasterop modes: normal, linear pattern, and fill. The contents of the Address Processor and Video Processor chip rasterop parameter registers are NOT modified or destroyed by any operation of the system. Only those registers whose values are to be changed need to be loaded between operations. Of course, the content of data registers may be changed by rasterops. #### 3.3.6.1 Address Processor Chip · Addressing Every rasterop has a destination and may have zero one or two sources; a zero source implies a constant source. The destination generator selects pixels to be modified and the source generators select pixels being combined with the destination. No curve algorithms are implemented because all of the useful ones require multiplications and there is no "best" algorithm for all applications; curves may be handled by passing a series of straight vectors to the Address Processor chip. The destination is a parallelogram and may be a different size or orientation than the first source rectangle with the data scaled or rotated to fit the destination. Rotation and scaling are used more for transforming picture elements such as characters and patterns than for transforming whole pictures. However, scaling can be used to #### FUNCTIONAL DESCRIPTION "zoom" an image to an area of the screen by a scaled copy from another area, possibly off screen. The parallelogram (as opposed to simple rectangle) form of the destination is largely a fallout of its implementation as two independent vectors, but is useful for forming italic characters and performing operations on screens with non-square pixels. Rotation and scaling may not be suitable during complement sequence of source/destination operations. The drawing operations is controlled by the Address Processor chip command register; three bits select one of the eight possible combinations or sources and a destination (sources: none, first, second and both, on, off; not all of these combinations are useful); the destination: source and destination addresses are always computed, but these three bits determine whether they are used. The effect of the source data is determined by the programming of the Video Processor chips. The origins for the first source and the destination areas may be offset by the addition of an X and a Y index. Index mode may be invoked for either the first source or the destination independently but the X and Y index values are the same for both. This mode allows the command data to remain unmodified when a region has been scrolled or is being scrolled (only the index values need to be updated), and/or the origin of a region may be 0,0 to the update process, regardless of its actual location in the bitmap. All address computations in the Address Processor chip use 14 bit, two's complement numbers for each of X and Y. Beyond the 14 bit limit, calculations will wrap from plus to minus in the normal fashion. The usable range of values for any of the DX or DY registers is +/- 12 bits (+/- 4095) because these values are multiplied by two in some internal calculations; however they are still specified as 14 bit, two's complement numbers. Thirteen bits of the X address (including specification of the pixel within a word) and 13 bits of the Y address are available at the output of the chip. A six deep FIFO is provided to store the computed addresses before they are used in memory cycles; this allows better use of available memory cycles during scrolling. If only one destination or source is required, six operations can be stored (and two more can usually be computed while these are being used, so that at least eight operations can be performed during each scan of scrolling, if the screen format allows); and, if source/destination operations are required, then three (or two for double source) operations can be stored. Figure 3-16 shows a diagram of the Address Processor chip data path. Figure 3-16 Address Processor Chip Data Path Diagram 3.3.6.1.1 Destination - Rotation - The destination is a parallelogram defined by two vectors and an origin (see Figure 3-17). Each vector is defined by two signed integers representing a horizontal delta (DX) and a vertical delta (DY) and both vectors start at the same origin. The area is scanned by addressing pixels along the path of one vector (the fast vector), starting from the destination origin (after indexing, if selected), until it is exhausted; and then, using the next pixel on the path of the other vector (the slow vector) as a new origin for another fast vector with its same DX and DY; fast vectors are scanned until all of the pixels on the slow vector have been addressed. Thus, parallelograms of any size or rotation can be scanned. Parallelograms can be used to scan rectangles on screens having non-square pixels. Figure 3-17 Example Destination Rasters The pixels on the path of the vectors are computed by Bresenham's Algorithm. Of the two components (DX and DY) of a fast or slow vector, one component is generally longer than the other and is called the "major axis"; the shorter component is called the "minor axis". According to Bresenham's Algorithm, the number of pixels selected along the path of a vector is equal to the length of the major axis. The origin and all points up to, but not including the last point on any vector (the point at "origin+delta") are selected. The last point is not included (the length of a vector would be one pixel too long) and an adjoining rasterop should not select the last point (its first point) a second time; because this would restore a pixel to its original state during complement writing. Because the destination can be indexed and is corrected for the effects of Y offset used in down scrolling, it can address any portion of the bitmap memory. 3.3.6.1.1.1 Holes and Duplications - Using this scanning technique for the destination, some fast and slow vector combinations will cause some pixels within the parallelogram to be addressed more than once. Some vector combinations will cause some pixels to be missed, and some vector combinations will cause both effects or neither effect within the parallelogram. The following combinations of fast and slow vectors will create duplications as shown in Figure 3-18. - 1. If both vectors point in one of the eight cardinal directions (0, 45, 90, etc.), then no duplications will occur unless both vectors are in the same or opposite direction. - 2. If one of the vectors points in one of the eight cardinal directions, then duplications will only occur, if the other vector is in one of the two adjacent octants or one of the two octants adjacent to the opposite cardinal direction. - 3. If neither vector points in a cardinal direction, then duplications will occur unless the vectors are in "perpendicular" octants, that is, octants separated by one intervening octant. Figure 3-18 Example of Fast and Slow Vectors That Duplicate Pixels Note that no RECTANGULAR area of any orientation (on a screen with square pixels) will cause duplications. Duplicated pixels will cause problems for complement operation, but one would expect some overlapping of data, when an image is compressed by any of the above conditions or by scaling down an image. These complement problems can be alleviated by doing any transformations in off screen memory without complement mode and then copying the result to the visible screen without a transformation. Two sets of control registers are provided in the Video Processor chip to support repeated two-step operations. Figure 3-19 shows combinations of fast and slow vectors that will create holes: - 1. If either of the vectors is parallel to the X or Y axes, then no holes can occur. - If neither of the vectors is parallel to the X or Y axes, then holes will only be generated, if one vector is in a quadrant adjacent to the quadrant containing the other vector. Figure 3-19 Example of Fast and Slow Vectors That Leave Holes Holes will be created in images, regardless of drawing mode, so these holes are filled with a modification to the scanning algorithm. Hole filling can be disabled for drawing single width vectors. - 3.3.6.1.1.2 Bresenham Error Computation Bresenham's Algorithm is implemented in the Address Processor chip by unconditionally incrementing the position register for the major axis, but only incrementing the position register for the minor axis according to an "error" computation. - At the start of a vector computation, the error register is initialized to minus the magnitude of the major axis and the X and Y position registers are set to the origin of the vector (the origin of the rasterop for the slow vector and the current slow vector position for the fast vector). - 2. For each iteration of the algorithm, a point is plotted at the current position. - 3. The position along the major axis is incremented. - Twice the magnitude of the minor axis is added to the error register. - 5. If the error register becomes non-negative, the position along the minor axis is incremented, and twice the magnitude of the major axis is subtracted from the error register. In addition, the initial value of the error register is offset by adding a programmable value to the built in initialization described above. For normal and linear pattern rasterops, the content of the Error l register is added to the destination slow vector error register and the Error 2 register is added to the destination fast vector error register. In fill mode, the Error l register is used the same way (controlling the A edge of the filled area), and the Error 2 register is added to the source l error register (controlling the B edge). Control of the error initialization allows the center line of the drawn vector to be shifted by half a pixel to either side of its normal position which is exactly through the centers of the pixels that are its end points. The slope of the line is unaffected by the error register initialization. These error registers are normally set to zero. 3.3.6.1.2 First Source · Scaling · The first source is an unrotated rectangle defined by a fast vector (a signed width; the fast vector of the source is always parallel to the X axis), a slow vector (a signed height; always parallel to the Y axis) and an origin. The magnitude of the first source fast vector is determined by the length (major axis) of the fast vector of the destination times a fast scale factor. The sign of the source fast vector is determined by the sign of the source DX register, a 14-bit register with the sign in the MSB (the remainder of the two's complement source DX is not significant in normal mode; it is used for linear pattern and fill modes. Similarly, the magnitude of the source slow vector is determined by the length of the destination slow vector times the slow scale factor; and the sign is determined by the sign of the source DY register. A fast or slow scale factor is a number less than one with an indication of up or down scaling, stored in a 14 bit register. MSB (bit 13) indicates up or down scaling and the magnitude is specified in the remaining 13 bits with the binary point preceding bit 12. On each computation of a vector (fast or slow), the Address Processor chip increments either the source or destination vector, adds the scale factor plus 0.000000000001B to an accumulator (initialized to zero) and, if bit 12 of the accumulator overflows, increments the other vector. If up scaling is specified, the source incremented only when the accumulator bit 12 overflows and the destination is always incremented, vice versa, if down scaling is specified. One pixel from the smaller vector may map to more than one pixel in the larger vector; this results in non-uniform sampling of the smaller vector during the scaling process. The scaling of fast and slow vectors is independent. Down scaling will cause pixels in the destination to be written multiple times. If complement writing is used, two step operations using off screen memory may be used to obtain correct results, as suggested above for duplicate destination pixels. To ensure expected operation of scaling for rational scale factors, it is necessary to round up any scale factor that has a remainder beyond the 13th bit from the binary point. This will ensure that the first pixel is not read one time too many. However, the Address Processor chip adds 0.000000000000001B to each scale factor. Therefore, a scale #### FUNCTIONAL DESCRIPTION Due to the 13 bits of precision available in the scale factor, inaccuracies can exist in large scale factors. This problem becomes significant when the number of significant bits in the scale factor is reduced (by having a large scale factor) to near or below the binary order of magnitude of the size of the source or destination in a scaled operation. The first source rectangle is scanned by starting at the origin (after indexing, if selected) and selecting pixels along the fast vector (X direction) until the destination fast vector is exhausted and the fast scale accumulator allows incrementing to the next destination pixel (the latter condition ensures correct down scaling for the last destination pixel). Then, if the slow scale accumulator allows, using the next pixel on the slow vector (Y direction) as a new origin for another fast vector of the same length; additional fast vectors are scanned until the destination slow vector and slow scale accumulator are exhausted. Because the first source can be indexed and is corrected for the effects of Y offset used in down scrolling, it can address any portion of the bitmap memory. The data read from the pixels addressed by the first source can be combined logically with data addressed by the second source and by the destination to form new destination pixels. The first source is most commonly used to move objects in the bitmap such as characters, or to move areas of the screen. 3.3.6.1.3 Fast Mode - When scaling or rotation of the fast vector is involved, computation and memory cycles occur one pixel at a time. However, if the fast vector of the destination is parallel to the X axis, the fast scale factor is one and the source and destination fast vectors are in the same direction (same sign) (the last condition is not necessary, if the first source is disabled), the hardware will operate on words (16 bits) to increase the speed of writing. This "fast mode" is invoked automatically under the appropriate conditions. Fast mode is disabled if any of linear pattern mode, fill in Y mode, or Z mode (used for processor/bitmap transfers) are enabled. These modes are described below. 3.3.6.1.4 Second Source - Tiles - The second source addresses are derived from the destination addresses by adding the destination address, before indexing, to an address (offset) stored in the Source 2 Origin registers; this allows a second image to be combined with the first source and destination (or just destination). No scaling or rotation is provided between the second source and the destination, although the first source may still have these properties, of course. This use of the second source can be thought of as copying a source area with clipping to the destination parallelogram. The second source is neither indexed, nor adjusted for the effects of Y Offset (used for down scrolling) and is, therefore, only useful for objects and patterns that are stored in off screen memory for the definition of off screen memory). This limitation is not serious because most second source data will be from off screen fonts. A special form of the second source will read tile patterns, if the source 2 height and width register is appropriately programmed. When tiling, the second source is used to texture other objects with a two dimensional rectangular pattern. An important property of such patterns is that they must mesh continuously when two independent patterned objects touch anywhere on the screen. The desired effect shown in Figure 3-20 is as if copies of the pattern rectangles were used to tile the whole screen and when a patterned object is written, these tiles are exposed to view throughout the interior of the object. The Address Processor chip achieves this effect by restricting the height and width of a pattern rectangle to integer powers of 2, adding just the LOW ORDER bits of the destination X and Y addresses (before indexing) to the X and Y components of the source 2 origin to create the source 2 X and Y addresses. The effect of the source 2 origin is more like a pointer to the origin of the tile than like an offset, when tiling is enabled. If the destination is indexed, the phase of the tiles will drift across the bitmap with changes in index value. This is a desired effect because it allows patterned objects to mesh properly, even if they are written at different times to a region that. is scrolling. Figure 3-20 Tiled Areas The height and width of a tile are independent of each other and range from 2^2 to 2^9. The tile width may never be set to less than the bus width (16 bits for the VCB02), but one can still have 4 and 8 wide tiles in 16 bit mode by repeating the tile elements within the tile cell. Tile origins must be on word boundaries in the memory. Like the second source, no scaling or rotating of tile patterns is provided because the Address Processor chip is not capable of the #### FUNCTIONAL DESCRIPTION calculations required to determine the starting phase of the resulting pattern. If scaling or non-power-of-two tile sizes are required, the pattern can be written more slowly by calculating the phase in the MicroVAX CPU and using linear patterns to write one scan of the patterned area at a time. 3.3.6.2 Video Processor Chip · Data Manipulation The Video Processor chip performs the actual manipulation of the memory data accessed by the Address Processor chip. This consists of aligning the source data bits with the destination location; communicating this data to its own logic unit and/or to those of other Video Processor chips and modifying the destination data with the logic unit. For Video Processor chip functions, see the rasterop data path diagram shown in Figure 3-21. 3.3.6.2.1 Barrel Shifter · Bit Alignment - During a bitmap memory read cycle, the barrel shifter accepts a 32 bit input and provides any contiguous 16 bit segment of this as an output. Both words of the input can be the current word being read, or one word can be the current word and the other a previous word held in one of two delay registers; fast mode operations require the latter ability to avoid excess reads to the source. One delay register is always associated with the first source and the other always with the second source. The output of the barrel shifter can be directed to the source or mask registers on the Video Processor chip and/or to the I/D bus bus for broadcast to the other Video Processor chips or the Address Processor chip. Only one Video Processor chip can drive the I/D interconnect during any source operation. The Address Processor chip provides the shift constants. For the first source, the shift constant is the difference between the source and destination pixel addresses (low 4, 3 or 2 bits of the X addresses) after indexing. If selected; for the second source, the shift constant is simply the difference between the low bits of the Source 2 X Origin and the X index, when selected for the destination. 3.3.6.2.2 Logic Unit And Source/Mask Registers - During a bitmap memory read-modify-write cycle, the logic unit combines the content of the source register (loaded with a constant or during a preceding source read cycle) with the present contents of the destination memory location. Any of the 16 possible bit-wise logical combinations may be requested. The output of the logic unit selects, on a pixel for pixel basis, a foreground or background color to form new destination data. The foreground and background registers are usually loaded explicitly by the MicroVAX CPU a Z axis load, or ordinary load. They are also loaded implicitly during a Z mode processor to bitmap transfer. When using a full resolution binary pattern (such as a text character or vector path) to write into a low resolution plane, it is necessary to spread adjacent pattern bits, so that all the bits of a low resolution "pixel" are either on or off. This is accomplished by resolution mode logic between the source register and the logic unit. This logic ORs the adjacent two or four bits in two and four bit modes, respectively. If any of the bits in the group is a "l", then all two or four bits of the group will be one at the input of the logic unit. In order that either the ones or the zeros in the source can be so spread, there is a programmable complementer between the source register and the resolution mode logic. If an operation requires moving data that has already been expanded to low resolution colors, the resolution mode logic can be disabled. Two mask registers are provided to control which bits in a destination word are to be modified. These registers are loaded in a similar fashion to the source register. Loading the mask 1 register also loads the mask 2 register with the same data, so that only one mask is effective. Mask 2 may be loaded independently when two masks are required. Either a mask value or its complement may be used. A special mask (called the edge mask) is provided by the Address Processor chip, via the I/D bus during read-modify-write cycles, to define the bit or segment of a word involved in the current rasterop cycle. All of these mask words are ANDed together, so that only bits selected by all three masks will be modified. Bits not addressed by the Address Processor chip as being in the range of a rasterop cannot be modified. When no mask is being used, mask I should be loaded with all ones and both complementers turned off to prevent masking of destination bits. If only the mask I is used, the complementers for both mask I and mask 2 should be set to the same state, or else all bits will be masked. 3.3.6.2.3 Control Store RAM and Function Registers - To provide flexibility in the sequencing and operations of rasterops, each Video Processor chip has two memories that define its functions. The control store RAM provides 6 locations, each of which define the data transfer function to be performed on each memory cycle of a rasterop. The functions are: - Where to send the read data from the barrel shifter (source, masks, I/D interconnect) - Where to send incoming I/D data (source, masks) - 3. Whether to capture the read data in one of the delay registers that precedes the barrel shifter. There are two banks of control store RAM, with three locations each. The first location of each bank controls data transfers during a source 1 read and specifies the control of the delay register for first source. The second location controls transfers during a source 2 read and specifies the control of the other delay register for the The third location controls the destination source. read-modify-write. The two banks allow easy switching between two functions without reprogramming the Video Processor chips (such as, when a function that must be performed with two rasterop steps is executed repeatedly). The Address Processor chip selects which bank to use (as specified by the MicroVAX CPU) and also defines the sequence of source and destination accesses (the sequence is: source 1, source 2 and destination, if enabled). The control store RAM is required because the Video Processor chips often do different things at the same time; for example: during text operations one Video Processor chip will be reading the font and transmitting it on the I/D bus, while the others will be receiving the font from the ${\mbox{I/D}}$ interconnect. The other memory controls the logic unit, source resolution logic and mask registers. This RAM has four locations of eight bits. Four bits select a logic function for the logic unit; two bits select normal or complement for each of the two masks and the last two bits select normal or complement for the source register and enable the source resolution mode logic. This RAM is also addressed by the Address Processor chip during rasterops, as specified by the MicroVAX CPU. These registers permit convenient transitions between tasks requiring different logic selections such as writing normal and reverse text. Four registers allows two orthogonal functions to be programmed. 3.3.6.3 Processor to Bitmap and Bitmap to Processor Transfers Processor to bitmap (PTB) and bitmap to processor transfers are similar to rasterops, except that either the source or destination is the MicroVAX CPU memory. Processor to bitmap transfers are referred to as PTBs; Bitmap to processor transfers are referred to as BTPs; and transfers of either type are referred to as PBTs. All data for a PBT is transferred through the six deep I/D data FIFO. There are two modes for PBTs, X mode and Z mode. The second source is not available; no scaling or rotation are available. In an X mode PBT, data from one plane is transferred to/from the MicroVAX CPU memory with 16 bits adjacent in X occupying one word followed by additional X words and then by additional scans. In a Z mode PBT, all the bits from one pixel location of are transferred to/from the MicroVAX CPU memory word, followed by additional pixel data along the fast vector and then by additional scans. Since a VCBO2 video subsystem can have a maximum of 8 planes, the DMA gate array can be used to pack/unpack data as it is transferred to/from the MicroVAX CPU memory. Compressing the data reduces the memory required to store and image and reduces the bus bandwidth required to transfer the data. A PBT transfers a continuous stream of data words to/from the MicroVAX CPU memory, either through the MicroVAX CPU itself or through the DMA logic in the DMA gate array. The data words are written/read by the hardware along the path of the destination/source fast vector, until exhausted and then along additional fast vectors starting at points along the path of the slow vector. Depending on the sophistication of the transferring device, these words can be all sequential in the MicroVAX CPU memory or each fast vector's data could be indexed to different points in the MicroVAX CPU memory. The latter action could be used to access a rectangle of data within a larger rectangle already formatted in MicroVAX CPU memory; such indexing is an externally supplied function, not a part of the Address Processor chip. In general, executing PBTs while scrolling is possible. X mode transfers are restricted from use in a region that is horizontally scrolling because the number of words transferred depends on the alignment of the rectangle being transferred to the memory words, which changes during horizontal scrolling. Z mode transfers have no restrictions during scrolling. PBTs in a scrolling region (or in any on screen location if some part of the screen is down scrolling) must operate continuously, adhering to a maximum time between words transferred. If the transfer becomes delayed, address calculations for scrolling will become invalid and data will transfer to/from the wrong screen location. There is no such problem for PBTs in off screen memory. It is recommended that the MicroVAX CPU compute exactly the number of words that will be transferred with a PBT command by the hardware. For a Z mode transfer, this will simply be the width times the height (in pixels) of the area being transferred. For an X mode transfer, the width calculation will be dependent on the width (in pixels), the bus width mode (16 bits for the VCBO2) and the indexed X origin address. If exact calculations are not possible, too much data is accommodated by harmless additional reads or writes to the FIFO. However, if too little data is transferred, the Address Processor chip will not be satisfied, requiring a cancel command (or more data) to continue operation. The ability to cancel a BTP operation is useful, if the MicroVAX CPU wishes to scan the bitmap data for a particular set of values, stopping when such is found. This is useful for a polygon flood operation. #### 3.3.6.4 Performance When no scrolling is in progress, destination-only and single source rasterops are compute bound in the Address Processor chip; so they operate at approximately 500K cycles/sec (compute cycle rate). Rasterops with two sources are memory cycle bound and operate at approximately 400K cycles/sec (depending on screen format). Cycles operate on either single pixels or words depending on whether the conditions for fast mode exist. Four compute cycles are required by the Address Processor chip to initialize each rasterop. If the whole screen is scrolling up or sideways, or any area is down scrolling, all rasterops are memory cycle bound. Destination-only rasterops operate at 300K-400K cycles/sec. Single source rasterops operate at approximately 200K cycles/sec and two source rasterops operate at approximately 150K cycles/sec. Partially scrolling screens (except down scrolling) will have update speeds intermediate between the non-scrolling and full scrolling speeds. There is one additional performance limitation that applies to updates to a region that is in motion (scrolling) or any region when down scrolling is in progress. Normally, when the screen refresh and scrolling process passes an area on the screen where updates are taking place (or source data is being read); the update process is temporarily halted while the refresh process passes to ensure that only old indexes are used below the refresh process and only new indexes are used above. This delay is necessary because the address computer cannot predict precisely when a computed address will be output to the memory. Normally this causes an unnoticeable decrease in update speed. However, if the update process is proceeding down the screen faster than the refresh process (this can happen if fewer than about 8 memory cycles, depending on screen format, are required to write or read all the data at each Y address, eg. vertical vectors), the update process will not be able to pass the refresh process. Thereby limiting progress to that of the refresh process. To eliminate this effect, it is recommended that tall, skinny rasterops, in regions whose height is a significant portion of the screen height, be written from bottom to top, rather than from top to bottom. When the new and old indexes are equal (or if they are disabled for both source and destination) and the Y offset is unchanged from that of the previous frame, this limitation does not apply. # 3.3.7 Application to Text Normal rasterops are used to write characters. The Address Processor chip contains no additional hardware to assist in the display of text. This section will describe common text procedures. # 3.3.7.1 Font Storage and Access Fonts are stored in an undisplayed portion of the bitmap. Ordinarily, a font need be stored only in one plane and is transmitted from that plane to itself and others when a character is written. This will result in writing characters in the bitmap that are monochromatic (all of one foreground color and one background color), as is normally desired. If multi-colored or gray-scale (for anti-aliasing) characters are desired, then the fonts can be stored across many planes. Characters may be stored anywhere in the bitmap (though normally in off screen memory). However, a character does occupy a two dimensional space in the memory, described by height, width and an X and Y origin. Thus, font storage in the memory must be allocated in a two dimensional fashion. Normally the MicroVAX CPU will keep a table for the characters in each font, where it can look up their origins and widths. While character origins may be on any pixel, faster operation will result, if characters are left justified in bitmap memory word cells (16 bit words), because only left shifting will be required, resulting in fewer source reads. # 3.3.7.2 Normal Text The display of unrotated, unscaled, fixed-pitch text could use the following example settings in the Address Processor and Video Processor chips. Only those settings actually changing between characters need to be updated following initialization: - 1. The update region is initialized with clipping limits, indexes and resolution mode. - The Video Processor chip control store RAMs are set for the proper data transfers during the rasterop. Normally the settings would enable broadcast of the character data from the plane containing the font to all other planes. - 3. The Video Processor chip logic functions, foreground, background and (possibly) source and mask registers are set for some of the desired character attributes - 4. The Address Processor chip mode register is initialized as: rasterop = normal, hole fill = off, source index = off, destination index = on, and pen down. - 5. The source l origin (X and Y) is set to the start of the first character to be transferred and the DX and DY sign bits (the rest is not significant) are set for the direction of source scanning. - 6. The destination origin (X and Y) is set to the desired screen location for the first character. The destination fast DX is set to the width and fast direction of the character cells and the fast DY is set to 0. The destination slow DX is set to 0 and the slow DY is set to the height and slow direction of the character cells. - 7. The fast and slow scale registers are set for scale factors of one. The following operations could now be performed to write each character in a string: - 1. The MicroVAX CPU would load the command register in the Address Processor chip to start a source l/destination rasterop with the desired logic unit function register and CSR bank selected. - 2. The Address Processor chip now copies the source to the destination using fast mode (because there is no rotation or scaling). - 3. After waiting for the Address Processor chip to finish the initialization phase of the rasterop, but while the character is still being written, the MicroVAX CPU can reload the source and destination origins and the command (if the same as the previous command), so that the next character will start immediately upon completion of the first. - 4. This process is repeated until the text is exhausted or an attribute change is required. The speed of text writing in this mode varies with the character size; but, for 9 wide by 15 high cells about 20K chars/sec can be written, if fully supported by the MicroVAX CPU. The speed will range from 15K to 25K chars/sec for other useful character sizes. Because a full page screen contains about 6000 characters, 300 msec will be required to fill the screen with characters. Adding about 100 msec to clear the screen, but considering that an average text page really only contains about 3000 characters, about 250 msec will be required for a "new page" of average text. Obviously, if the MicroVAX CPU is not able to process characters as fast as the hardware can take them, then the processor will determine the overall performance. # 3.3.7.3 Variable Pitch Text The MicroVAX CPU may use any technique it wishes to compute the character spacing. Obviously, fixed spacing is useful in many applications. Variable spacing can be used to justify a line of text by spreading any extra pixels over the line. One such computation is to find the "real number" (integer and fraction) of pixels for each character (or space). Then, for each character, spacing by the integer number of pixels, plus one more pixel, if the fractions have accumulated to more than one. This algorithm also allows any non-integer, but otherwise fixed pitch to be simulated (as may be useful for compatibility with dot-matrix printers when dumping the bitmap). A variable pitch font would be displayed with a different spacing for each character (read by the MicroVAX CPU from its width table). This may be accomplished by changing the destination origin and fast DX or just the destination origin alone. The former mode allows the font to be stored compactly, with the characters only occupying their width in The speed will be somewhat reduced because the MicroVAX the memory. CPU must wait for the previous rasterop to be completed before reloading the DX register and starting a new rasterop. The latter mode allows the same speed of operation as fixed pitch text, but the characters would probably need to be stored in cells the size of the largest character, so that portions of unwanted characters would not be copied to the screen. Some loss of speed will result from copying If overstriking of variable pitch characters is larger areas. performed, care should be taken to center smaller characters on top of the largest one, and to space to the next character by the largest space. If the character pitch of any character is larger than the destination fast DX setting, care must be taken to clear the area between characters that is not covered by the rasterops. This could be done by clearing the area of the text line before writing the character string. The performance of variable pitch text is similar to that described above for fixed pitch text. ## 3.3.7.4 Rotated and Scaled Text Display of rotated or scaled text is similar to normal text, except that the destination fast and slow vectors need not be parallel to the X and Y axes, respectively, and the scale factors need not be one. The execution of a rasterop defaults to one pixel at a time. For a rotated rectangular text cell, the fast DX and DY are chosen to be the closest integer pair to the desired angle and size (the magnification of images along the 45 degree axes may want to be accounted for). An example of scaled and rotated text is shown in Figure 3-22. This is NORMAL text. This is ITALIC text. This is 1.3 SCALING. # SCALED 2.4 italic Figure 3-22 Text Scaling and Rotation Examples To insure proper tracking of an arbitrary base line, real destination origin updates could be made for variable pitch text, but with an integer and fractional part for both X and Y that correspond to the correct base line angle. Use of real position updates will allow accurate simulation of any orientation or scale of a fixed pitch text string; the characters will be within one pixel of their intended position. The performance of text scaling cannot be expressed in terms of characters/second because of the varying number of pixels/character. These characters can be written at 500K pixels/sec and it will take 1.7 sec to fill a 840K pixel screen. #### 3.3.7.5 Character Attributes To set the character attributes, appropriate Address and Video Processor chip registers are loaded; all characters retain the current attributes until the settings are changed. However, only the registers for those attrubutes that actually change between strings need to be loaded; although, if a permanent display list is being maintained, it may be desirable to reset all the attributes periodically (maybe the beginning of each line). The following list describes the intended implementation of attributes: - 1. Reverse Reverse is a specific case of a more general class of attributes that modifies the logic function being performed on the destination data. Two bits are provided in the Address Processor chip command word to address one of the four logic unit function/mask complement registers in the Video Processor chips. These function registers could be set to the current definition of reverse and some other function (such as switching from replace mode to overstrike mode). - 2. Underline Underlines can be drawn as a vector of the desired thickness and linear pattern mode can be used, if a dashed or other patterned underline is desired. Another technique would be to overstrike each character with another character containing an underscore. - 3. Overstrike Overstrike may be accomplished by appropriate loading (or NOT loading) the destination origin register and the use of "OR" writing modes. If characters from variable pitch fonts are overstruck, care must be taken in positioning. - 4. Invisible The pen up bit in the Address Processor chip mode register may be used to disable writing, or the MicroVAX CPU can just skip any text strings that are invisible. If erasure of the invisible area is desired, this must be performed explicitly. - Intensity, Color and Blink These are Z axis parameters and are implemented through the color map. To enable writing the appropriate color in the bitmap planes or subplanes, a Z axis load of the Video Processor chip foreground and/or background registers would be accomplished with a Z axis I/D bus command. This will set all of the F/B bits in each plane or subplane to either 1s or 0s. Source patterns would then be loaded (via the Video Processor CSRs) into a Video Processor chip mask register to accomplish overstrike writing or into the source register to accomplish replace mode writing. Alternately, blink may be performed by periodic writing to the bitmap. - 6. Size, Italics and Rotation Any size, italic slope or rotation is available by setting the destination fast and - slow vectors, fast/slow scale factors, and providing appropriate destination origin update, as discussed above. - 7. Subscript and Superscript These character offsets are obtained by appropriate loading of the destination origin registers. In this way, subscripts and superscripts may be nested and angled baselines may be accounted. # 3.3.8 Application to Graphics and Additional Graphics Support Most graphics functions use the features introduced above. Linear patterns and polygon fill add some additional features. #### 3.3.8.1 Points and Vectors Solid color points and vectors are plotted as specific parallelograms, without any source operations. The source or foreground/background registers in the Video Processor chips are loaded with constants according to the desired color (usually with a Z axis I/D bus command). For a point, the location is loaded into the destination origin registers, the destination fast and slow vectors are loaded with a length of one (DX, DY or both equal to one) and the rasterop command is loaded. The point is drawn at the pixel addressed by the destination origin registers. A single pixel may be read from the bitmap by using a Z mode bitmap to processor transfer to address one pixel. This operation is permitted even while scrolling because the six deep data FIFO can always accommodate one to six words without being subject to MicroVAX CPU delays. While a PTBZ could be used to write one pixel, this is not possible while scrolling because the processor might not supply the data quickly enough after the PTBZ command. To avoid this problem, the single pixel rasterop described above is recommended. Because of the computational overhead required to initialize a rasterop or PBT, it is best to read or write many pixels at a time, if possible. Figure 3-23 shows examples for the various vector types described in the following paragraphs. a) Single Width Vectors b) Broad Width Vectors Figure 3-23 Vector Types For a single width vector, hole fill is disabled, the start point is loaded into the destination origin registers, the slow vector is set to a length of one, the fast vector is set to the DX and DY of the desired vector, and the rasterop command is loaded. The point initially addressed by the destination origin ([XO,YO]) is drawn, as are all of the points up to, but not including, the point [XO+DX,YO+DY]. Loading the DX and DY into the fast vector, rather than the slow vector, is preferred so that horizontal vectors can take advantage of fast mode (words written rather than single pixels). If a broad vector is desired, the set up would be the same except to turn hole fill on and load a slow vector with a length equal to the desired thickness and a direction perpendicular to the fast vector. Care must be taken at corners to prevent gaps (seen in the Figure 3-23) between vectors. Caps may be filled with appropriate adjustments to the origin and length of the vectors; or, a "vertex shape" may be copied to each vertex to cover the gaps. Simulation of the area traced by a rectangular brush may be accomplished by decomposing each vector segment into two parallelograms with one edge parallel to the side of the brush and the other edge parallel to the path. Curves must be formed from a string of straight vectors or points. # 3.3.8.2 Shading of Vectors - Linear and Tile Patterns Vectors may be shaded in one of two ways. Figure 3-24 shows examples of both types. - Inclusion of a first source set for linear pattern mode will provide linear patterns (like dashed lines, bullets or stripes) that align themselves with the direction of a vector. - 2. Inclusion of a second source set for tile mode will provide tile patterns that are "uncovered" under the path of the vector. Figure 3-24 Vector Shading Linear patterns are created by setting the Address Process chip mode register to linear pattern mode. This uncouples the source and destination initialization from each other. The source DX (fast) and DY (slow) registers define the size and scanning direction for the pattern (the magnitudes of the DX and DY registers ARE significant in this mode). The size of the source pattern can be any integer in either the fast or slow directions. The path of a patterned vector is defined by the destination slow vector and the width of the vector by the destination fast vector. Any fast or slow scale factor may be used in the normal manner. Linear patterns never operate in fast mode. Linear patterns operate in the following manner: - 1. As the destination scans its fast vector, the source will provide pixels from its fast vector (as determined by the fast scaling). - 2. If the source fast vector expires before the destination fast vector, the source will reinitialize its fast vector at the same origin (slow vector point) last used. Thus, the source will scan its fast vector as many times as required to cover the length of the destination fast vector. - 3. When the destination fast vector expires, the source and destination slow vectors will be incremented (as determined by the slow scaling). - 4. Both the source and destination fast vectors will be initialized to the resulting new slow points. Fast scaling is also initialized. New fast vectors are scanned. - 5. If the source slow vector expires before the destination slow vector, the source slow vector will be reset to the source l origin and the whole source will repeat again. - 6. When the destination slow vector expires, a new destination vector can be initialized without disturbing the state of the source slow vector or the slow scale factor. However, if desired, loading a new source origin will cause the source and slow scale to be initialized, also. The result is that a two dimensional pattern is scanned by the source and transferred to the position, direction and scale of the destination. If it is desired to scale the pattern, so that its size along a diagonal is the same as along an axis, the scale registers will need to be loaded along with each new destination fast and slow vector. Appropriate linear patterns for texturing vectors normally are coarse grained to reduce the effect of sampling errors inherent in rotation and scaling. Linear patterns require the fast vector to represent the discontinuous direction (narrow direction) of the destination and the slow vector to represent the continuous direction (long direction). This prevents the phase of the pattern form being disturbed when a new vector is commanded. The fast vector can be used to represent the long direction, but this will require the phase of the linear pattern to be reset between each vector command. If it is desired to adjust the starting phase of the linear pattern (as is required if linear patterns are used to simulate filling an area with a tile whose width or height are NOT a power of 2), the source pattern can be written into the bitmap as a two-by-two set of four adjoining copies of the pattern. The phase can then be set by programming the source lorigin to a point in the interior of one of the blocks (so that the source fast and slow vectors will overflow into the adjoining blocks). If the slow scale phase must also be controlled, the source and destination can be programmed to start the vector with pen up set in the mode register. Once the source origin and scale have reached the desired values, a new destination vector can begin with pen down. To create tile patterned vectors, source 2 and the destination are enabled. The area under the destination will be tiled as previously described. Appropriate tile patterns for texturing vectors normally will be fine grained and approximately isotropic (no stripes). When patterned broad vectors are drawn, the same consideration must be given to gaps between vectors as discussed above for solid vectors (Figure 3-24 contains gaps). In addition, the phase of linear patterns may need to be adjusted. No additional consideration is required for tiled vectors. # 3.3.8.3 Fill Mode - Polygons In general, a fill operation places a solid or textured object on the screen whose shape is described mathematically, such as by a list of vertices. This is contrasted to a flood operation. To assist in the filling of polygons, additional modes are available to appropriately configure the hardware. When polygons are being filled, the first source hardware is used internally to define one edge of a polygon. Therefore, polygons may only be filled with solid colors (destination only) or with the second source. Through the use of the second source with fill mode, the interior of a polygon may be filled with a tile pattern or if tiling is disabled, a whole object from off screen can be moved, with "clipping" to the polygon outline (in addition to the normal rectangular region clipping). The basic area fill is computed by defining two arbitrary vectors and writing the space between them by scanning fast, parallel to either the X or Y axis and slow along the opposite axis. The direction of fast scanning (the fill axis) is selectable by mode, but the X axis is preferred because fast mode (word access) is used. Each fast scan includes all points on both of the edge vectors. Scanning is always from one vector (A) to the other vector (B), even if the vectors cross (in such a case the fast scanning direction will reverse at the crossing and continue to fill the space between). The last fast scan between the last point on any vector and a point on the other vector is not plotted (except under the conditions that cause doubling. This is similar to a normal rasterop, for which the first but not the last point is plotted. To fill a whole polygon, it must be subdivided into pieces that can be directly filled by the VCB02 video subsystem hardware. Such a piece will be intersected by every line that is parallel to the fill axis exactly twice (except at edge intersections or when an edge is parallel to the fill axis). If the border of a piece is traversed from the top most (left most) vertex (for an X (Y) fill axis), there will be only one reversal of direction along the Y (X) axis. Figure 3-25 shows an example of a polygon meeting this requirement for an X fill axis. Assume a polygon that meets the preceding conditions for an X fill axis. To fill such a polygon (see Figure 3-25): - The Address Processor chip is set to fill mode, with X fill, not baseline mode, source 2 parameters as required (if used) and Video Processor drawing modes as required. - One side of the polygon (from the upper most point "TOP" to the lower most point "BOTTOM") is designated the A side and the other side is designated the B side. It does not matter which side is designated A or B. - 3. The vector strings that represent each side of the polygon are expressed as DX and DY pairs to the next point (just like ordinary vectors), see the AO example. After an initial origin load, all vectors are relative. - 4. The vertices from both sides are sorted as a single group by increasing the Y coordinate. If a vertex on each side has the same Y value (always the case at the top and bottom), the A and B vertices are sorted as a pair. In the example: A0/B0, A1, B1, A2, A3/B2, A4, and A5/B3 (A3, A4 and B2 all have the same Y coordinate). - 5. The DX,DY pairs are sorted as single vectors or vector pairs according to the order determined by sorting the vertices (actually the vertex information is used only to determine this vector order). In the example: A0(DX:DY)/B0(DX:DY), A1(DX:DY),...., B2(DX:DY), and A4(DX:DY) (no vectors start from A5 or B3, but a final A(0:1)/B(0:1) vector pair may be added at the point A5/B3 to complete the last scan of the polygon). - 5. The destination origin registers are loaded with the start point (A0), and the source 1 X origin is loaded with the X component of the origin (B0, actually B0 need not be the same point as AO, assuming they both have the same Y coordinate, the source 1 Y origin register is ignored for X fill, the roles of the two source 1 origin registers are reversed for Y fill). - 7. The first vector pair is loaded into the destination slow DX and DY registers (A vector) and the source DX and DY registers (B vector, the magnitudes of the source DX and DY ARE significant in fill mode). - 8. The Address Processor chip command register is then loaded with a rasterop command, including a source 2, if needed. Source 1 should never be enabled in fill mode. - 9. Then the space between the two vectors is filled by the hardware parallel to the X axis as the vectors are advanced synchronously in Y. - 10. When the Address Processor chip signals that it needs more data (rasterop complete flag), the MicroVAX CPU loads the next vector or vector pair in the list into the appropriate vector registers (A to destination slow and B to source 1). Then loads the Address Processor chip command register again, continuing with the previous step until all required vectors are plotted. - 11. The process is terminated when the MicroVAX CPU loads new data into the destination origin registers (which will cause the positions to be reinitialized) or switches the Address Processor chip out of fill mode. Figure 3-25 Polygon Fill Example 3.3.8.3.1 Fill with Complement Mode - The above procedure will plot all of the points that would have been plotted by the edge vectors, plus all the points in between. However, some of the points will be plotted more than once, creating potential problems for complement mode operations (any operation that XORs or uses the complement of the destination). Fortunately, some extra work by the MicroVAX CPU can fix this problem (for most of the important cases) by forcing all pixels that would be written an even number of times to be written an odd number of times (ordinarily, writing doubled pixels a third time). Doubling will occur each time an A or B vector is loaded, AND the previous vector or the vector on the other side (whether or not it has also expired) was (is): - 1. "Inbound" (approaching the other vector) - 2. Has its major axis parallel to the fill axis 3. Satisfies the following equation which identifies the places along the minor axis of a vector where two or more points are addressed: ``` ( [(2dist + 1)maj - 1] modulo 2min ) + 2min < 2maj ``` #### where: dist = magnitude of the distance, perpendicular to the fill axis, from the start of a vector to the current drawing point (for X fill, the sum of the DYs from the start of the fill on the side that has expired, minus the sum of the DYs to the start of the vector being tested). maj = magnitude of the major axis (larger of DX or DY) for the vector being tested. min = magnitude of the minor axis (smaller of DX or DY) for the vector being tested. According to the above conditions, any vector that expires and has an inbound slope greater than or equal to 2:1 (major:minor) with its major axis parallel to the fill direction will always cause doubling and any other expiring vector will never cause doubling. This can be seen by substituting major/2 for the minor axis in the above equation. For a vector that is not expiring, doubling will always occur for slopes greater than or equal to 2:1, doubling will never occur for slopes less than or equal to 1:1, but the equation must be evaluated for slopes between 2:1 and 1:1. If doubling occurs, it can be corrected (tripled) by preceding the next vector with a unit length vector inbound and another unit length vector outbound; if both the A and B sides have expired, then this fix is applied to both vectors. This extra procedure for complement mode will correct all doubled pixels, except in two circumstances: if the two edges cross, some uncorrectable doubling may occur on one scan (this operation is normally avoided, except in baseline mode). If an inbound vector of the stated slope is followed by an outbound vector that also meets the slope condition, the pixels that are common to the vectors but which lie outboard of the vertex will be doubled. If necessary, these conditions can be computed by the CPU corrected later by tripling. As an example of correction of doubling of pixels (see Figure 3-25), assume that the vectors Al (from Al to A2) and A3 (from A3 to A4) are the only two inbound vectors with a slope flatter than 2:1 and that B2 (from B2 to B3) is the only vector that is inbound with a slope between 2:1 and 1:1 but there are no expirations of the A side during its length. If the doubling is to be corrected, the following complete vector list would be used: A0(DX:DY)/B0(DX:DY), A1(DX:DY), #### FUNCTIONAL DESCRIPTION B(-1:0), B(1:0), B1(DX:DY), A(1:0), A(-1:0), A2(DX:DY), A3(DX:DY)/B2(DX:DY), A(1:0), A(-1:0), A4(DX:DY), A(0:1)/B(0:1). The last vector pair is used to plot the last vertex of the polygon, if desired. If polygons are butted together, so that one shares some edges with a previous polygon; the adjoining edges will be written twice. But because all of the pixels on the edge vector have been written exactly twice, it is possible to ensure an odd number of writes to the edge pixels by writing just the edge vectors again (in the same direction as when filling), including the last point on the last vector. 3.3.8.3.2 Baseline Fill - A simplified fill mode is provided that fills from a single vector to either a horizontal (for Y fill) or vertical (for X fill) baseline. The position of the base line is programmed by loading the source 1 Y origin (for Y fill) or the X origin (for X fill). In addition, the source 1 DY must be zero for Y fill and the DX must be zero for X fill. In either case the other delta must be non-zero. Only a single vector path is required and the path is allowed to reverse the direction of its component that is parallel to the baseline (not allowed with two-line mode). However, the space between two lines that converge on a point from the same quadrant is difficult to fill in this mode (some products have provided a fill to a point function for this case, but this creates more problems for complement mode.). With baseline mode, the same problems and procedures apply when using complement operations. In addition, if the vector path crosses the baseline and then reverses direction (parallel to the baseline, such as when filling a circle). The baseline will be written twice, as if two polygons had been butted together and the baseline will need to be drawn again as a single vector to correct for the even number of writes. ## 3.3.8.4 Polygon Flood A flood operation colors or textures the interior of an area whose outline is previously described in the bitmap. This is contrasted to a fill operation. No explicit support for a polygon flood function is provided by the Address Processor chip. This function requires the PATH of writing in the bitmap to be conditional on the previous contents of the bitmap. In the hardware, the path of writing is controlled by the Address Processor chip, but only the Video Processor chips see the memory data. Flood can be implemented using the following commands: - The processor/bitmap transfer facility is used to read a scan of the bitmap in Z mode or one plane of the bitmap in X mode. - Each returned pixel value is checked for a match with a set of boundary colors and a count is maintained of the pixels received. - 3. When a match is found, the BTP transfer is terminated by loading a cancel command to the Address Processor chip. - 4. A vector is commanded to write the desired pixels on the scan with a color or pattern in the normal fashion. - 5. The flood algorithm would then step to a point on the next scan or continue at a previous seed point, in the normal manner. The speed of this operation is determined by the BTP scanning time plus the overhead time of the MicroVAX CPU (which could be significant if it takes more than 2 usec for each comparison or if the flooded area is narrow). The drawing time is generally not significant compared to scanning and decision making. Using this technique, an empty full page screen (1024 x 864) has been flooded in less than 2 seconds. ## 3.3.8.5 Objects Ordinary rasterops can be used to move objects or windows on the screen. In a multiplane environment, rectangles can be copied by moving the pixels in all planes, in parallel, to new [X,Y] locations in the same planes. This is referred to as a raster move because all of a rectangle is copied. The source 1 is indexed and offset which can be achieved from either on or off screen. If a source 2 is used it must be from off screen. To move just an object which is to alter only the destination pixels within the boundary of the object, it is necessary for the hardware to distinguish between object and background. This can be done by defining the foreground of the object in one plane. The area of this plane within the rasterop rectangle is then transmitted to the other planes during the rasterop for use as a mask that prevents the alteration of background pixels. This operation is referred to as an object move. Alternatively, the second source can be used to copy an object from off screen, with "clipping" to the destination shape. The previous two paragraphs described the movement of color objects (objects defined in more than one plane). It is also possible to move objects (ones specified by just a foreground shape), assigning a foreground and background color to them at the time that they are moved. This type of operation has been previously described in the discussion on writing text. ## 3.4 ADDRESS AND VIDEO PROCESSOR CHIP REGISTERS AND COMMANDS This section defines the interface to the Address Processor and Video Processor chips in detail. There are basically two types of commands to the hardware: direct commands to the Address Processor chip and I/D bus commands that are passed through the Address Processor chip to the Video Processor chips and chip select registers. #### 3.4.1 Address Processor Chip Registers and Commands All Address Processor chip commands are the result of Address Processor chip register loads by the MicroVAX CPU or the VCB02's DMA logic (in the DMA gate array). Before presenting the Address Processor chip commands and interface, it is appropriate to define the Address Processor chip registers. ## 3.4.1.1 Address Processor Chip Registers The Address Processor chip contains many loadable registers that hold parameters for rasterops, set system timing, and control the operation of the chip. Unless otherwise specified, registers are write only and numerical registers contain 14 significant bits (including sign, the two MSBs of a word are ignored, except for test purposes) in two's complement representation. The loading of some registers causes specific additional actions to be taken by the Address Processor chip. These actions will be described with the corresponding register. There are different types of coordinates implied by the various position registers. "World coordinates" refers to the coordinate system of the image as viewed by the MicroVAX CPU before index values (if enabled) are added to translate the image to "device coordinates". Device coordinates describe a physical position on the screen; [0,0] is the upper left corner with increasing X to the right and increasing Y downward. "Memory coordinates" are obtained internally to account for down scrolling by adding the Y offset to all addresses to the on screen part of the memory (any memory location accessed by a major read cycle for screen refresh), delineated by the X limit and Y limit registers. Because registers may be loaded by the DMA logic in the DMA gate array through the register address counter, thereby loading several sequential registers; the register addresses are assigned to allow all common combinations of registers to be adjacent. This allows loading to be accomplished with a minimum of address register loads in the DMA data list (DMA display list). The register addresses (or the address of the first of a group of registers), in HEX and enclosed in [], precede the register descriptions in the following list. Where specified, bit assignments (or the LSB of a group of bits) are enclosed in <>. ## 3.4.1.1.1 Interface Control Registers - - [0] ADDRESS COUNTER (ADCT) This address controls a counter that provides indirect access to the Address Processor chip registers for use during DMA. If the MSB of the data word is a 0 when this register is written, the data is placed in the register pointed to by the contents of the counter and then the counter is incremented. MSB of the data is I when this register is written, the low six bits of the data replaces the original contents of the address counter. The only exception is that, if the address counter is pointing to either the I/D Data register (IDD) or the I/D Scroll Data register (IDS), the MSB of the data is ignored by the address decoding and all 16 bits are loaded into the appropriate I/D register. When a read is directed to the address counter, the register pointed to by the address counter is accessed and the counter is always subsequently incremented (note that only a few registers are actually readable). The counter is cleared when the -INIT pin is asserted. - [1] REQUEST ENABLE (REQ) - [2] INTERRUPT ENABLE (INT) The unencoded bits of these two registers allow any selection of the corresponding 13 bits of the status register to be enabled for asserting the request or interrupt output pins. A one in either of these registers enables a status bit. If a bit in the status register is a one and that bit is enabled by one of the enable registers, the output pin corresponding to the enable register will be asserted. Both enable registers are cleared by assertion of the -INIT pin on the Address Processor chip. In the VCB02 video subsystem, the request register and pin control the data requests to the DMA gate array. In general, only one of these request conditions would be set at a time because the DMA process will be waiting for one specific event before passing the next data word. The interrupt pin and register are provided to control interrupt requests to the interrupt logic in the DMA gate array. During the interrupt service routine the MicroVAX CPU will need to read the status register to determine the interrupting condition(s), if more than one interrupt is enabled. [3] STATUS (STAT) - The status register provides various indications of the internal progress of the Address Processor chip. The conditions that set and clear each bit are identified in the following list. This register is readable only (except as noted below). - Pause Complete Set when the screen refresh process reaches the Y address (in device coordinates) that the pause register was set to when the current frame began. Cleared by writing a word to the status register with a zero at this bit position; unaffected by a one at this bit position or by values of other. bits, This status bit will queue two pause events. Thus, if in one frame the pause register was set near the bottom of the screen and in the next frame the pause register was set near the top of the screen, both pause events will be separately detected, even if the second event occurs before the first event. However, this means that, if the pause register is set within the active screen and the pause status bit has not been cleared within the previous two frames, two clears will be required to make this status bit stay low. The pause status bit can be prevented from being set by programming the pause register to a value greater than that of the end vertical period event in the YCT- registers. The -INIT pin will clear any queued pause event, but one explicit clear by writing to the status register is still required to set the pause status bit low. - <1> Scroll Service (Frame Sync) Set at the start of a frame, when new scroll parameters may be loaded. Cleared by writing a word to the status register with a zero at this bit position; unaffected by a one at this bit position or by values of other bits. This bit differs from the vertical blank bit in that the latter is set at the beginning of the vertical blank interval. - Rasterop Initialization Complete Set when initialization of a rasterop, processor to bitmap transfer (PTB), or bitmap to processor (BTP) tansfer is complete, indicating that it is safe to load the source l and destination origin registers, or to load a new (but not different) rasterop (but not PTP or BTP) command. Cleared when any rasterop, PTB or BTP command is loaded. Set by a cancel command or the -INIT pin. - Rasterop Complete Set when rasterop, PTB or BTP address calculations are complete and no further command is pending, indicating that it is safe to load any rasterop parameters such as: origins, DX/DY pairs, source 2 parameters, scale factors, and the mode register, or to load a new (but not different) rasterop (but not PTB or BTP) command. Cleared when any rasterop, PTB or BTP command is loaded. Set by a cancel command or the -INIT pin. - <4> Address Output Complete Set when all addresses calculated by all pending rasterops, PTBs or BTPs have been used, indicating that it is safe to load ANY update parameters including: clipping boundaries, indexes, I/D data or different commands. In addition, during BTP (bitmap to processor) commands, this status bit will not go high until the IDD FIFO is also empty, indicating that all data transferred by the BTP has been picked up by the MicroVAX CPU or DMA controller (DMA gate array). Cleared when any rasterop, PTB or BTP command is loaded. Set by a cancel command or the -INIT pin. - (5) I/D Data Receive Ready This bit is set if the I/D data FIFO has an data word available for reading. It is cleared, if the FIFO becomes empty. When a rasterop, PTP, BTP or cancel command is loaded to the command register or bus; initialization occurs, the FIFO is initialized and this bit will be cleared. Note that this bit will be set any time that data is in the FIFO, such as during PTB, BTP, or I/D command sequences and should be masked when not used. - <6> I/D Data Transmit Ready This bit has four interpretations, depending on the commands being executed by the Address Processor chip: - a. When a rasterop, PTB or BTP command is loaded to the command register, the FIFO is initialized and this bit will be set. During a rasterop or PTB command, this bit is set if the I/D data FIFO (6 words long) can accept an additional data word. It is cleared if the FIFO becomes full. While this bit responds during rasterop commands, I/D data is not used in these commands and any data loaded will remain in the FIFO during the command. - b. During an I/D command (after an I/D command has been loaded and until some other command is loaded), this bit is set if a new data word may be loaded to the I/D data register and it is cleared when an I/D command is loaded to the command register. This bit should also be checked before loading another command following an I/D command. However, if at least three major cycles (one major cycle plus a sync cycle, about 3 usec) passes before the new command is loaded, this status bit need not be checked. - c. When a cancel command is loaded, this bit is momentarily set low. When execution of the cancel command is complete, this bit will be set high to indicate that the IDD FIFO is cless and a new command may be loaded. This bit should be checked to indicate completion of a cancel command. This is not required if at least four major cycles are guaranteed to pass before the next command is loaded. - d. If the I/D data register is loaded when a rasterop, PTB or BTP is not in progress (see IDD register) or the -INIT pin is asserted, the FIFO is initialized and this bit will be set. - <7> I/D Scroll Data Ready This bit is set if a new data word may be loaded to the I/D scroll data register and it is cleared when an I/D command is loaded to the I/D scroll command register. - A portion of at least one rasterop clipped at the top boundary. - <9> A portion of at least one rasterop clipped at the bottom boundary. - <A> A portion of at least one rasterop clipped at the left boundary. - A portion of at least one rasterop clipped at the right boundary. - <C> A portion of at least one rasterop was successfully drawn (did not clip at any boundary). The preceding five clipping bits accumulate clipping activity by having clipping results for each destination write cycle ORed with their previous contents. These bits are asserted high. The last bit may be used to aid a picking algorithm by indicating that a rasterop was at least partly inside the clipping rectangle. Clipping information for a rasterop will be complete after the address complete status bit is asserted. Reading the clipping status bits during a rasterop can yield undefined results. These five bits are selectively cleared by a write to the status register with a zero in each corresponding clipping bit position to be cleared and a one in positions to be unaltered. Zeros or ones in other bit positions will have no effect on these status bits. Clearing of the clipping status bits during a rasterop will give unpredictable results. These bits should only be cleared after the address complete status bit is asserted. Vertical Blank - Set at the start of the vertical blank interval. Cleared by writing a word to the status register with a zero at this bit position, unaffected by a one at this bit position or by values of other bits. This bit differs from the scroll service bit in that the latter is set near the end of the vertical blank interval. - [4] RESERVED Test function. - [5] SPARE - [6] RESERVED This register address is used only for a test function because it precedes the IDD register and would force a load to the IDD, if this address were accessed through the address counter. - [7] I/D DATA (IDD) When a rasterop, PTB, BTP or cancel command is loaded into the command register or the -INIT pin is asserted, the six deep FIFO at this register address is cleared. During PTP or BTP commands, the FIFO is either read or written (depending on the direction of the transfer command) to transfer data between the processor and the bitmap. The I/D interconnect data FIFO is 16 bits wide. When screen data is passed through the I/D data FIFO (in X mode), the LSB corresponds to the left most pixel in the word. Whenever a load to the I/D data register occurs AND the address output complete status bit is set (a PTB, BTP or rasterop command is NOT in progress), the FIFO is cleared as the data word is loaded; so that only the loaded word remains in the FIFO (only the last word loaded to this register is available for transmission on a subsequent I/D command). Reading this register under the same conditions does not clear the FIFO. Note that the address output complete status bit will continue to indicate that a BTP operation is not complete until all data has been removed from the FIFO. - [8] COMMAND (CMD) This address accesses the same command register described following the mode register. The duplicate address is provided to ease access through the address counter because the command register is frequently written following writes to the I/D data or mode registers. - [9] MODE (MDE) Sets various rasterop execution modes as described by the following bits: - <0> 00=Normal Mode The first source is coupled to the destination so that the source size is determined from the scaled destination size. 01=Reserved (1) 10=Linear Pattern Mode - The first source is uncoupled from the destination so that the source pattern size is determined by the source DX and DY registers. 11=Fill Mode - The destination slow generator computes the "A" edge vector, the first source generator computes the "B" edge vector and the space between is filled. - The next two bits are ignored, except when fill mode is selected in the preceding two bits. - <2> 0=The fill area is scanned parallel to the X axis ("X fill"). l=The fill area is scanned parallel to the Y axis ("Y fill"). - <3> 0=Normal, two edge fill. l=Baseline fill, the "B" edge generator is locked to form a vertical or horizontal baseline for fill (depending on the scan direction selected with the preceding bit). - <4> 0=Hole fill disabled. This is the normal setting for single pixel wide destinations. l=Hole fill enabled. This is the normal setting for all other destinations. - <5> 0=First source indexing disabled. l=First source indexing enabled. - <6> 0=Destination indexing disabled. l=Destination indexing enabled. - <7> 0=Pen up, writing disabled. l=Pen down, writing enabled. - [A] COMMAND (CMD) Address Processor chip command register. The command register is used for all commands by the update process. Some combinations of bits will result in undefined operation. When performing a series of operations (e.g.: text or vector strings), an identical command may be reloaded after the rasterop initialization complete status bit is set, if only the source l and destination origins have been changed or after the rasterop complete bit is set; if other rasterop parameters have been changed. To load a new command, the address output complete status bit must be set. - <0> 8 Bits. I/D Command. - 2 bits. Function select. 00=Cancel all active and pending commands (except ICS). 01=I/D command. 10=Rasterop command. 11=Processor to Bitmap or Bitmap to Processor transfer command. - <A> Destination Enable. - <B>> First Source Enable. - <C> Second Source Enable. #### FUNCTIONAL DESCRIPTION - <D> Test Function, normally 0. - <E> Test Function, normally 0. - <F> Reserved, normally 0. - 3.4.1.1.2 Scroll Registers During active scrolling, scroll registers must be loaded by the scroll process before the START of vertical blank. The Address Processor chip performs various functions during vertical blank, depending on the type of scroll activity pending for the next frame. - [B] RESERVED This register address is used only for a test function because it precedes the IDS register and would force a load to the IDS, if this address were accessed through the address counter. - [C] I/D SCROLL DATA (IDS) This contains data to be transmitted to the I/D interconnect, during scroll process I/D commands. The last word loaded to this register will be transmitted on the next I/D scroll command. This register is 16 bits wide. - [D] I/D SCROLL COMMAND (ICS) I/D command register for the scroll process. Commands directed through this register will be transmitted on the I/D interconnect without interference with any update activity that may be in progress, assuming that only scroll related registers in the Video Processor chips are addressed. - [E] SCROLL X MIN (PXMN) Left boundary of scroll region. The left most pixel in the scroll region. - [F] SCROLL X MAX (PXMX) Right boundary of scroll region. The first pixel outside the right side of the scroll region. The two LSBs of the X boundaries are ignored, the X boundaries may only be specified to a multiple of four pixels. - [10] SCROLL Y MIN (PYMN) Top boundary of scroll region. The upper most pixel in the scroll region. - [11] SCROLL Y MAX (PYMX) Bottom boundary of scroll region. The first pixel outside the bottom of the scroll region. - Scroll boundaries are in device coordinates so that they are unaffected by the index values. That is, they stand still on the screen. These registers are double buffered so that the values loaded become active at the start of the following frame. - [12] PAUSE (PSE) Y device coordinate specifying the scan that, when being displayed, will cause the pause status bit to be set or a second pause event to be queued (see description #### FUNCTIONAL DESCRIPTION of the pause complete status bit above). This register is double buffered so that comparison with the new value loaded begins at the start of the following frame and continues throughout that frame. Only the low 11 bits of this register are significant. - [13] Y OFFSET (PYOF) Offset added to device coordinates to get memory coordinates. Decremented by the MicroVAX CPU during down scroll; ranges between 0 and the height of the displayed portion of the bitmap memory (the same value minus one; see below). The offset value loaded to this register should be that which will be in effect when the following frame is complete, stored in the Y limit register, due to the multiple buffering of this register. - [14] Y SCROLL CONSTANT (PYSC) Specifies the vertical distance to be scrolled in one frame time. Loading of this register will cause the region selected by the scroll boundaries to be scrolled (by the vertical distance loaded to this register OR the horizontal distance loaded to the scroll constant registers in the Video Processor chips) during the following frame. If no value is loaded during a frame, no scrolling will occur in the next frame. - <0> 12 Bits. The vertical magnitude (unsigned distance) of the scroll. If a non-zero X scroll constant is specified in the Video Processor chips, the Y scroll constant must be zero. - <C> 0=Up, left or right scrolling. l=Down scrolling. If down scrolling is specified, the scroll direction bits in the Video Processor chips should also be set to down and left. - <D> 0=Normal scrolling. The scroll direction bits in the Video Processor chips should be set according to the desired scroll direction. 1=Erase mode. The entire scroll region will be cleared to the fill color regardless of the settings of the scroll constants. Up scrolling must be specified in both the Address Processor and Video Processor chips. ## 3.4.1.1.3 Update Control Registers - - [15] PENDING X INDEX (PXI) - [16] PENDING Y INDEX (PYI) - [17] NEW X INDEX (NXI) - [18] NEW Y INDEX (NYI) - [19] OLD X INDEX (OXI) - [lA] OLD Y INDEX (OYI) Index values are added to the rasterop addresses to adjust them for scrolling and the location of regions on the display. The pending values are those which will be automatically loaded into the new registers at the start of the next frame. The content of these registers is not destroyed by this load so that, if no scrolling will take place in the next frame, these registers need not be reloaded. The new values are the indexes that apply to data that has already been moved during the current frame. The contents of these registers will be loaded into the old registers at the start of the next frame, before the pending values are loaded into the new registers. The old values are the indexes that apply to data that has not yet moved. The index values apply to the region that is being updated, because they only affect the update addresses. These registers are normally loaded by the scroll process, if the scrolling region is also the current update region and are also loaded by the update process whenever the update region changes. All of these registers may be loaded directly, as is required when changing from one update region to another. They must always be loaded in the order: pending, new and then old. - [1B] CLIP X MIN (CXMN) Left clipping boundary. The left most pixel in the update region. - [1C] CLIP X MAX (CXMX) Right clipping boundary. The first pixel outside the right side of the update region. The two LSBs of the X boundaries are ignored, the X boundaries may only be specified to a multiple of four pixels. - [1D] CLIP Y MIN (CYMN) Top clipping boundary. The upper most pixel in the update region. - [1E] CLIP Y MAX (CYMX) Bottom clipping boundary. The first pixel outside the bottom of the update region. Clipping boundaries are in device coordinates so that they are unaffected by the index values. Because clipping is in device coordinates, the clipping boundaries stand still on the screen during scrolling and thus are not usable as a drawing function, but merely to contain the image within the borders of the scroll window. They affect whether or not destination data is written and the setting of the clipping status bits. All rasterop calculations are still performed. [1F] SPARE # 3.4.1.1.4 Rasterop Control Registers - - [20] FAST SOURCE 1 DX (FSDX) Fast extent for the first source. This can only be in the + or X direction, so there is no Y component. - [21] SLOW SOURCE 1 DY (SSDY) Slow extent for the first source. This can only be in the + or Y direction, so there is no X component. Only the sign bit (MSB, bit 13) of the source 1 delta registers is significant in normal mode (even the signs are ignored, if the source 1 is not enabled). The whole value is significant in linear pattern and fill modes. In fill mode, only values in the range 2 ^12-1 to -2 ^12 are allowed in the source 1 delta registers, because these values are multiplied by 2 in some calculations internal to the Address Processor chip. - [22] SOURCE 1 X ORIGIN (SXO) X coordinate of the first source origin. - [23] SOURCE 1 Y ORIGIN (SYO) Y coordinate of the first source origin. The first source origin components can be in either world or device coordinates, depending on the setting of index mode for the first source. The loading of either of these registers in linear pattern mode will reset the source pattern scan and the slow scale calculations. - [24] DESTINATION X ORIGIN (DXO) X coordinate of the destination origin. - [25] DESTINATION Y ORIGIN (DYO) Y coordinate of the destination origin. The destination origin components can be in either world or device coordinates, depending on the setting of index mode for the destination. Loading of either of these registers during fill mode causes a new fill position to be initialized. Otherwise, all vector extents are relative to the end of the previous vector. Neither the first source nor destination origin registers are used during any mode after the rasterop initialization is complete. These registers may be loaded with new values after the rasterop initialization complete status bit is set. - [26] FAST DESTINATION DX (FDX) X component of the destination fast vector. - [27] FAST DESTINATION DY (FDY) Y component of the destination fast vector. - [28] SLOW DESTINATION DX (SDX) X component of the destination slow vector. - [29] SLOW DESTINATION DY (SDY) Y component of the destination slow vector. Only values in the range 2 ^12-1 to -2 ^12 are allowed in the destination delta registers because these values are multiplied by 2 in some calculations internal to the Address Processor chip. - [2A] FAST SCALE (FSC) Scale factor relating the fast vectors of the first source and destination in normal and linear pattern modes. - [2B] SLOW SCALE (SSC) Scale factor relating the slow vectors of the first source and destination in normal and linear pattern modes. For each of the scale factors, the MSB (bit 13) indicates up scaling (if a zero) or down scaling (if a one). The magnitude is specified in the remaining 13 bits with the binary point preceding bit 12. The Address Processor chip adds 0.000000000001B to each scale factor. The scale factors are ignored by the Address Processor chip unless both the source 1 and destination are enabled. - [2C] SOURCE 2 X ORIGIN (S2XO) X coordinate of the second source origin. - [2D] SOURCE 2 Y ORIGIN (S2YO) Y coordinate of the second source origin. The source 2 origins are added to the unindexed destination addresses (or low bits of them, if tiling is enabled). The second source origin components are always memory coordinates. The source 2 cannot be indexed and it is not adjusted for the effects of Y offset, therefore must be off screen. If tiling is enabled, the source 2 origin must be on a word boundary in the memory. - [2E] SOURCE 2 HEIGHT AND WIDTH (S2HW) The contents of this register determine the size of the source 2 tile. - <0> 3 Bits. Tile width (W) from 0 to 7; the width of the tile is 2 ^(W+2) (from 4 to 512). - <3> Reserved. Should be 0. - <4> 3 Bits. Tile height (H) from 0 to 7; the height of the tile is 2 (H+2) (from 4 to 512). - <7> 0=Tile height and width enabled; high bits of destination component truncated before adding to source 2 origin. l=Tile height and width disabled; all destination address bits added to source 2 origin. - [2F] ERROR 1 (ERR1) Error adjustment added to the error register during rasterop initialization for the slow destination (A side in fill mode). - [30] ERROR 2 (ERR2) Error adjustment added to the error register during rasterop initialization for the fast destination in normal and linear pattern mode and for the source 1 (B side) in fill mode. ## 3.4.1.1.5 Screen Format Control Registers - - [31] Y SCAN COUNT 0 (YCT0) - [32] Y SCAN COUNT 1 (YCT1) - [33] Y SCAN COUNT 2 (YCT2) - [34] Y SCAN COUNT 3 (YCT3) These four Y parameter registers program all vertical timing for the VCB02 video subsystem. Each register determines the time of one vertical event, such as asserting vertical blank. The event is specified by the two MSBs (bit 12 and 13). The low 11 bits determine the time of the event (scans for vertical synchronization events and scans minus one for other events), starting from vertical unblank. The events are stored in the registers in order of increasing time (low ll bits), starting in YCTO. The highest time value is programmed for the vertical period event. If the horizontal period is set for an odd number of major cycles (N odd, where "N" is defined for the horizontal period event, below), there must be an even number of scans in a frame; so that there will still be an even number of major cycles in a frame (the vertical period event must be set to an odd number). Vertical blank is deasserted (set low) when the vertical period is reached. The bits of the Y scan count registers are assigned as: - <0> 11 Bits. Time of event from deassertion of vertical blank, in scans for vertical synchronization events and scans minus one for other events. The end vertical period event is set to the number of scans in the frame, minus one. - <B> Reserved, should be zero. C> 2 Bits. Event. 00=End vertical period. Set vertical blank low in following scan. 01=Set vertical blank high. 10=Set vertical sync low. 11=Set vertical sync high. The VCB02 video subsystem provides a composite synchronization signal. The vertical synchronization signal chooses between two events in the X scan counter that provide the variable width horizontal synchronization pulse needed in a composite synchronization system. When using composite synchronization, the vertical synchronization interval must be delineated by the high state of the vertical synchronization signal, allowing the longer horizontal synchronization time to be determined by the "100" or "101" event in the X scan counter (see below). An example assignment of events for a composite sync application is: YCTO will set vertical blank high, YCTl will set vertical sync high, YCT2 will set vertical synchronization low and YCT3 will set vertical blank low and restart the vertical counter. System synchronization request will be generated by the Address Processor chip in the scan prior to deasserting vertical blank (scan prior to the first displayed scan). The exact timing of synchronization request within that scan is determined by the X scan count registers described below. #### [35] X SCAN CONFIGURATION (XCON) - 6 Bits. Number of major read cycles used for each scan. This is normally set to the smallest integer greater than or equal to: the number of pixels to be displayed on each scan divided by 128. In the VCB02 video subsystem this must be set to 8 (1024/128 = 8). Memory refresh will be accomplished approximately every 0.5 msec, plus any gap occurring during vertical retrace. See the discussion of XCT- and XL registers for required relationships to this register. - 2 Bits. Bus width mode must be programmed here and in the Video Processor chips before any bitmap memory access is attempted. Once bus width is initialized, most operations are independent of the bus width. Exceptions are X mode processor/bitmap transfers, source 2 tile origins and Video Processor scroll boundaries. The assignment of X and Y address bits to the Address Processor chip output pins is dependent on bus width and the memory configuration bit below. The VCB02 is a 16 bit bus width system and requires both these bits to be set. 00=4 bit bus width. 01=8 bit bus width. 10=Undefined. 11=16 bit bus width. Memory configuration controls the number of row addresses refreshed on each scan. In "greater than or equal to 1024" mode, 8 are refreshed. In "greater than or equal to 512" mode, 4 row addresses are refreshed. The number of pixels read in each scan is the (number of refresh reads programmed in XCON \* 16 \* 8). The VCB02 video subsystem requires this bit to be reset which selects 1024 mode (XCON \* 16 \* 8 = 1024). 0=1024 <= NUMBER OF PIXELS READ FROM MEMORY/SCAN < 2048 1=512 <= NUMBER OF PIXELS READ FROM MEMORY/SCAN < 1024 - [36] X LIMIT (XL) Width of that portion of the memory READ by the screen refresh process (could be more than displayed). This register tells the address calculation hardware what extent of the memory, in X, the Y offset (used for down scrolling) should be applied to. The number loaded to this register must be the number of read cycles set in the X scan configuration register, times 128 (for the VCB02: 8 128 = 1024). - [37] Y LIMIT (YL) Height of the portion of memory read by the screen refresh process (864 for the VCB02), plus the number of extra scans required when down scrolling (between 16 and 32 is suggested). This register tells the address calculation hardware what extent of the memory, in Y, the Y offset (used for down scrolling) should be applied to. The Y offset is applied to all of the rectangular area in the memory defined by the corners: [0,0] and [XL-1,YL-1], inclusive. The memory in the rectangle from address [0, height of displayed screen (scans)] to (but not including) the address [X limit, Y limit] is not usable for any purpose. While the memory between the right edge of the screen and X limit (if any) can be used, this is only possible for Y addresses from 0 to the height of the displayed screen. The addresses referred to in this paragraph are in device coordinates. - [38] X SCAN COUNT 0 (XCT0) - [39] X SCAN COUNT 1 (XCT1) - [3A] X SCAN COUNT 2 (XCT2) - [3B] X SCAN COUNT 3 (XCT3) - [3C] X SCAN COUNT 4 (XCT4) - [3D] X SCAN COUNT 5 (XCT5) - [3E] X SCAN COUNT 6 (XCT6) The X scan count registers are similar in function to the Y scan count registers. These seven X parameter registers program most horizontal timing for the VCB02 video subsystem. Each register determines the time of one horizontal event, such as asserting horizontal blank. event is specified by three high order bits. The low 11 bits determine the time (in 16ths of a major cycle. nominally 60 nsec. But some events are not allowed to be programmed to this precision) of the event, starting from a reference time preceding the beginning of the memory cycle that reads the first data to be refreshed on a scan (or the corresponding time during vertical retrace). The events are stored in the registers in order of increasing time, starting in XCTO. The highest time value is programmed as the horizontal period event. Bit <E> must be programmed in all seven registers, even if the "end horizontal period" event is in an earlier register. bits of the X scan count registers are assigned as: - <0> 11 Bits. Time of event from a reference time 3-1/4 major cycles preceding the start of the first memory cycle on a scan, in 16ths of a major cycle. The start of a memory cycle is defined as the rising edge of PHI 2 during the RAS precharge that begins the cycle. No two events may occur in the same 1/4 of a major cycle; that is, no two events may have times that are equal in all but the low two bits. - <B> 3 Bits. Event. - 000=Set horizontal blank low. - 001=Set horizontal blank high. - 010=Set horizontal sync low except during vertical sync event. - Oll=Set horizontal sync high except during vertical sync event. - 100=Set horizontal sync low. - 101=Set horizontal sync high. - 110=End horizontal period. - lll=Set sync request event. - <E> A one must be programmed for this bit in the XCTregister following the register that contains the "sync request" event. All other registers must contain a zero in this bit. <F> Test function in XCT6, normally 0. The period must be set to Nx16-4. The integer multiple "N" must be equal to twice the number of read cycles in XCON plus at least two (an integer number of major cycles). A larger "N" will lengthen the horizontal retrace interval by units of one major cycle. N must be at least 10. Horizontal blank is normally set low shortly after the start of the first memory cycle of the scan to allow for the pipeline delay of data in the Address Processor and Video Processor chips and in the video output circuitry. The Address Processor chip produces the 3-1/4 major cycle delay mentioned above and the Video Processor chip produces an additional 10 Alpha clock delay (5/8 major cycle). Horizontal blank would be set high after the desired number of pixels have been displayed on a scan. The polarity of horizontal sync is programmable. Horizontal synchronization starts when set high by the "101" event (or low by the "100" event). Horizontal synchronization ends when set low by the "010" event (or high by the "011"); except when vertical synchronization from the Y scan counter is high, when horizontal synchronization is set low by the "100" event (or high by the "101" event). The "100" or "101" events will always change horizontal synchronization; one of these events should be set to occur after the "010" or "011" event when composite sync is generated. System synchronization is generated by logic external to the Address Processor chip one major cycle after the synchronization request event occurs. Synchronization request always occurs during the scan preceding the end of vertical blank. This event must be programmed in the range Mx32+4 to Mx32+16, inclusive. The integer multiple "M" must be in the range 0 to (N/2)-2, inclusive (integer truncation is implied), where "N" is defined for the period event above. This must also be set for a time during the scan when no other X scan counter events will occur during the following sync interval (two major cycles). Event times affected are in the range Mx32+21 to $(M+1)\times32+23$ , inclusive. The two low bits of the synchronization request event time are not significant (only 240 nsec intervals allowed). An example assignment of events for a composite synchronization application is: XCTO sets horizontal blank low, XCTl sets synchronization request, XCT2 sets horizontal synchronization low for vertical interval ("100" event), XCT3 sets horizontal blank high, XCT4 sets horizontal synchronization high, XCT5 sets horizontal synchronization low except during vertical interval ("010" event), and XCT6 ends the horizontal period. [3F] SYNC PHASE (SYNP) - 11 Bits. The value loaded in the horizontal synchronization counter at each system synchronization time (once per frame). This must be set for (M+1)x32, where M is defined for the synchronization request event (this assumes the required synchronization interval of two major cycles). The low five bits of this register are ignored (not programmable). # 3.4.1.2 Address Processor Chip Commands All commands to the hardware are passed to the two command registers in the Address Processor chip (except scrolling, which is initiated by loading the scroll constant register). The command register (CMD) is used for all screen update functions and the I/D scroll command register (ICS) is used only for I/D bus register loads by the scroll process. The command register has 13 significant bits (the three MSBs are reserved for test functions), as shown in Figure 3-26. Figure 3-26 Command Register Format The low byte contains the I/D bus (interconnect) portion of any command, consisting of an opcode nibble and a nibble that usually specifies a register address. The next 2 bits select one of four functions (I/D bus, processor/bitmap transfer (PTB or BTP), rasterop or cancel) and the next 3 bits enable a combination of the destination and two sources. The ICS register is identical, except that it uses only the low byte to specify the I/D operation and an I/D command is assumed. Not all combinations of the command bits are meaningful; only the specific commands that are described in this section are allowed. Illegal commands will yield undefined results; they are not NOPs. All commands (except cancel) involve the Video Processor chips. Only those Video Processor chips that are selected by the chip select register will respond to commands on their I/D bus (interconnect) inputs and/or will allow writes to their associated memory planes. Participation in scrolling is determined by the setting of the scroll enable bit in each Video Processor chip. When multiple Video #### FUNCTIONAL DESCRIPTION Processor chips are involved in an operation (such as a color rasterop or a register load common to many chips), all the corresponding chip selects are set. If only one Video Processor chip is to be active (such as a unique register load), only the one chip select is enabled. A separate chip select register is used for loading Video Processor chips, when using the scroll I/D command register. The chip select registers have an unencoded enable bit for each Video Processor chip in the system. The chip select registers are connected to the I/D bus (interconnect) and are loaded with an "external" I/D bus (interconnect) load. If a rasterop command has been loaded and the initialization phase is complete (indicated by the initialization complete status bit), another IDENTICAL command may be loaded, effectively requesting a repeat of the previous command. The command register is not actually double buffered (only the reloading is remembered), so the previous command will not complete properly if a different command is loaded before the previous command finishes (address output must be complete before a new command is loaded). The ability to queue (one) repeated command is used to reduce register loading overhead between rasterops of a series, such as when displaying a text string. PTB or BTP commands cannot be queued in this way, because loading a new PTB or BTP command will clear the IDD FIFO. 3.4.1.2.1 Register Loading - Loading of Address Processor chip registers does not require the execution of any command. These are loaded either directly, by use of the address pins, or indirectly, through the address counter. The interrupt and request pins, in conjunction with the status register, are used to determine the safe time to load a register. All Video Processor chip registers and chip select registers are loaded using the Address Processor chip I/D command. Although any I/D interconnect instruction could be transmitted with this command, only these register loads are permitted. No reading or active cycles are allowed which are controlled by the Address Processor chip as part of rasterops. Figure 3-27 shows the F/D bus Video Processor Register Load Command format. Figure 3-27 I/D Bus Video Processor Register Load Command Format The ADDRESS in Figure 3-27 specifies the desired Video Processor chip register. Only those Video Processor chips, whose addressed registers are to be changed should be chip selected. Figure 3-28 shows the I/D bus Z Axis Video Processor Register Load Command. Figure 3-28 I/D Bus Z Axis Video Processor Register Load Command Format The REG in Figure 3-28 specifies the register to be loaded: 00=Source register. 01=Foreground register. 10=Scroll fill register. 11=Background register. Z BLOCK should be set to zero for the VCB02 video subsystem. Z block can specify one of the four possible groups of planes or sub-planes whose values are specified by the 16 bit I/D bus data. All Video Processor chips pertinent to the Z axis load should be chip selected. Figure 3-29 shows the I/D bus External Register Load Command format (used for loading the chip select registers). Figure 3-29 I/D Bus External Register Load Command Format This instruction will be ignored by all Video Processor chips, regardless of the setting of the chip select registers. Any data except, 00H, may be encoded in the seven low bits of the command for the external devices to decode. But the Address Processor chip will always source data during the I/D interconnect data transfer cycles. The I/D bus (interconnect) instruction 00H is reserved for the Address Processor chip to transmit during idle I/D bus cycles. Any of these three instructions can be used through either the update (IDD and CMD) or scroll (IDS and ICS) ports. The corresponding data register must be loaded before one of the command registers is loaded. When the I/D data register is loaded (except during PTB or BTP commands), this data word can be transmitted on a following I/D command, regardless of the previous state of the IDD FIFO. Of course, the action of the IDS register is the same because it is only a single register. After the command is loaded to the appropriate register, the corresponding status flag should be detected (by interrupt, request or poll) before a new data word or another command is loaded. In order to avoid interference with update operations, only the scroll process should load the following registers in the Address Processor chip: - 1. I/D SCROLL DATA (IDS) - 2. I/D SCROLL COMMAND (ICS) - 3. SCROLL X MIN (PXMN) #### FUNCTIONAL DESCRIPTION - 4. SCROLL X MAX (PXMX) - 5. SCROLL Y MIN (PYMN) - 6. SCROLL Y MAX (PYMX) - 7. Y OFFSET (PYOF) - 8. Y SCROLL CONSTANT (PYSC) - 9. PAUSE (PSE), if used for scroll synchronization. The following Address Processor chip registers may be loaded by the scroll process with the necessary synchronization between the scroll and update processes: - 1. PENDING X INDEX (PXI) - 2. PENDING Y INDEX (PYI) - 3. NEW X INDEX (NXI) - 4. NEW Y INDEX (NYI) - 5. OLD X INDEX (OXI) - 6. OLD Y INDEX (OYI). The scroll process should only load the following registers in the Video Processor chip: - 1. SCROLL CONSTANT - 2. FILL - 3. LEFT SCROLL BOUNDARY - 4. RIGHT SCROLL BOUNDARY. 3.4.1.2.2 Rasterop Command - Prior to issuing a command to start a rasterop, all pertinent registers should have been loaded, including the mode register. During a rasterop, the appropriate status bits should be detected before changing any registers. All functions are invoked by the command indicated in Figure 3-30. Figure 3-30 Rasterop Command Format In Figure 3-30, the first two bits enable the first or second source, or both (source 1 should never be enabled in fill mode). The next bit is always set high to enable the destination (if it were disabled, no action would be taken by the hardware, except setting of the status bits). The I/D byte specifies the active cycle for the rasterop. FNC SEL is a two bit code selecting one of the four logic unit function registers in each Video Processor chip. CSR specifies the bank of CSRs to be referenced during the source and destination cycles. The Address Processor chip fills in the last two CSR address bits according to the cycle in progress. The Video Processor chips participating in the rasterop are selected with the chip select register. There is no equivalent to a Z axis form of a rasterop command. Three status bits are used to monitor the progress of a rasterop command. Initialization complete indicates that the source I and destination origins may be loaded and the previous rasterop command may be requeued (by loading the CMD register again). This is useful to reduce wasted time between text characters. Rasterop complete indicates that rasterop parameters may be loaded. Address output complete indicates that any registers may be loaded. Normally, only one of these status bits is enabled at a time. 3.4.1.2.3 Processor to Bitmap or Bitmap to Processor Transfers - Processor to Bitmap transfers (PTB) or Bitmap to Processor transfers (BTP) are similar to rasterops, except that either the source or destination is the processor's memory (MicroVAX CPU's memory). They use the same rasterop status bits for control of the process, with the addition of two I/D data buffer bits. All data for a PTB or BTP is transferred through the I/D data FIFO (IDD). This six deep FIFO is cleared when any PTB or BTP (or rasterop, or cancel) command is written to the command register. Data may then be written to the IDD address during a processor to bitmap (PTB) transfer, if the transmit status bit is set. Data may be read from this address during a bitmap to processor (BTP) transfer, if the receive status bit is set. A PTB or BTP command is complete when the address output complete status bit is set. All data will have been transmitted/read from the FIFO and any register can be loaded. Scaling cannot be applied to PTB or BTP because the Address Processor chip ignores the scale registers unless both the source 1 and destination are enabled. A PTB or BTP never enable both. When PTB or BTP are used during scrolling, data must be transferred continuously to prevent computed addresses in the Address Processor chip from becoming invalid. The MicroVAX CPU or DMA controller (in the DMA gate array) must transfer two words every horizontal scan time. 3.4.1.2.3.1 X Mode PTB and BTP - In an X mode PTB, data is transferred from the processor memory (MicroVAX CPU's memory) to one plane with 16 bits adjacent in X occupying one word followed by additional X words and then by additional scans. In an X mode BTP, data from one plane is transferred to the procesor memory with 16 bits adjacent in X occupying one word followed by additional X words and then by additional scans. The LSB of a word is the left most pixel in the displayed word and the MSB is the right most pixel. The area of the bitmap that is involved in a transfer of data to or from the procesor memory is determined by setting the rasterop destination and source to span an unrotated rectangle. Figure 3-31 shows the Processor to Bitmap X Mode Command format. | ++ | · + | -+ | ++ | # | +- | + + + + | -++ | |----------------|-----|----|----|---|----|---------------|-----| | | | | | | | 1 FNC SEL NOP | | | +++++++##+++++ | | | | | | | | Figure 3-31 Processor To Bitmap X Mode Command Format In Figure 3-31, the FNC SEL and CSR bits have the same meaning as for rasterops, except that any CSR location can be used to control the register to which the processor data will be loaded. The plane(s) to which the processor data is being transmitted is controlled by the chip select register. The destination rasterop registers are programmed for the origin and size of the rectangle to be transferred. The fast DY and slow DX must both be zero. The destination may start on any pixel, but no shifting of the processor data will occur. If the destination starts in the middle of a bitmap memory word, the bits in the first processor word on each fast vector which will be outside the destination rectangle will be masked. Similar masking will occur on any trailing bits in the last word on each fast vector. Because there is no shifting available, PTB commands cannot be directed to any region that is scrolling horizontally. This can be avoided by transferring the data to an off screen area and then using a normal rasterop to transfer to a scrolling region. If the desired alignment of destination data is known at the time data is read from the bitmap with a BTP command, the correct shifting can be applied at that time. Figure 3-32 shows the Bitmap To Processor X Mode Command format. Figure 3-32 Bitmap To Processor X Mode Command Format In Figure 3-32, the CSR bit has the same meaning as for rasterops, except that any source CSR location can be used to select the Video Processor chip that talks on the I/D interconnect (alternately, if more than one Video Processor chip is enabled by the CSR, the transmitting chip may be selected by the chip select register). The use of one of the source CSRs is required to obtain proper function of a delay register. The destination rasterop registers are programmed for the size of the rectangle to be transferred. The fast DY and slow DX must both be zero. The source registers are programmed for the origin of the data. The source DX and DY sign bits must be the same as those for the destination. Shifting of the data will be determined by the low 4 (or 3 or 2) bits of the destination origin. The first bit of the source will be shifted to the bit addressed by the destination origin (just like any rasterop). Like the masked bits on each fast vector of the PTB command, the corresponding bits (those not in the "destination") will be undefined in the BTP data words. BTP data may be read from a vertically scrolling region, because normal indexing and offsetting apply to this source. 3.4.1.2.3.2 Z Mode PTB and BTP - In a Z mode PTB or BTP, all the bits from one pixel location (one bit from each plane) are transferred from or to a processor memory word, followed by additional pixel data along the fast vector and then by additional scans. The bitmap area is again determined by an unrotated rectangle addressed by the rasterop destination and source. Because the Z transfer occurs one pixel at a time, there are no restrictions on shifting or use during scrolling, other than the requirement of continuous data transfer. Figure 3-33 shows the Processor To Bitmap Z Mode Command format. ``` 0 0 0 1 1 1 1 1 0 1 0 F/B 1 Z BLOCK. ``` Figure 3-33 Processor To Bitmap Z Mode Command Format In Figure 3-33, F/B is set to "0" to select the foreground register, and to "1" to select the background register. The source register cannot be used for PTBZ operations. The use of logic unit function register "10" is assumed in the PTBZ command, and is normally set to force "1" to select the foreground register, or "0" to select the background register. The planes being transmitted to are controlled by the plane address, the Z BLOCK address and/or the chip select register. The destination rasterop registers are programmed for the origin and size of the rectangle to be transferred. The fast DY and slow DX should both be zero. The destination may start on any pixel. Figure 3-34 shows the Bitmap To Processor Z Mode Command format. ``` 0 0 0 1 0 1 1 0 1 1 0 0 Z BLOCK. ``` Figure 3-34 Bitmap To Processor Z Mode Command Format The plane address, the Z BLOCK address and/or the chip select register are used to select the Video Processor chips which form the Z word. The destination rasterop registers are programmed for the size of the rectangle to be transferred. The fast DY and slow DX should both be zero. The source registers are programmed for the origin of the data. The sign bits of the source DX and DY determine the direction of scanning. 3.4.1.2.4 Cancel Command - The cancel command stops all operations, regardless of the command in progress, EXCEPT for commands entered through the scroll I/D port. The rasterop status bits are set to their "completed" states and the Address output FIFO is cleared. The IDD FIFO is also cleared and the ID status bits set accordingly. The pause, scroll service, I/D scroll data, clipping and vertical blank status bits are not affected. Figure 3-35 shows the Cancel Command format. Figure 3-35 Cancel Command Format During execution of the cancel command, the "I/D data transmit ready" status bit will be held low. When this bit goes high, the cancel command is complete and any new data or command may be loaded. This bit should be tested before the next command is loaded unless the software guarantees 4 major cycles of delay. #### 3.4.2 Video Processor Chip (I/D Bus) Commands The instruction/data interconnect is used to control all of the Video Processor chips and chip select registers. The I/D bus (interconnect) also provides for the exchange of data between Video Processor chips or between the Video Processor chips and the Address Procesor. The chip select registers for the Video Processor chips control the Video Processor chip's participation in I/D bus transfers and rasterops. Two chip select registers are used in the VCB02 video subsystem, one for the scroll process to access the Video Processor chips and one for the update process. ## 3.4.2.1 Video Processor Chip Registers The basic width of a Video Processor chip register is 16 bits. All of the Video Processor chip registers are writable and none are readable. The register address (or the address of the first of a group of registers), in HEX and enclosed in [], precedes the register descriptions in the following list. Where specified, bit assignments (or the LSB of a group of bits) are enclosed in <>. - [0] RESOLUTION MODE 2 Bits. Controls the actions of the mask bits (the combination of mask 1, mask 2 and the edge mask), the source register, the rasterop barrel shift constant, and Z axis commands to make a Video Processor chip perform as 1, 2 or 4 planes. The VCB02 color maps cannot take advantage of resolution mode, so this feature is NOT supported. For normal VCB02 operation 1 plane resolution must be selected. - <0> 00=1 Plane. Each mask/source bit controls its respective mask mux/logic unit bit independently of the others. All barrel shifter constant bits are significant. The Video Processor chip acts as a single plane for Z axis operations, receiving or transmitting the one bit corresponding to its plane address. The plane address may be programmed to any value. 01=2 Planes. Even and odd mask/source bits are ORed (after the complementers controlled by the LUF registers) and the result is used to control both of the corresponding bits of the mask mux/logic unit. The LSB of the rasterop barrel shift constant is truncated, so that data in this plane will only move by a multiple of two bits. The Video Processor chip acts as two planes for Z axis operations, receiving or transmitting the two bits corresponding to its plane address and the next most significant bit. The plane address must be programmed to an even value. 10=This setting will give undefined results. ll=4 Planes. The four mask/source bits from each nibble are ORed (after the complementers controlled by the LUF registers) and the result is used to control all four of the corresponding bits of the mask mux/logic unit. The two LSBs of the rasterop barrel shift constant are truncated, so that data in this plane will only move by a multiple of four bits. The Video Processor chip acts as four planes for Z axis operations, receiving or transmitting the four bits corresponding to its plane address and the next three most significant bit. The plane address must be programmed to a multiple of four. #### NOTE The rasterop barrel shift constant must be truncated in low resolution Video Processor chips to keep the bits in their proper subplanes because the Address Processor chip cannot supply each Video Processor chip with a different shift constant (each Video Processor chip may be programmed for a different resolution). On the other hand, this effect cannot be provided for scrolling because the error caused by truncation must not be accumulated and because the scrolling region may not be the region for which the resolution mode has been set. Horizontal scrolling should only be in increments of the lowest resolution plane involved. - [1] BUS WIDTH 2 Bits (starting with <2>). Allows either 4, 8, or 16 bits of memory to be used depending on the number of pixels required by the display. The VCB02 video subsystem is a 16 bit system and requires the bus width to be set to 16 bit mode. All Video Processor chips and the Address Processor must be set to the same bus width. The video bus speed for the 16 bit bus width is 4 bits ever 60 nsec. - <2> 00=4 Bit bus width. 01=8 Bit bus width. 10=This setting will give undefined results. 11=16 Bit bus width. - [2] SCROLL CONSTANT This register is double buffered; data loaded becomes active at the beginning of the following frame. - 4 Bits. X scroll constant. For left scroll, this nibble is the magnitude of the scroll, 0 to 15 pixels per frame time. For right scroll, this nibble is the magnitude of the scroll minus one. The values 0 to 15 result in scrolls of 1 to 16 pixels per frame time, respectively. If the scroll disable bit is set in this register or if a non-zero Y scroll constant is programmed in the Address Processor chip, this nibble must be zero. If the region being scrolled contains some Video Processor chips set for low resolution, the low order one or two bits of this nibble should be zero for left scrolls or all ones for right scrolls. - <4> Horizontal scroll direction. 0=Left. Also use "0" for up, down and disabled scrolling. If a non-zero Y scroll constant is programmed in the Address Processor chip, this bit must be zero. l=Right. - <5> 0=Disable scrolling (horizontal or vertical) of all data accessed by this Video Processor chip (disables writing for memory plane). Also, the other bits in this register must be set to down, left and zero X scroll constant. l=Enable scrolling. - <6> Vertical scroll direction. This bit accounts for some asymmetries between up and down scrolling. 0=Down scroll. Also used with disable scroll. 1=Up, left or right scroll. - [3] PLANE ADDRESS 6 Bits. Plane address for Z axis operations. No two Video Processor chips should be given the same (or overlapping) plane address(es). If the fill register is loaded in Z mode by the scroll process, the plane addresses must be established permanently. However, if the scroll process loads the fill registers individually, then different update regions could have different plane address arrangements. - 4 Bits. Bit address within Z axis block (0 to 15). Addresses the bit (or low order bit in a low resolution Video Processor chip) on which the Video Processor chip will exchange data on the I/D bus during Z mode transfers. This must be a multiple of two or four in a low resolution Video Processor chip. - 2 Bits. Z axis block address (0 to 3). These are essentially the high order bits of a 6 bit plane address (intended for use in systems with more than 16 planes), but separate blocks must be addresses with seperate Z commands. For the VCB02, these bits should be 00. - [4] LOGIC UNIT FUNCTION 4 registers of 8 bits. Any one of the four registers can be selected for use during a rasterop or PTB command. During Z mode processor to bitmap commands, function register "10" is used for modification of the bitmap. - 4 Bits. Logic unit function. The Video Processor chip logic unit combines the word read from the destination (D) during a destination cycle (read-modify-write cycle) with the contents of the source register (S) (normally loaded during a previous source memory cycle); after the latter has passed through a complementer and resolution logic, and uses the result (F) to select the foreground or background color. ``` 0000= F=ZEROs 0001 = F = NOT(D OR S) 0010= F=NOT(D) AND 0011 = F = NOT(D) 0100 = F = D AND NOT(S) 0101 = F = NOT(S) 0110= F= D XOR ·S 0111= F=NOT(D AND S) 1000 = F = D AND S 1001 = F = NOT(D XOR) S) 1010 = F = S 1011 = F = NOT(D) OR S 1100 = F = D D OR NOT(S) 1101 = F = 1110 = F = D OR S llll= F=ONEs ``` - <4> 0=Use mask 1. l=Use the complement of mask 1. - <5> 0=Use mask 2. l=Use the complement of mask 2. - <6> 0=Use the complement of source. l=Use source. - <7> 0=Enable resolution mode logic for the source register. l=Disable resolution mode logic for the source register (pass bits through to the logic unit without combining adjacent bits, regardless of resolution mode register setting). The following four registers have 16 bits. The LSB is the left most pixel in a word, as viewed on the screen and the MSB is the right most pixel. All four of the registers can be loaded by I/D bus register load commands. The mask and source registers can also be loaded by data transfers during rasterop cycles. The source and fill registers can be loaded with constant data (solid color) by a Z axis register load. - [8] MASK 1 = Programmable mask register 1. Used to control which bits are modified by a read-modify-write cycle. Loading mask 1 loads mask 2 with the same data, so that only one mask is effective. - [9] MASK 2 Programmable mask register 2. Used to control which bits are modified by a read-modify-write cycle. The outputs of the two mask registers are followed by independent complementers (controlled by the logic unit function registers). The outputs of the complementers are ANDed with each other and with the edge mask (which defines those bits involved in a rasterop). Only those bits are modified that are selected by all three masks (a one from the AND enables modification of a bit). Resolution mode logic follows the AND function. If only mask 1 is used, both complementers must be enabled or disabled together to prevent masking all bits. - [A] SOURCE Source word (normally loaded by a source memory cycle) for the logic unit to combine with the destination to select the foreground or background colors for each pixel. The source data is processed by a complementer and resolution mode logic before entering the logic unit. The Z axis address for this register is "00". - [B] FILL Data that will be inserted into memory words to fill the blank space created by scrolling. Normally a solid color fill is desired and will be provided with a Z axis load, if loaded directly. This register is double buffered and data loaded becomes active on the following frame. The Z axis address for this register is "10". Because the scroll region boundaries can be set within a word, the Video Processor chips must be told which bits of the left most word and the right most word are actually in the scroll region. The Video Processor chip can be programmed to place the region boundaries on any bit position (for possible future extension), but the Address Processor chip cannot specify the boundary closer than a multiple of four. Therefore, only those boundaries should be selected that select groups of four bits. These registers are double buffered and data loaded becomes active on the following frame. [C] LEFT SCROLL BOUNDARY - 16 Bits. All bits are clear, corresponding to the pixels that are to be scrolled in the word that contains the left edge of the region (all other bits set). Normally, this requires clearing all bits from the pixel on the edge through the MSB of the word, but if both edges are contained in one word, then only bits from the left edge through the right edge are clear. [D] RIGHT SCROLL BOUNDARY - 16 Bits. All bits are clear from the LSB (left edge) through the bit corresponding to the right most pixel that is to be scrolled in the word that contains the right edge of the region (all other bits set). Unless the right boundary is between words (LSB not scrolled) or both edges are contained in the same word, in which case all bits are set. - [E] BACKGROUND COLOR Selected by a zero at the output of the logic unit. The Z axis address for this register is "ll". - [F] FOREGROUND COLOR Selected by a one at the output of the logic unit. The Z axis address for this register is "01". The foreground and background registers have 16 bits. The LSB is the left most pixel in a word, as viewed on the screen and the MSB is the right most pixel. Both of the registers can be loaded by I/D bus register load commands and by a Z axis register load. The outputs of the logic unit select these registers on a bit-by-bit basis as the inputs to one side of the mask mux (the mask mux then selects between this new data and the old destination data). Either of these two registers is used to pass data during Z mode PTB operations. CONTROL STORE RAM - 6 registers. The Video Processor chip control store RAM controls the transfer of data within the Video Processor chip and to/from other I/D bus devices during rasterops. Addressing of its contents during rasterops is controlled by the Address Processor chip and occurs once for each update memory cycle. - [10] CSR 0 Controls the first source read, if bank 1 is selected and source 1 is enabled in the Address Processor chip command register. - [11] CSR 1 Controls the second source read, if bank 1 is selected and source 2 is enabled in the Address Processor chip command register. - [12] CSR 2 Controls the destination read-modify-write, if bank 1 is selected and the destination is enabled in the Address Processor chip command register. - [13] Reserved - [14] CSR 4 Controls the first source read, if bank 2 is selected and source 1 is enabled in the Address Processor chip command register. - [15] CSR 5 Controls the second source read, if bank 2 is selected and source 2 is enabled in the Address Processor chip command register. - [16] CSR 6 Controls the destination read-modify-write, if bank 2 is selected and the destination is enabled in the Address Processor chip command register. - [17] Reserved #### NOTE These assignments of CSR functions are defined by the Address Processor chip. The Video Processor chip does not assume any assignment of CSRs, except that CSR 0 and 4 are linked to the first delay register and CSR 1 and 5 are linked to the second delay register. Each of the CSR words has the following bit assignments: <0> 2 Bits. External load. Selects the register into which incoming data from the I/D bus (if any) will be loaded following a memory read. 00=None 01=Source 10=Mask 1 and mask 2 11=Mask 2 <2> 2 Bits. Internal load. Selects the register into which incoming data from the local memory plane (from the barrel shifter) will be loaded following a memory read. 00=None 01=Source 10=Mask 1 and mask 2 11=Mask 2 <4> I/D bus (interconnect) output control. Only one plane should be enabled to output its shifted data on the I/D bus for all other planes during any one memory read cycle (i.e.: for any one CSR address). 0=Disable output. l=Enable output. Sarrel shifter delay control. When executing a fast mode rasterop, one output word is usually formed from a part of each of two source words. To avoid excessive reads to the source raster, the previous word can be held in a delay register so that its remainder can be used with the next word. This bit controls one delay register when the active CSR is 0 or 4 (for source 1) and controls the other delay register when the active CSR is 1 or 5 (for source 2). 0=Do not load delay register. l=Do load delay register. NOTE With two separate delay registers, selected by the CSR address, the delay enable bit is no longer necessary. It should be programmed to a 1. NOTE There may be no reason to ever program either destination CSR to other than "000000"; these two registers may be unnecessary. # 3.4.2.2 Instruction/Data Bus Instructions I/D bus instructions are specified by a one byte code. Rasterop, PTB and BTP commands are further specified by a subinstruction byte. Most I/D interconnect instructions are also accompanied by a 16 bit data transfer. 3.4.2.2.1 I/D Instructions Issued By The MicroVAX CPU - The addressed Video Processor chip register with the 16 bit data transmitted on the I/D interconnect (see Figure 3-36) which was contained in the word loaded to the IDD (or IDS) register of the Address Processor chip (previous to loading an I/D bus command). This instruction is always initiated by the MicroVAX CPU. The Address Processor chip never transmits the instruction without an explicit command to do so. Figure 3-36 Video Processor Chip Register Load Instruction Format 3-88 Figure 3-37 shows the instruction format which loads all bits of the addressed register (in the Video Processor) with the contents of one of the 16 I/D bus data bits. The low four bits of the plane address programmed into each Video Processor chip selects the I/D data bit used during the load. Only those Video Processor chips in the addressed Z block that are chip selected are updated. The Z block should be zero for the VCB02. If a Video Processor chip is set for a low resolution mode, a pair of bits or a nibble is duplicated into each of the 8 pairs or four nibbles of the selected register. Z axis register addresses are defined as: ``` 00=Source. 01=Foreground. 10=Fill. 11=Background. ``` Figure 3-37 Video Processor Chip Z Axis Register Load Instruction Format The VCB02 uses intructions that are designed to control external I/D devices to load the update and scroll chip select registers. The format of the external register load instructions is shown in Figure 3-38. I/D instructions are distinguished by bit <7>=0 in the instruction byte. Instruction 00H is reserved for NOP. Figure 3-38 External Register Load Instruction Format 3.4.2.2.2 Address Processor Chip I/D Instructions - The only direct I/D bus (interconnect) instructions that a programmer will use are the Video Processor chip and chip select register loads. The remaining I/D interconnect instructions are used by the Address Processor chip to control rasterops. The instruction shown in Figure 3-39 is transmitted by the Address Processor chip when the I/D bus is idling. | | + | <b></b> - | + | + | | + - | + | | - + | | - + | |----------|----|-----------|------------|------|------|-----|---|--------------|-----|---|-----| | INST: | 0 | 0 | 0 | 0 | 0 | : | 0 | 0 | i | 0 | | | | + | | + | +4 | | + - | + | | - + | | -+ | | | + | | <b>+</b> - | + | | +- | + | - <b>-</b> - | - + | | - + | | SUBINST: | | | Į | UNDE | FINE | ED | | | | | ! | | | ++ | <b></b> - | + | +4 | | +- | | | -+ | | - + | Figure 3-39 No Operation Instruction Format The instruction shown in Figure 3-40 is essentially identical to the Video Processor chip Z axis register load, except that the instruction is generated with an accompanying read-modify-write cycle (as part of processor to bitmap transfer). Bit F/B is set to "0" to select the foreground register and to "1" to select the background register. The source register cannot be used for PTBZ operations because the propagation delays in the Video Processor chip are too long for the path through the source register. The use of logic unit function register "10" is assumed in the PTBZ command. An edge mask is provided to select the one bit in the memory being written. However, the Z data being written by the current memory cycle is that which was transmitted during the previous I/D bus cycle (not the concurrent cycle). These are really ordinary Z axis register loads interleaved with destination only rasterop cycles. The right and left mask specifiers are equal for this instruction and are the address of the selected bit. | INST: | 1 : 0 1 0 : F/B 1 Z BLOCK | |----------|------------------------------| | SUBINST: | LEFT MASK RIGHT MASK | Figure 3-40 Z-Axis Write (Two Interleaved Instructions) Format The instruction shown in Figure 3-41 is used by the Address Processor chip during a bitmap to processor transfer along with an accompanying memory read cycle. The bit address specifies the bit in the memory word for which the color is being read. The Video Processor chip generates a barrel shift constant from the bit address and the low four bits of the plane address. Each of the Video Processor chips addressed by the Z block transmits its bit (or bits, if a low resolution chip) on the appropriate I/D bus pin. | | + | ++ | +- | + - | + | -+ | -++ | | |----------|--------|------|------|------|--------|--------------|--------|--------| | INST: | . 1 | 0 | 1 . | 1 | NOP | : <b>Z</b> | BLOCK | | | | + | ++ | +- | + - | + | -+ | -++ | | | | + | ++ | +- | +- | + | -+ | -++ | | | SUBINST: | | | NOP | ! | BIT | ADDF | RESS | | | | + | ++ | +- | +- | + | · <b>- +</b> | -++ | | | | Figure | 3-41 | Z-Ax | is R | Read I | insti | uction | Format | The instruction shown in Figure 3-42 is generated by the Address Processor chip with an accompanying memory read cycle to control the handling of the read data. The CSR address selects the controlling CSR location (and therefore a delay register) will be either 0, 1, 4or 5. The subinstruction controls the use of the barrel shifter to align the source data with the destination location. The barrel shifter has a 32 bit input and selects a 16 bit segment as an output. If the shift constant is 0, the left most 16 bits are selected. If the shift constant is 15, the right most bit of the left word and the left 15 bits of the right word are selected. The inputs to the left or right word of the barrel shifter can come either from the data read on the current cycle or from the data previously stored in the delay register that corresponds to the addressed CSR. If the LD bit=0, the current word is used for the left input. If the LD bit=1, the delay register is used for the left input. The right input is selected similarly. | INST: | 1 1 1 NOP | CSR ADDRESS | |----------|----------------|-------------| | SUBINST: | NOP L D R D SH | FT CONSTANT | Figure 3-42 Active Cycle For Memory Read Instruction Format The instruction shown in Figure 3-43 is generated by the Address Processor chip with an accompanying read-modify-write cycle to control the logic unit register and the edge masks. The CSR address selects the controlling CSR location and will be either 2 or 6. One of the four logic unit function and mask control registers is selected. The subinstruction sends the edge mask to select the bits to be written within the word. The left mask is the bit address of the left most pixel to be modified. The right mask is the bit address of the right most pixel to be modified. Therefore, if one pixel is to be modified, both mask values are the same. O is the LSB or left most pixel. 15 is the MSB or right most pixel. INST: 1 1 FNC SEL NOP CSR ADDRESS +--+--+--+--+ SUBINST: LEFT MASK RIGHT MASK Figure 3-43 Active Cycle For Read-Modify-Write Instruction Format ## 3.4.3 Physical Configuration This section describes system wide interconnection, timing and functional issues specific to the VCB02 implementation. # 3.4.3.1 Address Processor Chip Pins The Address Processor chip is contained in an 84 pin, leaded, square, surface mount package. Pin numbers are indicated in []; for grouped pins, the pin numbers are listed in order, starting with the high order pin. #### 3.4.3.1.1 Processor Interface - - DAT<15:0> (Input/Output) [57, 58, 59, 60, 63, 64, 65, 66, 69, 70, 71, 72, 73, 74, 75, 76] DAT<15:00> are connected to PB<15:00> on the DMA gate array and are used for the read/write data transferred form/to any register in the Address Processor and Video Processors. DAT<15:00> are tri-stated to receive register data unless RD is high, and -AS and -DS are low. - AD<5:0> (Input) [77, 78, 79, 80, 81, 82] AD<5:0> are connected to the AA<6:1> pins of the DMA gate array and select an Address Processor chip register. AD<5:0> are latched on the falling edge of -AS. - The falling edge of -AS latches address on AD<5:0> and provides the Address Processor chip select function. In the VCB02 video subsystem -AS and -DS are both connected to the ADDAS L pin on the DMA gate array. ADDAS L is asserted by the DMA gate array only for Address Processor chip bus cycles. When data is transferred to the Address Processor's ADCT register, -AS increments the register pointer. - -DS (Input) [83] The falling edge of -DS latches processor data. During read, the low level enables DAT<15:0> and the rising edge disables DAT<15:0> output buffers. -DS and -AS are both connected to the ADDAS L pin on the DMA gate array. ADDAS L is asserted by the DMA gate array only for Address Processor chip bus cycles. - RD (Input) [1] RD is connected to the DMA gate array pin ADDWR L. When RD is asserted (high) a read cycle is selected. When RD is deasserted (low) a write cycle is selected. RD is latched by -DS. - REQ (Output) [11] -REQ is connected to the DMA gate array pin ADDRQ L. -REQ is asserted by the Address Processor chip when a bit in the request enable register matches the corresponding bit in the status register. ADDRQ L synchronizes the transfer of data by the DMA logic (in the DMA gate array) with the execution of instructions by the Address Processor. - -INT (Output) [10] -INT is connected to the IRQl L pin on the DMA gate array. -INT is asserted by the Address Processor chip when a bit in the interrupt enable register matches the corresponding bit in the status register. IRQl L is used by the DMA gate array to request interrupt service from the MicroVAX CPU for the Address Processor. - -INIT (Input) [2] -INIT is connected to the QBUS INIT signal. -INIT Resets Address Processor chip command processor, halts commands and clears address counter and IDD and address output FIFOs. Disables I/D bus drivers on the Address Processor chip until the first occurrence of SYNC following deassertion of -INIT. # 3.4.3.1.2 Memory Address and Video Processor Chip Interface - - MEMAD<10:0> (Output) [52, 51, 50, 49, 48, 47, 46, 45, 44, 43, 40] Bitmap Memory Address Bits. Multiplexed row and column addresses for bitmap. Addresses are clocked out by ADDCLK; one row and eight column addresses for a major cycle and one each of row and column for a minor cycle. - ADDCLK (Input) [25] Bitmap Memory Address Clock. Nine cycles per major memory cycle; two cycles per minor memory cycle. - 128/-16 (Output) [37] Bitmap Memory Cycle Select. High selects a major cycle for a 128 bit read or write (in 16 bit mode). Low selects a pair of minor cycles for a 16 bit read or write (also 16 bit mode). - R/-W (Output) [36] Bitmap Memory Read/-Write. Selects read or write for major or minor cycles. If write is indicated for a minor cycle, external timing implements the required RMW sequence. - -WE<3:0> (Output) [35, 34, 33, 32] Bitmap Memory Write Enables. Four write enables to disable writes to nibbles in memory words that are outside of the scroll or clipping regions. -WE<0> controls the low order nibble (left most on the screen). A set of values is provided for each column address output by the Address Processor chip. Low enables writing. - FORCE (Output) [38] High indicates major cycles during a down scrolling frame, so that writing can be forced in all planes not participating in down scrolling. - SCROLL (Output) [39] Scroll Enable. High indicates all bitmap bus words that are contained in a scrolling region, except for the right most word in the region. A state output is provided for each column address output by the Address Processor chip during a screen refresh major cycle. - ADS (Input) [28] Address Disable. When high, allows the Address Processor chip to complete its current memory cycles and then suspend all update (minor) memory cycle activity. ADS is always low in a VCB02 video subsystem so that the Address Processor never suspends memory cycles. # 3.4.3.1.3 I/D Bus (Interconnect) - - ID<7:0> (Input/Output) [22, 21, 20, 19, 18, 16, 15, 14] I/D bus Bit. Eight bit bus always transmits during the two instruction cycles; tri-stated during the two data cycles unless a PTB or I/D command is being executed. - IDCTL (Output) [12] Chip Select Control. IDCTL is used to select the the outputs of the scroll or update chip select register for connection to the Video Processor CS input. Scroll chip select registers are selected when IDCTL is high and update registers are selected when IDCTL is low. IDCTL is high during execution of commands in the ICS register. # 3.4.3.1.4 Monitor Timing - - BLANK (Output) [7] Video Composite Blank Signal. High indicates blank. - CMPSYN (Output) [6] Video Composite/Horizontal Synchronization. Composite synchronization. Programmable polarity. - VRTSYN (Output) [5] Video Vertical Synchronization. Not used in the VCB02 Video Subsystem. Programmable polarity. #### 3.4.3.1.5 Clocks - - PHI1, PHI2 (Input) [53, 55] Phase 1, 2 Clock Inputs. Non-overlapping clocks. Period is 1/4 major cycle. - PHI3, PHI4 (Input) [26, 27] Phase 3, 4 Clock Inputs. Non-overlapping clocks. Period is 1/8 major cycle. - -SYN/REQ (Output) [8] System Synchronization Request. Low indicates that a system synchronization should be initiated by the external timing generator (in the following major cycle). Reset to high state by the assertion of SYNC. - SYNC (Input) [9] System Synchronization. Issued by the external timing generator during the first part of a synchronization interval to reset phase of Address Processor chip timing logic. Also, a number of double buffered registers will be updated. Note that this is not a chip reset pin. All clock signals are held frozen during the entire synchronization interval (two major cycles). #### 3.4.3.1.6 Power - - VDDL1, VDDL2, VDDL3, VDDI, VDDM, VDDC, VDDD [3, 23, 62, 17, 41, 54, 67] Power. Plus 5 volts supply for logic, I/D bus, memory address bus, clocks, and data bus. - GNDL1, GNDL2, GNDL3, GNDI, GNDM, GNDC, GNDD [4, 24, 61, 13, 42, 56, 68] Power Return. Ground for logic, I/D bus, memory address bus, clocks, and data bus. - VBB [31] VBB bypass. - Spare [29, 30] #### 3.4.3.2 Video Processor Chip Pins The Video Processor chip is contained in a 68 pin, leaded, square, surface mount package. Pin numbers are indicated in []; for grouped pins, the pin numbers are listed in order, starting with the high order pin. # 3.4.3.2.1 Bitmap Memory - - DIO<15:0> (Input/Output) [19, 18, 17, 16, 15, 14, 13, 12, 11, 8, 7, 6, 5, 4, 3, 2] Bitmap Data Input/Output Bus. The DIO<15:0> output drivers are tri-stated when R/-W is high. - SCROLL (Input) [10] Scroll Enable. High indicates all DIO<15:0> bus words that are contained in a scrolling region, except for the right most word in the region. - PE (Output) [25] Plane Enable. When high, this tri-state signal allows the bitmap memory to be written during a rasterop or scroll write cycle. This output driver is tri-stated when R/-W is high. - 128/-16 (Input) [65] Major or Minor Cycle. When high, this signal activates internal logic that is associated with major cycles (128 bit process). When low, this signal activates internal logic that is associated with minor cycles (16 bit process). - R/-W (Input) [64] Bitmap Memory Read/Bitmap Memory Write. When high, all DIO<15:0> and PE output drivers will be tri-stated and the Video Processor chip may receive bitmap memory data. When low, all DIO<15:0> and PE output drivers will be enabled. When 128/-16 is low, the falling edge of R/-W is used to latch in bitmap memory data on the DIO<15:0> lines. - LTCLK (Input) [66] Latch Clock is generated by the timing logic on the Base Module. When R/-W and 128/-16 are high, the falling edge of LTCLK is used to latch in bitmap memory data on the DIO<15:0> lines. When R/-W is low and 128/-16 is high, the rising edge of LTCLK will cause valid scrolled data to be shifted out on the DIO<15:0> lines. There are eight cycles of LTCLK per major cycle. # 3.4.3.2.2 I/D Bus (Interconnect) - - ID<7:0> (Input/Output) [31, 32, 33, 35, 36, 38, 39, 46] Instruction/Data input/output interconnect. Normally tri-stated to receive instructions or data, the ID<7:0> output drivers can be enabled during execution of Z axis or active I/D instructions. - CS (Input) [40] Chip Select. While receiving an instruction, if ID<7> and CS are high, the arriving instruction will be latched and executed. Otherwise, the arriving instruction will be ignored. # 3.4.3.2.3 Video Output - - VID<3:0> (Outputs) [56, 57, 58, 59] Video Output. Screen refresh data is shifted out on these output lines on the rising edge of ALPHA. #### 3.4.3.2.4 Clocks - - ALPHA (Input) [55] Data on the VID<3:0> lines will be shifted out on the rising edge of ALPHA. Period is 1/16 of a major cycle. - PHIl, PHI2 (Inputs) [50, 49] Non-overlapping clocks that determine overall timing and control of the Video Processor chip. Period is 1/4 of a major cycle. - SYNC (Input) [63] System Synchronization. When asserted, synchronizes the phase of internal Video Processor chip states to the remainder of the VCB02 video subsystem. Also, a number of double buffered registers will be updated. Note that this is not a chip reset pin. #### 3.4.3.2.5 Power - - VDD 1, VDD 2 [53, 54] Plus 5 Volts Supply - VSS <8:0> [Drivers: 1, 68, 67, 27, 28, 44, 45; Logic: 29, 30] Power Return. Driver ground, logic ground. - VBB, CAVITY [61, 60] Substrate bias. VBB must be connected to CAVITY. # 3.4.3.2.6 High Speed Timing - - 3.4.3.2.6.1 Clock Generation The Address Processor and Video Processor chips require the following clocks: - o PHIl, PHI2 Basic system clocks for both the Address Processor and Video Processor chips. Determines I/D bus timing. - o PHI3, PHI4 Serial arithmetic clocks for the Address Processor chip. - o ALPHA Video output clock for the Video Processor chip. - o ADDCLK Address output clock for the Address Processor chip. - o LTCLK Data clock for 128 bit cycles (major cycles) for the Video Processor chip. Clock timing is in increments of 30 nsec (nominal), however, the actual period for PHI 3 and 4 is 115.6 nsec, rather than the nominal 120 nsec. All other clocks scale accordingly. The skew between any two of the above clocks do not exceed +/-5 nsec. This is achieved by deskewing all of these clocks through latches clocked at 30 nsec. ADDCLK has nine cycles per major cycle or two per minor cycle. LTCLK has eight cycles for every major cycle or pair of minor cycles; although LTCLK does not clock data at the pins during minor cycles, it is still used internally. 3.4.3.2.6.2 System Synchronization - Once per frame (vertical scan of the screen), all system timers are synchronized to each other. Synchronization occurs at a time when no screen refresh or other user perceivable activity is in progress. Synchronization is accomplished by freezing ALL clocks and memory timing signals for two major cycles (one compute cycle in the Address Processor chip), It is called the synchronization interval and asserts the SYNC pin on the Address Processor and all Video Processors during the first part of the synchronization interval (for the first major cycle). The clocks must be stopped at the start of any major cycle (rising edge of every other PHI2) that is permitted by the programming of the X SCAN COUNT registers). During the synchronization interval, the clocks must remain in the following states: - o PHIl Low - o PHI2 High - o PHI3 High - o PHI4 Low - o ALPHA High - o ADDCLK High - o LTCLK High - o Other memory timing signals as required. After the synchronization interval, all clocks must proceed exactly as if the two major cycles of the synchronization interval had never occurred. Basically, the only clocks that do not freeze are the ones that are needed to time the synchronization interval. The synchronization interval is initiated when the Address Processor chip issues the SYN/REQ signal. The exact timing of this signal is programmed in the X SCAN COUNT registers. The clock generating logic responds to SYN/REQ by starting a synchronization interval at the next major cycle boundary. Processor bus activity can proceed as normal during the synchronization interval. 3.4.3.2.7 I/D Bus (Interconnect) - The Instruction/Data interconnect is tied to the Address Processor and Video Processor chips and to the chip select registers. The I/D bus transmits two bytes of command from the Address Processor chip and transfers two bytes of data from the Address Processor or Video Processor chips every minor cycle. Transmissions are synchronized to memory cycles, as required. A byte is transmitted during each of the four PHIl and PHI2 pulses in a minor cycle. Each of the two PHIl and two PHI2 pulses are labeled A and B. The rising edge of PHI2B starts a minor cycle and the sequence is PHI2B, PHI1B, PHI2A and PHI1A. The command/data sequence is: - 1. PHI2A Instruction 1 - 2. PHILA Subinstruction 1 - 3. PHI2B Low byte data 0 - 4. PHILB High byte data 0 - 5. PHI2A Instruction 2 - 6. PHILA Subinstruction 2 - 7. PHI2B Low byte data 1 - 8. PHILB High byte data 1 - 9. PHI2A Instruction 3 - 10. PHILA Subinstruction 3 - 11. PHI2B Low byte data 2 - 12. PHILB High byte data 2 - 13. etc. Notice that the data for instruction 1 follows instruction 2. This provides for certain pipelining requirements of source rasterop memory cycles. - 3.4.3.2.7.1 External I/D Bus (Interconnect) Devices In addition to the Address Processor and Video Processor chips, the chip select registers are attached to the I/D bus. These devices are write only because the Address Processor chip will always transmit data during an I/D interconnect command. External I/D commands are distinguished from Video Processor chip commands by a zero in bit <7> of the instruction byte. The subinstruction is undefined during external I/D instructions and so is not of use to an external device. The external register numbers for the chip select registers are: - o Update Chip Select = 60L - o Scroll Chip Select = 40L The logic that controls the loading of the chip select registers decodes the instruction byte which is present only during PHI2A cycles. The logic synchronizes to the PHI1/PHI2 A/B cycles by using SYNC, which always occurs during a PHI2B cycle. 3.4.3.2.8 Chip Selects - Each Video Processor chip has a chip select pin that controls whether or not it responds to I/D bus instructions and through the PE pin and write enable logic, whether it allows writing in its associated memory during rasterops. An unencoded pint from a chip select register is provided for every Video Processor in a VCB02 video subsystem. This allows any combination of Video Processor chips to be enabled. Chip selects are sensed by the Video Processor chip only during the instruction cycle (PHI2A). Because the scroll process needs to access the Video Processor chips without disturbing the update process, it requires a separate set of chip selects. The scroll chip selects are provided by a register connected to the I/D bus. - 3.4.3.2.9 Memory Address Bus The bitmap address bus is common to all bitmap planes. There are two groups of pins from the Address Processor chip that control the address bus to the bitmap memory: - The MEMAD. WE and SCROLL pins are clocked by the ADDCLK pin. The MEMAD pins provide one row address and one column address for each 16 bit (minor) cycle and one row and eight column addresses for each 128 bit (major) cycle. A valid set of write enables and a scroll are provided for each column address. The -WE pins are only meaningful during write cycles. The SCROLL pin is only meaningful for 128 bit read cycles. ADDCLK has a high interval that includes the first 30 nsec of the PHI2B that starts a major cycle (or pair of minor cycles). The rising edge of the pulse that includes this interval brings the first column address (or only column address for a minor cycle) from the Address Processor chip. The previous pulse fetches the row address and the following pulses (for a major cycle) fetch additional column addresses. There are nine cycles of ADDCLK in a major cycle and two cycles of ADDCLK in a minor cycle. ADDCLK is the same for reads as for writes. The series of column addresses in a major cycle form a sequential up count. The MEMADs are latched externally to the Address Processor chip (on the 4-Plane Module) to deskew the propagation delay of the Address Processor chip to obtain tight memory timing. This latch is also clocked by ADDCLK, so that the last column address of the previous cycle is going to the memory while the row address of the next cycle is coming from the Address Processor chip. Similarly, the row address is applied to the memory while the first column address is fetched from the chip. The SCROLL pin indicates memory words that are contained in the scroll region. It comes out of the Address Processor chip with the address of the associated word and is latched along with the MEMADs. But it is accepted by the Video Processor chip as if it were data coming from the memory, so it is delayed further so that it matches the data timing. # NOTE The scroll pin from the Address Processor chip does NOT connect directly to the scroll pin of the Video Processor chip. 2. 128/-16, R/-W and FORCE are provided by the Address Processor chip on the PHI2A that precedes the PHI2B that starts each major cycle (or pair of minor cycles). These pins warn the clock generator of the type of cycle that should be generated next. A 16 bit write cycle means that a 16 bit read-modify-write cycle is next which will contain both read and write portions. #### NOTE The 128/-16, R/-W pins from the Address Processor chip do NOT connect directly to the 128/-16, R/-W pins of the Video Processor chip. The force pin indicates major cycles in a frame which is down scrolling. 3.4.3.2.9.1 Memory Address Bit Assignments - The sequence of address outputs at the MEMAD<10:0> pins of the Address Procesor is a function of the bus width and memory configuration bits in the X Scan Configuration register of the Address Processor chip. The X and Y address bits are multiplexed out at row and column times for the memory in such a way that memory refresh is guaranteed by keeping the fastest moving X and Y addresses in the low 8 row addresses. Table 3-1 lists the address bits which are numbered according to their significance in address calculations. The lowest four X address bits (not shown in Table 3-1) access pixels within a memory word in the 16 bit bus width mode used by the VCBO2. The VCBO2 does not use address bit 10. Table 3-1 Multiplexed MEMAD<10:0> Bits | "Greater than | | • | | | | | |-------------------------|------|---|------|------|------|------| | MEMAD bit | <br> | | <br> | <br> | <br> | <br> | | Row time<br>Column Time | | | | | <br> | <br> | On the VCB02 these addresses are mapped with an external multiplexer to generate the row and coulmn addresses for the memories as shown in Table 3-2. Note that ll bits of Y are used for a total of 2048 scan lines of memory. The low four bits of X (X0 through X3) are not used since data is accessed 16 bits at a time. X4 is not used in the address bits supplied to the memories but is used to multiplex between two banks of memory. Five bits of X are supplied to the memories as address. This results in 1024 pixels on a scan line (16 x 2 x 32 = 1024). The VCB02 memory is organized as 1024 horizontal by 2048 vertical pixels. Table 3-2 Memory Address Bits | Address Bit | 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------------------|---|-----------|---|---|----------|---|---|---|---| | Row Address<br>Column Address | | X9<br>Y10 | | | Y2<br>Y8 | | | | | 3.4.3.2.9.2 Memory Refresh - Memory refresh is accomplished by the screen refresh process For each horizontal scan 8 unique row addresses are generated. To generate a complete sequence of 256 row addresses 32 scans must occur. The VCB02 displays 864 scans which is a multiple of 32 so there are no incomplete sequences of 256 row addresses at the bottom to the displayed screen. For the VCB02 a complete 256 address sequence is completed in less than .6 msec. This is far less than the 4 msec required by the dynamic memory. However, no refresh is accomplished during vertical retrace. Therefore, the worst case time to complete a refresh (1.263 usec) is the refresh period (593 usec) plus the vertical retrace time (36 scan lines = 667 usec). **3.4.3.2.9.3** Memory Configuration - The VCB02 video subsystem was designed to work with 64Kx4 dynamic RAMs (with page mode access). The data rate during major cycles requires approximately 90 nsec cycles. To achieve this data rate two banks of RAM are multiplexed. Since the VCB02 has two screens of memory per plane 64Kx4 RAMs are arranged in even and odd banks (of 4 chips each) with successive major cycle words accessing alternate banks (selected by address bit X 4). 3.4.3.2.10 Memory Data Bus - The memory data lines for each plane are connected to the Video Processor data lines through a transceiver with integral transparent latch. The latch is held open to pass data directly to or from the memory during minor (16 bit) cycles with the direction controlled by R/-W. The latch is used during major (128 bit) cycles to extend the hold time of memory data. The latch is clocked by LTCLK. The type of memory cycle in the Video Processor is controlled by the 128/-16 and R/-W pins. These pins are changed at the time of the PHI2B clock that starts each major or minor cycle. If the minor cycle is a read-modify-write (signaled from the Address Processor chip as a 16 bit write), the R/-W pin initially indicates a read and at the appropriate time in the cycle, changes to a write to latch data and reverse the bus. #### NOTE The 128/-16, R/-W pins from the Address Processor chip do NOT connect directly to the 128/-16, R/-W pins of the Video Processor chip. The memory data bus is controlled differently for major and minor cycles. Major cycles - The clocking of data is controlled by LTCLK. During 128 bit reads, data is latched in the Video Processor on the falling edge of LTCLK. During 128 bit writes, data propagates from the Video Processor on the rising edge of LTCLK. The timing of LTCLK is different for 128 reads and writes. During 16 bit cycles, LTCLK continues to run using the 128 read cycle timing. The scroll signal is applied to the Video Processor along with each corresponding memory word during 128 bit reads. - 2. Minor cycles During a 16 bit read, data is latched in the Video Processor chip on the falling edge of the PHI2A in the middle of the cycle. During a read-modify-write, data is latched by the earlier of R/-W falling or PHI2A falling. The falling edge of R/-W will cause the Video Processor to reverse its direction and enable write data. - 3.4.3.2.11 Write Enable Circuits The write enables of the bitmap memories are used by the clipping and scrolling logic to selectively write memory words and parts of words. In a VCB02 video subsystem, the write enables are arranged in groups of four adjacent bits, separately for each plane. This allows clipping/scrolling to boundaries at each multiple of four bits horizontally and also allows each plane to be independently enabled for rasterops or scrolling. These groups of write enable pins are controlled by a logical combination of signals from four sources. - 1. The four -WE pins from the Address Processor chip provide the write enables for each nibble of each 16 bit word associated with each column address. The -WE signals are latched externally on ADDCLK, similar to the MEMAD signals. The write enables are futher delayed to match required memory timing. These signals provide the four bit resolution in the clipping and scrolling boundaries and are used by the write enable logic for each plane. - 2. The PE pin from each Video Processor chip is used for the write enable logic of only the associated plane to enable or disable rasterops or scrolling for that plane. rasterops, the PE pin responds to the state of chip select that is present during each I/D instruction of the rasterop. It follows the associated bit of the update (not scroll) chip select register. For scrolling, the PE pin is controlled by the scroll enable bit in the Video Processor chip SCROLL CONSTANT register. le; The FORCE pin from the Processor chip is delayed until the rising edge of PHI2B starts a major (or minor) cycle and then combined in the write enable logic of all planes. This pin is asserted during major cycles if down scrolling is active anywhere in the frame. This signal is used to force writing in planes where scrolling is disabled (because ALL data, rather than no must actually move in these planes during down scrolling). Thus writing is disabled in any plane where PE is not asserted, UNLESS both FORCE is asserted AND PE is not asserted. 3. The write enable logic also uses high speed clocks to generate the high resolution edges in the final write enable waveforms. 3.4.3.2.12 Video Bus and Video Output Circuits - The video bus from the Video Processor chip is clocked by ALPHA and provides data on every clock. The data is deskewed by a short setup time shift register on the next 60 nsec edge. Ultimately, the four bit video data is shifted in a serial stream through acolor map, and digital to analog converter and sent to the video monitor. The BLANK and CMPSYN signals from the Address Processor chip are precision outputs that provide the Address Processor composite video blanking and composite synchronization of the monitor. These signals are generated with 60 nsec resolution and are normally deskewed with the video data. Because the BLANK output is only programmable in 60 nsec increments, external pipelining is used to insure the blank signal matches the higher resolution video signal, so that the correct pixels are blanked and unblanked. #### 3.4.3.3 Initialization INIT pin resets the operational aspects of the chip: stops rasterops, clears FIFOs, resets status bits and clears the interrupt enable registers. This is different from the system SYNC pin which resets timers and counters. #### 3.5 DMA GATE ARRAY The DMA Gate Array will provide a complete DMA QBus interface, Address Processor display list processing using the Template RAM, hardware cursor support, and I/O decode including interrupt handling. The DMA gate array (DC 7035) is a semicustom integrated circuit constructed using double level metal HCMOS Gate Array technology, packaged in a ceramic 120 PGA (Pin Grid Array). The DMA gate array was designed to provide a specialized DMA engine that interfaces the QBUS to the Address Processor chip and assists in the execution of video display lists and the transfer of bitmap data. A display list is merely a sequence of commands and data that effect the desired video operation when executed by the Address Processor chip. By using the DMA engine provided by the DMA Gate Array, the MicroVAX CPU need only create the display list and initiate the DMA process. This frees the MicroVAX CPU from the burden of transferring the data to the Address Processor chip and monitoring the execution of the display list. Display lists transferred and executed by the DMA gate array are referred to as DMA Display Lists. The gate array provides dedicated address and control signals for the Address Processor chip. The data is transferred from/to the QBUS through the gate array to/from a second 16 bit data bus called the Private Bus. The Private Bus is shared by the DMA Gate Array, the Address Processor chip, and external RAM called the Template RAM. The Template RAM is partitioned into three segments. The first 64 words are reserved as a FIFO for the DMA process. The last 32 words are used to store cursor bitmap data. The remainder of the Template RAM is used to store display list routines, particularly those routines common to many applications. Display lists stored in the Template RAM are referred to as Template Display Lists. Special commands have been designed to allow Template Display Lists to be called from DMA Display Lists. Commands have also been provided that allow Template Display Lists to fetch commands and data from the DMA Display List data stream (from the FIFO). As a result, routines stored in the Template RAM can serve as command 'templates' that fetch variable data from the FIFO. By using Template Display List routines the number of commands that must be transferred in a DMA Display List can be minimized. Fewer bus cycles are required to transfer the reduced DMA Display List, therefore, overall system performance is improved. The DMA gate array provides dedicated address and control signals for the Template RAM. In addition to the DMA engine, the DMA gate array includes an interrupt controller, address decoding logic, and video cursor logic. The interrupt controller provides masks, generates a variable interrupt vector (the vector base is programmable), and resolves interrupt priorities for three interrupt sources. One interrupt comes from the internal DMA logic. The interrupt outputs of the Address Processor chip and the Communications Controller chip on the VCB02 Base Module are connected to two interrupt input pins provided by the DMA Gate Array. The address decoding logic provides various chip enables for a 56 kb memory address block. Enable signals are provided for external ROM, the Template RAM, the Address Processor chip, and an external address decoder. The base of the 56 kb address block is programmable to any 64 kb boundary in the QBUS memory address space. The cursor logic generates a two plane, 16 by 16 pixel, bitmap cursor. Cursor data is read from the Template RAM during the horizontal sync interval. The start address of the cursor is programmable to any pixel location and may be positioned off the active screen refresh area. The gate array outputs the cursor data at the appropriate time every fourth VCB02 video pixel clock. The data is output as two four bit words. The following sections detail the operation of the DMA Gate Array. #### 3.5.1 Address Decoding A power reset disables the address decoder in the DMA Gate Array. To enable the address decoder, a value must be written to the I/O Page Control Status Register (CSR) decoded external to the gate array by logic on the Base Module. When this address is detected, the external decoder asserts the CONSEL L signal pin on the gate array. If the cycle is a write cycle, the DMA gate array writes the bus data into it's Memory Base Register, asserts the signal pin RPLYO H, and enables it's address decoding logic. If the cycle is a read cycle, the gate array asserts RPLYO H and the contents of the external I/O Page CSR are output (the gate array does not drive the data lines). The value written into the Memory Base Register selects the starting address, or base address, of a 56 kb block of addresses to be decoded by the DMA gate array. The base address is always on a 64 kb boundary in the QBUS Memory Address Space. All locations in this 56 kb block are word addressable only. The DMA gate array segments the 56 kb block of addresses and generates enable signals as shown in Figure 3-44. The gate array asserts RPLYO H during any cycle that accesses any location in the 56 kb address block. All addresses can be expressed as the sum of the QBUS MEMORY BASE and the VCB02 MEMORY BASE and the OFFSET (offset within the selected 56 kb block). The QBUS MEMORY BASE is the system address of the first location in the 4 Mb QBUS memory address space. The VCB02 MEMORY BASE is the offset of the first location of the VCB02 memory address space within the QBUS memory address space. The VCB02 MEMORY BASE is selected by the value written to the Memory Base Register. ## 3.5.1.1 ROMENB Decode When any location in the first 32 kb (offset 0000 Hex to 7FFF Hex) of the 56 kb address block is accessed, the DMA Gate Array asserts the signal pin ROMENB L. ROMENB L is used as an enable for the external Console Emulation/Diagnostic ROM on the Base Module. The DMA gate array does not drive the bus data lines when ROMENB L is decoded. # 3.5.1.2 RAMOE Decode The DMA gate array asserts the signal pin RAMOE L when a QBUS cycle accesses any location in the next 16 kb (offset 8000 Hex to BFFF Hex) of the 56 kb address block. RAMOE L enables the Template RAM for access. The gate array completes the QBUS cycle by performing the desired operation on the Template RAM. QBUS slave accesses of the Template RAM are allowed at any time and temporarily halt any display list execution that may be in progress. Execution of the display list resumes when the slave cycle is completed. | ADDRESS | SIZE OF BLOCK | | |----------------------------------------------------|---------------|--------------------------------| | QBUS MEMORY BASE + VCB02 MEMORY BASE + E000 Hex | ++ | <b>&lt;</b> | | | 7 kb | EXTERNAL I/O | | QBUS MEMORY BASE + VCB02 MEMORY BASE + C400 Hex | i | < | | QBUS MEMORY BASE + | 512 bytes | | | VCB02 MEMORY BASE + C200 Hex | + | | | QBUS MEMORY BASE +<br>VCB02 MEMORY BASE + C000 Hex | | ADDRESS PROCESSOR<br>CHIP<br>< | | | 16 kb | TEMPLATE RAM | | QBUS MEMORY BASE + VCB02 MEMORY BASE + 8000 Hex | + | < | | | 32 kb | ROM | | QBUS MEMORY BASE + VCB02 MEMORY BASE + 0000 Hex | + | < 64 kb<br>Boundary | Figure 3-44 Address Map 3.5.1.3 Address Processor Chip Addresses The next 256 word locations (512 bytes, offset C000 Hex to Clff Hex) are reserved for Address Processor chip registers. If one of the Address Processor chip locations is being accessed the gate array completes the QBUS cycle by performing the desired operation on the Address Processor chip. The DMA gate array temporarily halts the execution of display lists to allow QBUS slave accesses at any time. Execution of the display list resumes when the slave cycle is completed. # 3.5.1.4 Gate Array Addresses The next 256 word locations (512 bytes, offset C200 to C3FF Hex) are reserved for registers internal to the DMA gate array. QBUS Address bits AD09 H through AD01 H are decoded as shown in Table 3-3 to select registers. Currently, only 9 register addresses are utilized. Table 3-3 Gate Array Address Decoding QBUS ADDRESS BIT (X = DON'T CARE) # 09 08 07 06 05 04 03 02 01 REGISTER SELECTED X X X X X 0 0 0 0 0 0: CONTROL STATUS REGISTER X X X X X 0 0 0 1 1: 1: DMA ADDRESS COUNTER (15:00) X X X X X 0 0 1 0 2: DMA ADDRESS COUNTER (21:00) X X X X X 0 0 1 1 3: DMA BYTE COUNTER (15:00) X X X X X X 0 1 0 0 4: DMA BYTE COUNTER (21:00) X X X X X X 0 1 0 1 5: FIFO REGISTER X X X X X 0 1 1 0 6: CURSOR X POSITION REGISTER X X X X X X 0 1 1 1 7: CURSOR Y POSITION REGISTER X X X X X X 1 0 0 0 0 8: COUNTER PROBITER \_\_\_\_\_ #### 3.5.1.5 IOENB Decode If a location in the next 7 kb (offset C400 Hex to DFFF Hex) of the 56 kb address block is accessed, the DMA gate array asserts the signal pin IOENB L. IOENB L is used as an enable for an external decoder on the Base Module that segments the 7 kb address block to provide register space for the Communications Controller, the Memory Page Control Status Register, and the color maps (red, green and blue). The DMA gate array does not drive the data bus lines when IOENB L is decoded. # 3.5.2 DMA Engine The DMA logic provided by the DMA gate array can perform three basic types of DMA transfers. They are: - Processor to bitmap transfers (PTB) - 2. Bitmap to processor (BTP) - 3. Display list transfers The BYTE ENABLE bit (08), DMA MODE 0 bit (09), and the DMA MODE 1 bit (10) in the Control Status Register (CSR) select the type of DMA transfer to be performed. These bits should not be modified unless the DMA Byte Counter is zero AND the FIFO is empty. For each DMA process, the QBUS start address of the data and the number of bytes to be transferred must be loaded into the 22 bit DMA Address Counter and the 22 bit DMA Byte Counter by the MicroVAX CPU. Two registers are provided for each counter. load the DMA Address Counter the low word (16 bits) must be written to register 1 (DMA Address Counter (15:00)) first, then, the remaining 6 bits must be written to register 2 (DMA Address Counter (21:16)). Similarly, to load the DMA Byte Counter the low word (16 bits) must be written to register 3 (DMA Address Counter (15:00)) first, then, the remaining 6 bits must be written to register 4 (DMA Byte Counter (21:16)). Loading DMA byte counter starts the DMA process and should therefor be loaded last. Once the DMA process has been initialized, the DMA Gate Array completes the selected DMA operation without any assist from the MicroVAX CPU. The Control Status Register DMA DONE bit (15), DMA ERROR bit (07), SLAVE PARITY ERROR bit (06), and BUS TIMEOUT bit (05) provide status information on the DMA process (see the Control Status Register description for more detail). If CSR bit 01 (DMA INTERRUPT ENABLE) is set, the DMA gate array interrupts the CPU if any of the DMA status bits become set (one of the bits must transition from a 0 to a 1 to generate the interrupt). Whenever the DMA gate array is the bus master and the slave device is a non-block mode device, the gate array transfers a minimum of 4 words (unless the DMA Byte Counter is less than 4). During the fourth word transfer the gate array checks the QBUS DMA request signal (signal pin DMRI H). If no other device is requesting bus mastership (DMRI H is not asserted), the gate array continues transferring data up to a maximum of 8 words. When the DMA gate array is the bus master and the slave device supports block mode transfers, the gate array does a minimum of 8 word transfers (unless the DMA Transfer Counter Register is less than 8). If no other device is requesting bus mastership during the eighth transfer, a maximum of 16 word transfers are performed. Each byte or word that is transferred via DMA by the DMA Gate Array passes through a 64 word FIFO. The FIFO registers are actually the first 64 word locations of the Template RAM. The gate array maintains two pointers into the ram that control the loading and unloading process. The MicroVAX CPU can access the FIFO by addressing register 5 (FIFO Register). When the MicroVAX CPU accesses the FIFO register, the appropriate pointer (read or write) is incremented and used as the address for the Template RAM cycle. FIFO data passes through the DMA gate array to the QBUS. The MicroVAX CPU can determine how many words are in the FIFO by reading register 2 (DMA Address Counter (21:16)). Bits 08 through 13 of register 2 indicate the number of words in the FIFO (0 = EMPTY, 63 = FULL). The MicroVAX CPU can access the FIFO locations directly by addressing the first 64 words in the Template RAM. Accessing the FIFO by addressing the Template RAM does not affect the FIFO pointers. The MicroVAX CPU should not access the FIFO register or modify any of the FIFO locations by addressing the Template RAM unless there is no active DMA process. The MicroVAX CPU can be used to load/unload the FIFO instead of the DMA Engine provided by the DMA gate array. Once the DMA mode is selected, the DMA gate array transfers the data between the Address Processor chip and the FIFO identically, independent of the loading or unloading method (MicroVAX CPU or DMA). If the Address Processor chip is the DMA destination, the DMA gate array transfers a word out of the FIFO whenever one or more locations are filled provided the the Address Processor chip's DMA request signal (signal pin ADDRQ L) is asserted. If the Address Processor chip is the DMA source and has data ready (signal pin ADDRQ L is asserted), the gate array transfers the data to the FIFO whenever there are at least two free locations. If Bitmap to Processor Byte mode is selected, DMA data can be byte packed as it passes through the DMA gate array. Byte packing takes the low bytes of two consecutive words in the FIFO and 'packs' them into one word for transfer to the QBUS destination. The low byte of the first word read from the FIFO becomes the low byte of the packed word. The low byte of the second word read from the FIFO becomes the high byte of the packed word. The packed word is then transferred to the QBUS destination. If the MicroVAX CPU is used to unload the FIFO instead of the DMA Engine, it must perform the byte packing task. The section on Bitmap to Processor Transfers describes the intended use of byte packing. If Processor to Bitmap Byte mode is selected, DMA data can be byte unpacked as it passes through the DMA gate array. Byte unpacking takes the low byte of a word read from the QBUS and 'unpacks' it into two words for transfer to the FIFO. The low byte of the QBUS word is written to the low byte of the first FIFO location. The high byte of the QBUS word is written to the low byte of the next FIFO location. If the MicroVAX CPU is used to load the FIFO instead of the DMA Engine, it must perform the byte unpacking task. The section on Processor to Bitmap Transfers describes the intended use of byte unpacking. When the QBUS is the DMA source and byte unpacking is disabled, the DMA gate array initiates a DMA transfer only when there are at least 17 free locations in the FIFO. When the QBUS is the DMA destination and byte packing is disabled, the DMA Gate Array initiates a DMA transfer whenever there are at least 16 FIFO locations containing data (except at the end of the DMA process when the DMA Byte Counter is less than 32). Twice as many FIFO locations are used for each QBUS word transferred when byte unpacking is enabled. When the QBUS is the DMA source and byte unpacking is enabled, the DMA gate array initiates a DMA transfer only when there are at least 33 free locations in the FIFO. When the QBUS is the DMA destination and byte packing is enabled, the DMA Gate Array initiates a DMA transfer whenever there are at least 32 FIFO locations containing data (except at the end of the DMA process when the DMA Byte Counter is less than 64). Twice as many FIFO locations are used for each QBUS word transferred when byte packing is enabled. # 3.5.2.1 Processor To Bitmap Transfers Processor to Bitmap DMA mode is selected by setting the DMA MODE 1 bit (10) and resetting the DMA MODE 0 bit (09) of the Control Status Register (CSR). The QBUS is the DMA source and the Address Processor chip is the DMA destination during processor to bitmap transfers. All words transferred are data words that are written to the Address Processor chip IDD Register (Address Processor chip register 7). There are two types of processor to bitmap transfers, single plane and Z-axis transfers. A single plane processor to bitmap transfer moves data from QBUS memory to one bitmap plane (the video memory associated with one Video Processor chip). Each word contains 16 bits that are adjacent horizontally (the end of a horizontal line is adjacent with the start of the next horizontal line). The LSB (bit 0) of the word is the left most pixel in the display and the MSB (bit 15) is the right most pixel. A Z-axis processor to bitmap transfer moves data from the QBUS memory to a single pixel location (each plane receives one bit of the data). Since the VCB02 supports a maximum of 8 planes, two words can be byte packed into one word to reduce the amount of QBUS memory required to store a copy of a multiplane bitmap image. The gate array can unpack the bytes as the data is read from the QBUS. Each byte of the word is stored into separate word locations in the FIFO. The low byte is written to the FIFO first. The high byte is written to the low byte of the next word location in the FIFO. Subsequently, the DMA Gate Array transfers the unpacked data from the FIFO to the Address Processor chip. By using byte unpacking the number of QBUS transfers can be reduced, resulting in higher system performance. Byte unpacking is enabled by setting BYTE ENABLE bit (08) in the Control Status Register. # 3.5.2.2 Bitmap To Processor Transfers Bitmap to Processor DMA mode is selected by resetting the DMA MODE 1 bit (10) and setting the DMA MODE 0 bit (09) in the in the Control Status Register (CSR). The QBUS is the DMA destination and the Address Processor chip is the DMA source during bitmap to processor transfers. All words transferred are data words that are read from the Address Processor chip IDD Register (Address Processor chip register 7). There are two types of bitmap to processor transfers, single plane and Z-axis transfers. All data read from the Address Processor chip is loaded into the FIFO directly. The DMA gate array transfers the data from the FIFO to the selected QBUS location. A single plane bitmap to processor transfer moves data from one bitmap plane (the video memory associated with one Video Processor chip) to QBUS memory. Each word contains 16 bits that are adjacent horizontally (the end of a horizontal line is adjacent with the start of the next horizontal line). The LSB (bit 0) of the word is the left most pixel in the display and the MSB (bit 15) is the right most pixel. A Z-axis bitmap to processor transfer moves data from a single pixel location (each plane contributes one bit of the data). Since the VCB02 supports a maximum of 8 planes two words can be byte packed into one word by the gate array to reduce the amount of QBUS memory required to store a copy of a multiplane bitmap image. The byte packing is performed as the data is being read from the FIFO for transfer to the QBUS. Byte packing takes the low byte of the first word read from the FIFO and saves it in the low byte of a holding register. The low byte of the second word read from the FIFO is written to the high byte of the holding register. The byte packed data in the holding register is then transferred to the QBUS. By using byte packing the number of transfers on the QBUS can be reduced, resulting in higher system performance. Byte unpacking is enabled by setting the BYTE ENABLE bit (08) in the Control Status Register. # 3.5.2.3 Display List Transfers Display List DMA mode is selected by resetting the DMA MODE 1 bit (10) and setting the DMA MODE 0 bit (09) in the Control Status Register (CSR). The QBUS is the DMA source and the Address Processor chip is the DMA destination during display list transfers. Both commands and data may be contained in the words read from the OBUS. The OBUS DMA logic in the DMA gate array transfers words from the QBUS to the FIFO (the first 64 words The transfer of data and commands from the the Template RAM). FIFO to the Address Processor chip is controlled by the display list processor logic in the gate array. As the words are read from the FIFO, the display list processor conditionally decodes If the word is decoded as a display list assist each word. command, the display list processor executes the command as specified in the Display List Commands and Data section. Some display list assist commands are transferred to the Address Processor chip while others are not. All words read from the FIFO that are not recognized as a display list assist command are transferred to the Address Processor chip. Command and data encoding are detailed in the Display List Commands and Data sections. #### 3.5.3 Interrupt Controller The DMA gate array provides a three bit interrupt controller. One interrupt is connected internally to the DMA logic and the other two are connected to the input pins, IRQ1 L and IRQ2 L. On the VCB02 Base Module IRQl L is connected to the Address Processor chips interrupt output and IRQ2 L is connected to the The EXTERNAL Communications Controller Communications Controller interrupt output. The EXTERNAL INTERRUPT ENABLE bit (02) of the Control Status Register (CSR) interrupt output. masks the external interrupts when set. The DMA INTERRUPT ENABLE bit (01) in the CSR masks the internal DMA interrupt when set. When the mask is set the interrupt(s) is(are) ignored. If any of the interrupts are asserted and are not being masked the gate array asserts IRQ L (interrupt output). An external interrupt is asserted by generating a high to low transition on the input pin and maintaining the low level until the interrupt has been acknowledged. The DMA interrupt asserts if the slave device reports a memory parity error (CSR bit 06), or a bus timeout condition occurs CSR bit 05). The DMA interrupt is also asserted when the DMA DONE bit, Control Status register bit 15, is set. During a QBUS interrupt acknowledge cycle the gate array latches the three interrupts when DIN H is asserted. If none of the interrupts are asserted the gate array asserts IAKO H when IAKI H is asserted. If a nonmasked interrupt is asserted when IAKI H is received, the gate array outputs a priority encoded interrupt vector, assert RPLYO H, and clear the highest priority interrupt. Bits 00, 01, and 09 through 15 of the interrupt vector are always 0 during an interrupt acknowledge cycle. Bits 04 through 08 of the vector are programmable by writing to the Interrupt Register. Bits 02 and 03 of the vector are encoded according to the the highest priority interrupt that is asserted and unmasked as shown in Table 3-4. The Interrupt Register is readable. While the vector register is being read the interrupts are latched, and are read on bits 12 through 15 of the Vector Register (see the section on the Interrupt Register). Table 3-4 Interrupt Register Vector Bits 02/03 | PRIORITY | INTERRUPT | VECTOR BIT | 03 VECTOR | BIT 02 | |--------------------------|-----------------------------|------------|-------------|-------------| | HIGHEST<br>2ND<br>LOWEST | DMA INT<br>IRQ1 L<br>IRQ2 L | ERRUPT | 0<br>0<br>1 | 0<br>1<br>0 | | | NONE | 1 | | 1 | # 3.5.4 Cursor Logic The cursor logic generates a two plane ('A' and 'B' plane), 16 by 16 pixel, bitmap cursor for use by external video output logic. The cursor data can be enabled for output at any pixel location, and may be positioned on or off of the screen (i.e. on = active video, off = video blanking). The CURSOR ENABLE bit (00) in the Control Status Register (CSR) enables the output of cursor data when set. The position is selected by the values written to the Cursor X Position Register and the Cursor Y Position Register. The X Position Register and the Y Position Register should only be modified during the vertical sync period or when the CURSOR ENABLE bit (00) in the CSR is reset (cursor is disabled). The Y Position Register is loaded into an up counter (requires two's complement data) on the second horizontal sync pulse during the vertical retrace period (BLANK H remains asserted for at least two horizontal sync periods). The Y counter is incremented by the trailing edge of BLANK H (the start of each active video line). The contents of the Y counter are checked on the leading edge of CSYNC H (during the horizontal retrace period preceeding the next scan line). If the CURSOR ENABLE bit (00) in the CSR is set, and all except the four least significant bits of the Y counter are set, the cursor is enabled for output on the new display line and two cursor data words (16 bits) are read from the Template RAM. The last 32 locations of the Template RAM are reserved for cursor bitmap data. The first 16 of these words are cursor 'A' data, the last 16 words are cursor 'B' data. The least significant 4 bits of the Y register select which Cursor 'A' and Cursor 'B' word to read. As the Y counter is incremented by succeeding scan lines the address of the Cursor A and Cursor B data words increments (as the monitor is scanned from top to bottom, the cursor data is output from lowest address to highest address). The reading of cursor data has the highest priority when competing for cycles on the private bus (i.e. display list execution, QBUS DMA and QBUS slave cycles, and display list execution are all lower priority). When the cursor data is enabled for output on a display line, the X counter determines the position on the line that the data is output. Bits 02 through 10 of the X Position Register are loaded into an up counter (requires two's complement data) by horizontal sync pulses (present on CSYNC L). The X counter is incremented (effectively by 4 since the X counter begins with bit 02) by CURCLK H (cursor clock). CURCLK H is one fourth the VCB02 video pixel clock frequency. The cursor data is output when all bits of the X counter are set (bits 02 through 10 are all 1). The least significant two bits of the Cursor X Position Register shift the cursor data so that it is pixel aligned (see the description of the Cursor X Position Register for details). The cursor data must be shifted up to speed by shift registers external to the gate array. The shift registers should be loaded synchronously on the leading edge of CURCLK H. ## 3.5.5 Display List Data And Commands The commands described in the following section provide flexibility in the use of the Template RAM as a local store RAM for routines that can be called from DMA Display Lists (display lists transferred from the QBUS by the DMA gate array). In addition to commands that start and stop execution of Template Display Lists (routines stored in the Template RAM), commands have been included that allow data and commands stored in the FIFO to be used by Template Display Lists. One of the commands allows Processor to Bitmap Transfers to be imbedded in a DMA Display List. Each command is described in detail in the following sections. # 3.5.5.1 Display List Data All words in a display list that have bit 14 and 15 reset as show in Figure 3-45 are considered to be display list data by the gate array and are transferred to the Address Processor chip's ADCT register (register 0). Bits 0 through 13 are data bits and may have any value. The Address Processor chip writes the word to the register being selected by it's ADCT register. Display list data can be used in Template Display Lists and DMA Display Lists. | | 15 | 1 | 4 | 13 | 12 | 11 | 10 | 09 | 80 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |---|----|---|----|----|----|----|----|----|-----|----|-----------|-----------|-----------|----|----|----|----| | + | + | | -+ | + | + | | + | | ++ | | <b></b> - | + | + + | + | + | + | + | | | | | | | | | | | D08 | | | | | | | | | | + | + | | -+ | + | + | | + | | + | | <b></b> | <b></b> - | <b></b> + | + | + | + | + | Figure 3-45 Display List Data #### 3.5.5.2 JMPT @ ADDRESS Command The JMPT @ ADDRESS command has bits 15 and 13 reset, and bit 14 set as shown in Figure 3-46. When executed by the display list processor, the JMPT @ADDRESS command loads the word address (A01 through 13) contained in bits 0 through 12 into an address counter in the gate array, called the Template Address Counter. If the address bits A07 through A13 are reset, the display list processor resumes execution of the display list contained in the If any of the address bits A07 through Al3 are set, the display list processor executes the Template Display List at the specified address. This command provides the ability to 'call' a Template Display List from a DMA Display list, to 'jump' within Template Display Lists, and, to end the execution of the Template display list and return to execution of the DMA Display list in the FIFO. The JMPT @ADDRESS command is not transferred to the Address Processor chip. Figure 3-46 JMPT @ ADDRESS (Jump To Template @ Address) #### 3.5.5.3 PTB NWORDS Command The PTB NWORDS command has bits 15 reset, and bits 14 and 13 set as shown in Figure 3-47. Bits 00 through 12 (N00 through N12) are a two's complement count value. When executed by the display list processor, the PTB NWORDS command loads the count into a counter in the gate array. The command is not transferred to the Address Processor chip. The gate array transfers the next N words (N is the count value) from the FIFO directly to the Address Processor chip's IDD Register (register 7). Display list execution resumes from the FIFO (even if the PTB NWORDS command was executed from a Template Display List). The PTB NWORDS command allows Processor to Bitmap transfers of up to 8 Kw to be imbedded in a DMA Display List. However the data must not be byte packed. Figure 3-47 PTB NWORDS (Processor To Bitmap Transfer Number Of Words) # 3.5.5.4 Other Display List Commands All other display list commands that are recognized by the DMA Gate Array are encoded in bits 12 through 15 of the word as diagrammed in Figure 3-48. Bits 00 through 11 of the word may be used as data for loading the Address Processor chips ADCT Register (The Address Processor chip only uses bits 00 through Bits 06 through 11 are reserved by Digital). All commands must have bit 15 set. All commands that have bit 14 cleared are transferred to the Address Processor chip causing the ADCT Register to be loaded (caused by bit 15 being set, see Address Processor chip documentation). When bit 13 of the command word is set, the Display List Processor logic fetches the next word from the FIFO (the word may be data or a command). Bit 12 disables the command decoding of the next word fetched by the Display List Processor logic (allows 16 bit data to use bits 11 through 15). Although many combinations of bits 12 through 15 are anticipated to be useful in the execution of display lists, some combinations of these bits may not be. | ++<br>15 | COMMAND | |----------|----------------| | 14 | WRITE DISABLE | | 13 | READ FIFO | | 12 | DECODE DISABLE | | 11 | DATA BIT 11 | | 10 | DATA BIT 10 | | 09 | DATA BIT 09 | | 08 | DATA BIT 08 | | 07 | DATA BIT 07 | | 06 | DATA BIT 06 | | 05 | DATA BIT 05 | | 04 | DATA BIT 04 | | 03 | DATA BIT 03 | | 02 | DATA BIT 02 | | 01 | DATA BIT 01 | | 00 | DATA BIT 00 | Figure 3-48 Other Display List Commands # 3.5.6 Register Descriptions The following sections describe the usage of each bit of all registers in the DMA gate array that are accessible from the QBUS. All registers are word accessible only. # 3.5.6.1 Control Status Register (REGISTER 0) The Control Status Register (CSR) provides various control and status bits for the various functions that the DMA Gate Array provides. Each bit is described in detail in Figure 3-49. | READ ONLY | 15 | DMA DONE | |------------|----|---------------------------| | READ/WRITE | | DONE SELECT | | READ ONLY | | RESERVED | | READ ONLY | 12 | RESERVED | | READ ONLY | - | RESERVED | | READ/WRITE | - | DMA MODE BIT 1 | | READ/WRITE | 09 | DMA MODE BIT 0 | | READ/WRITE | | BYTE ENABLE | | READ/WRITE | 07 | DMA ERROR | | READ ONLY | | SLAVE PARITY ERROR | | READ ONLY | | BUS TIMEOUT ERROR | | READ/WRITE | 04 | CURSOR TEST ENABLE | | READ/WRITE | | DMA TEST ENABLE | | | • | EXTERNAL INTERRUPT ENABLE | | | | DMA INTERRUPT ENABLE | | READ/WRITE | | CURSOR ENABLE | | | | | Figure 3-49 CSR Register Bitmap In explanation of Figure 3-49: ### BIT 15: DMA DONE The DMA DONE bit (15) is reset whenever the DMA Byte Counter is not zero. The DMA DONE bit (15) is also reset whenever the DONE SELECT bit (14) is set AND the FIFO is not empty. READ ONLY The DMA DONE bit (15) is set whenever the DMA Byte Counter is zero and the FIFO is empty. The DMA DONE bit (15) is also set whenever the DONE SELECT bit (14) is reset AND the DMA Byte Counter is zero. Asserting the signal pin QINIT H sets the DMA DONE bit (15). Writing the DMA DONE bit (15) has no effect. BIT 14: DONE SELECT READ/WRITE The DONE SELECT bit (14) selects the conditions that enable the DMA DONE bit (15) to be set. Writing a 0 to the DONE SELECT bit (14) enables the DMA DONE bit (15) to be set whenever the DMA Byte Counter is zero. The DMA Byte Counter must be zero AND the FIFO must be empty to set the DMA DONE bit (15) if a 1 is written to the DONE SELECT bit (14). See the description for CSR bit 15 above. Asserting the signal pin QINIT H resets the DMA SELECT bit (14). BIT 13: RESERVED READ ONLY CSR bit 13 is reserved for future use. Writing bit 13 has no effect. When the CSR is read, bit 13 is always zero. BIT 12: RESERVED READ ONLY CSR bit 12 is reserved for future use. Writing bit 12 has no effect. When the CSR is read, bit 12 is always zero. BIT 11: RESERVED READ ONLY CSR bit ll is reserved for future use. Writing bit ll has no effect. When the CSR is read, bit ll is always zero. BIT 10: DMA MODE BIT 1 READ/WRITE CSR bits 8, 9 and 10 control the operation mode of the DMA Engine. The table below shows the bit settings for the various DMA functions. Asserting the signal pin QINIT H resets bit 10. The DMA MODE 1 bit (10) should not be modified unless the DMA Byte Counter is zero AND the FIFO is empty. BIT 09: DMA MODE BIT 0 READ/WRITE CSR bits 8, 9 and 10 control the operation mode of the DMA Engine. The table below shows the bit settings for the various DMA functions. Asserting the signal pin QINIT H resets bit 9. The DMA MODE 0 bit (09) should not be modified unless the DMA Byte Counter is zero AND the FIFO is empty. BIT 08: BYTE ENABLE READ/WRITE CSR bits 8, 9 and 10 control the operation of the DMA Engine (refer to Table 3-5). The BYTE TRANSFER ENABLE bit (08) is effective during Processor to Bitmap (PTB) and Bitmap to Processor (BTP) transfers only. Setting the BYTE ENABLE bit (08) enables byte packing/unpacking during PTB/BTP transfers (see sections on Processor to Bitmap and Bitmap to Processor Transfers). The BYTE ENABLE bit (08) should not be modified unless the DMA Byte Counter is zero AND the FIFO is empty. CSR bit 10: DMA MODE 1 CSR bit 09: DMA MODE 0 CSR bit 08: BYTE ENABLE Table 3-5 CSR Bits 8, 9, And 10 | CSR 10 | CSR 09 | CSR | 08 DMA FUNCTION | |--------|--------|--------|-----------------------------------------| | 0 | 0 | X | HALT | | 0 | 1 | X<br>0 | DISPLAY LIST BITMAP TO PROCESSOR (WORD) | | i | 0 | ì | BITMAP TO PROCESSOR (BYTE PACKED) | | 1 | 1 | 0 | PROCESSOR TO BITMAP (WORD) | | 1 | 1 | 1 | PROCESSOR TO BITMAP (BYTE UNPACKED) | BIT 07: DMA ERROR READ/WRITE Writing a 0 to CSR bit 07 has no effect. Writing a 1 to CSR bit 07 resets the DMA ERROR bit (07), the SLAVE PARITY ERROR bit (06), and the BUS TIMEOUT ERROR bit (05). The DMA ERROR bit (07) is reset when the SLAVE PARITY ERROR bit (06) AND the BUS TIMEOUT ERROR bit (05) are both reset. Asserting the signal pin QINIT H resets the DMA ERROR bit (07). BIT 06: SLAVE PARITY ERROR READ ONLY If a slave parity error occurs while the DMA gate array is the bus master the SLAVE PARITY ERROR bit (06) and the DMA ERROR bit (07) are set. Writing a one to CSR bit 07, or asserting the signal pin QINIT H clears the SLAVE PARITY ERROR bit (06). Writing CSR bit 06 has no effect. BIT 05: BUS TIMEOUT ERROR READ ONLY If a bus timeout error occurs while the DMA gate array is the bus master the BUS TIMEOUT ERROR bit (05) and the DMA ERROR bit (07) are set. Writing a one to the CSR bit 07, or asserting the signal pin QINIT H clears the BUS TIMEOUT ERROR bit (05). BIT 04: CURSOR TEST ENABLE READ/WRITE Writing a 1 to the CURSOR TEST ENABLE bit (04) enables a special test mode for the cursor logic in the DMA gate array. This test mode is intended for use in device test only. For normal operation, the CURSOR TEST ENABLE bit (04) must be reset. BIT 03: DMA TEST ENABLE READ/WRITE Writing a 1 to the DMA TEST ENABLE bit (03) enables a special test mode for the DMA logic in the DMA gate array. This test mode is intended for use in device test only. For normal operation, the DMA TEST ENABLE bit (03) must be reset. BIT 02: EXTERNAL INTERRUPT ENABLE READ/WRITE Writing a 1 to the EXTERNAL INTERRUPT ENABLE bit (02) enables the signal pins IRQl L and IRQ2 L to generate an interrupt. Writing a 0 to the EXTERNAL INTERRUPT ENABLE bit (02) disables all external interrupts. Asserting the signal pin QINIT H resets this bit. BIT 01: DMA INTERRUPT ENABLE READ/WRITE Writing a 1 to the DMA INTERRUPT ENABLE bit (01) enables the DMA DONE bit (15), or the SLAVE PARITY ERROR bit (06), or the BUS TIMEOUT ERROR bit (05), to generate an interrupt. Writing a 0 to the DMA INTERRUPT ENABLE bit (01) disables all DMA interrupts. Asserting the signal pin QINIT H resets this bit. BIT 00: CURSOR ENABLE READ/WRITE Writing a 1 to the CURSOR ENABLE bit (00) enables the cursor logic to output cursor data. Writing a 0 to the CURSOR ENABLE bit disables the output of cursor data. This bit should be modified only during the vertical retrace period. Asserting the signal pin QINIT H resets this bit. 3.5.6.2 DMA Address Counter (15:00) (REGISTER 1) The DMA Address Counter (15:00) is the low word of the 22 bit DMA address counter provided by the DMA gate array. The low 16 bits of the QBUS DMA source/destination address are loaded into this register. If an odd value is written to the DMA Address Counter the first DMA transfer is a byte transfer and the counter is incremented by 1. If an even value is written to the DMA Address Counter, the first transfer is a word and the counter is incremented by 2. With the exception of the last transfer, all subsequent DMA transfers are word transfers and the counter is incremented by 2. If the DMA Byte Counter is even for the last transfer (byte count =2), the transfer is a word transfer and the DMA Address Counter is incremented by 2. If the DMA Byte Counter is odd for the last transfer (byte count = 1), the transfer is a byte transfer and the DMA Address Counter is incremented by 1. The DMA Address Counter (15:00) overflows into the DMA Address Counter (21:16) when it is at maximum count and is incremented. Whenever the DMA Address Counter (15:00) is written, Address Counter (21:16) must subsequently be written to maintain valid data. The counter should not be written unless the DMA Byte Counter is zero (the QBUS DMA process is complete). The DMA Address Counter (15:00) is readable. Figure 3-50 shows the DMA Address Counter Register 1 bitmap. DMA ADDRESS COUNTER (15:00) READ/WRITE Figure 3-50 DMA Address Counter Register 1 Bitmap 3.5.6.3 DMA Address Counter (21:16) (REGISTER 2) The DMA Address Counter (21:16) is the high 6 bits of the 22 bit DMA address counter provided by the DMA gate array. The high 6 bits of QBUS DMA source/destination address are loaded into this register. The counter is incremented when the DMA Address Counter (15:00) is at maximum count and is incremented. Whenever the DMA Address Counter (15:00) is written, the DMA Address Counter (21:16) must subsequently be written to maintain valid data. The counter should not be written unless the DMA Byte Counter is zero (the QBUS DMA process is complete). The DMA Address Counter (21:16) is NOT readable. Bits 07 through 15 of this register have no effect when written. Figure 3-51 shows the DMA Address Counter Register 2 bitmap. DMA ADDRESS COUNTER (21:16) WRITE ONLY Figure 3-51 DMA Address Counter Register 2 Bitmap 3.5.6.4 DMA Byte Counter (15:00) (REGISTER 3) The DMA Byte Counter (15:00) is the low word of the 22 bit DMA byte counter provided by the DMA gate array. The low 16 bits of the QBUS DMA byte count are loaded into this register. If an odd value is written to the DMA Address Counter, the first DMA transfer is a byte transfer and the byte counter is incremented by 1. If an even value is written to the DMA Address Counter, the first transfer is a word and the byte counter is incremented by 2. With the exception of the last transfer, all subsequent DMA transfers are word transfers and the counter is incremented by 2. If the DMA Byte Counter is even for the last transfer (byte count =2), the transfer is a word transfer and the counter is incremented by 2. If the DMA Byte Counter is odd for the last transfer (byte count = 1), the transfer is a byte transfer and the counter is incremented by 1. The DMA Byte Counter (15:00) overflows into the DMA Byte Counter (21:16) when it is at maximum count and is incremented. Whenever the DMA Byte Counter (15:00) is written, the DMA Byte Counter (21:16) must subsequently be written to maintain valid data. The counter should not be written unless the DMA Byte Counter is zero (the QBUS DMA process is complete). The DMA Byte Counter (15:00) is readable. Figure 3-52 shows the DMA Byte Counter Register 3 bitmap. DMA BYTE COUNTER (15:00) READ/WRITE Figure 3-52 DMA Byte Counter Register 3 Bitmap 3.5.6.5 DMA Byte Counter (21:16) (REGISTER 4) The DMA Byte Counter (21:16) is the high 6 bits of the 22 bit DMA byte counter provided by the DMA gate array. The high 6 bits of QBUS DMA byte count are loaded into this register. The counter is incremented when the DMA Byte Counter (15:00) is at maximum count and is incremented. Whenever the DMA Byte Counter (15:00) is written, the DMA Byte Counter (21:16) must subsequently be written to maintain valid data. The counter should not be written unless the DMA Byte Counter is zero (the QBUS DMA process is complete). The DMA Byte Counter (15:00) is readable. Figure 3-53 shows the DMA Byte Counter Register 4 bitmap. When read, bits 08 through 13 contain the FIFO count (number of words in the FIFO). If the FIFO count is zero, the FIFO is EMPTY. If the FIFO Count is 63, the FIFO is FULL. Reading the DMA Byte Counter (21:16) temporarily halts the execution of display lists. Display list execution resumes when the QBUS read cycle is completed. Bits 07 through 15 of this register have no effect when written. DMA BYTE COUNTER (21:16) | | | ++ | | | |-------|--------|----|------------|---| | READ | ONLY | | RESERVED | | | READ | ONLY | 14 | RESERVED | | | READ | ONLY | | FIFO COUNT | 5 | | READ | ONLY | 12 | FIFO COUNT | 4 | | READ | ONLY | • | FIFO COUNT | 3 | | READ | ONLY | • | FIFO COUNT | 2 | | READ | ONLY | 09 | FIFO COUNT | 1 | | READ | ONLY | 08 | FIFO COUNT | 0 | | READ | ONLY | 07 | RESERVED | | | READ | ONLY | 06 | RESERVED | | | READ, | /WRITE | | C21 | | | READ, | /WRITE | 04 | C20 | | | READ, | /WRITE | 03 | C19 | | | READ | /WRITE | 02 | C18 | | | READ | /WRITE | 01 | C17 | | | READ | /WRITE | | C16 | | | | | | | | Figure 3-53 DMA Byte Counter Register 4 Bitmap ### 3.5.6.6 FIFO Register (REGISTER 5) The FIFO implemented by the DMA gate array uses the first 64 word locations of the Template RAM. The gate array maintains two pointers into the RAM that control the loading and unloading process. The MicroVAX CPU can access the FIFO by addressing register 5 (FIFO Register). When the MicroVAX CPU accesses the FIFO register, the appropriate pointer (read or write) is incremented and used as the address for the Template RAM cycle. FIFO data always passes through the DMA gate array. The MicroVAX CPU can determine how many words are in the FIFO by reading register 2 (DMA Address Counter (21:16)). Bits 08 through 13 of register 2 indicate the number of words in the FIFO (0 = EMPTY, 63 = FULL). The MicroVAX CPU can access the FIFO locations directly by addressing the first 64 words in the Template RAM. Accessing the FIFO by addressing the Template RAM does not affect the FIFO pointers. The MicroVAX CPU should not access the FIFO register or modify any of the FIFO locations by addressing the Template RAM unless there is no DMA process active. Figure 3-54 shows the FIFO Register. FIFO REGISTER READ/WRITE Figure 3-54 FIFO Register ### 3.5.6.7 Cursor X Position Register (REGISTER 6) NOTE The format of the data loaded into the Cursor X Position Register is complex. Read this section CAREFULLY. Bits 02 through 10 of the X Position Register are loaded into an up counter by the first cursor clock pulse (signal pin CURCLK H) after the assertion of the signal pin CSYNC H (i.e. during horizontal sync interval). The second CURCLK H pulse completes the synchronous load of the two's complement value into the X counter. Begining with the third CURCLK H pulse, the X counter is incremented (effectively by 4 since the X counter begins with bit 02) by CURCLK H (cursor clock). CURCLK H is one fourth the pixel frequency. The cursor data is output when all bits of the X counter are set (bits 02 through 10 are all 1). Since the X counter begins counting during the horizontal retrace period an offset must be included in the data loaded into the Cursor X Position Register to position the cursor at the left edge of the active video line (see the algorithm in Figure 3-55). The data loaded into the X counter (bits 02 through 10 of the Cursor X Position Register) must be two's complement data. The least significant two bits of the Cursor X Position Register can NOT be two's complement data. The least significant two bits of the Cursor X Position Register shift the cursor data so that it is pixel aligned (see the algorithm and diagram below). The Cursor X Position Register should only be modified during the vertical sync interval or when the Control Status Register Cursor Enable bit (02) is reset. After modifying the Cursor X Position Register, at least one CSYNC H pulse must occur prior to the start of the first active display line (equalization pulses are required UNLESS a least one blank line occurs after the release of the vertical sync pulse). The Cursor X Position Register can not be read. Writing bits 12 through 15 has no effect. ``` CURSOR X POSITION REGISTER ``` WRITE ONLY ``` PIXEL ALIGNMENT DIAGRAM ``` ``` 1 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 D D D D D D D D D D D D D 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 D|D D D D D D D D D D D D D 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 <---->: ``` X00 = bit 00 of the Cursor X Position Register X01 = bit 01 of the Cursor X Position Register CUR0 = the CURA0 H or CURB0 H outputs of the gate array CUR1 = the CURA1 H or CURB1 H outputs of the gate array CUR2 = the CURA2 H or CURB2 H outputs of the gate array CUR3 = the CURA3 H or CURB3 H outputs of the gate array D0, ..., D15 = bit 0, ..., 15 of the cursor 'A' or 'B' data read from the Template Ram Figure 3-55 Cursor X Position Register 3.5.6.8 Cursor Y Position Register (REGISTER 7) The Y Position Register is loaded into an up counter on the second horizontal sync pulse during the vertical retrace period (BLANK H remains asserted for at least two horizontal sync periods). The Y counter is incremented by the trailing edge of BLANK H (the start of an active video line). The contents of the Y counter are checked on the leading edge of CSYNC H (during the horizontal retrace preceeding the next scan line). If the Control Status Register bit 02 is set, and all except the four least significant bits of the Y counter are set, the cursor is enabled for output on the current display line and two cursor data words (16 bits) are read from the Template RAM. Position Register should only be modified during the vertical sync period or when the Cursor Enable bit (02) in the CSR is reset (cursor is disabled). After modifying the Cursor Y Position Register, at least two CSYNC H pulses must occur prior to the deassertion of BLANK H (the end of the vertical sync blanking interval). The Cursor Y Position Register can not be Writing bits 12 to 15 has no effect. Figure 3-56 shows the Cursor Y Position Register. CURSOR Y POSITION REGISTER WRITE ONLY Figure 3-56 Cursor Y Position Register 3.5.6.9 Interrupt Register (REGISTER 8) The Interrupt Register provides interrupt status to the MicroVAX CPU. When read, the status bits are latched by the assertion of the signal pin DIN H and remain latched until DIN H is removed. By writing the Interrupt Register, the base for the interrupt vector output by the DMA gate array during interrupt acknowledge cycles can be selected (see the Interrupt Controller section). Each bit is described in detail in Figure 3-57. | | ++ | | |------------|----|---------------------| | READ ONLY | 15 | LATCHED IRQ | | READ ONLY | 14 | LATCHED IRQ2 | | READ ONLY | | LATCHED IRQ1 | | READ ONLY | | LATCHED DMA IRQ | | READ ONLY | • | RESERVED | | READ ONLY | 10 | RESERVED | | READ ONLY | 09 | RESERVED | | READ/WRITE | | VECTOR BASE 08 | | READ/WRITE | | VECTOR BASE 07 | | READ/WRITE | 06 | VECTOR BASE 06 | | READ/WRITE | | VECTOR BASE 05 | | READ/WRITE | 04 | VECTOR BASE 04 | | READ ONLY | | INTERRUPT VECTOR 03 | | READ ONLY | 02 | INTERRUPT VECTOR 02 | | READ ONLY | 01 | RESERVED | | READ ONLY | 00 | RESERVED | Figure 3-57 Interrupt Register In explanation of Figure 3-57: #### BIT 15: LATCHED IRQ READ ONLY The LATCHED IRQ bit (15) is set whenever the LATCHED DMA IRQ bit (12), LATCHED IRQl bit (13), or LATCHED IRQ2 bit (14) is set. Writing bit 15 has no effect. Asserting the signal pin QINIT H resets the LATCHED IRQ bit (15). ### BIT 14: LATCHED IRQ2 READ ONLY The LATCHED IRQ2 bit (14) is set whenever the Control Status Register EXTERNAL INTERRUPT ENABLE bit (02) is set and the signal pin IRQ2 L becomes asserted (the Adder chip is requesting interrupt service). Writing bit 14 has no effect. Asserting the signal pin QINIT H resets the LATCHED IRQ2 bit (14). BIT 13: LATCHED IRQ1 READ ONLY The LATCHED IRQl bit (13) is set whenever the Control Status Register EXTERNAL INTERRUPT ENABLE bit (02) is set and the signal pin IRQl L becomes asserted (the Communications Controller is requesting interrupt service). Writing bit 13 has no effect. Asserting the signal pin QINIT H resets the LATCHED IRQl bit (13). BIT 12: LATCHED DMA IRQ READ ONLY The LATCHED DMA IRQ bit (12) is set whenever the Control Status Register DMA INTERRUPT ENABLE bit (01) is set and a DMA interrupt occurs. The DMA interrupt status can be read from the Control Status Register (register 0). Writing bit 12 has no effect. Asserting the signal pin QINIT H resets the LATCHED DMA IRQ bit (13). BIT 11: RESERVED READ ONLY When read, bit ll is always reset. Writing bit ll has no effect. BIT 10: RESERVED READ ONLY When read, bit 10 is always reset. Writing bit 10 has no effect. BIT 09: RESERVED READ ONLY When read, bit 09 is always reset. Writing bit 09 has no effect. BIT 08: VECTOR BASE 8 READ/WRITE Bit 08 of the interrupt vector output by the DMA gate array is selected by writing this bit. VECTOR BASE 8 bit (08) is reset when the signal pin QINIT H is asserted. BIT 07: VECTOR BASE 7 READ/WRITE Bit 07 of the interrupt vector output by the DMA gate array is selected by writing this bit. VECTOR BASE 7 bit (07) is reset when the signal pin QINIT H is asserted. BIT 06: VECTOR BASE 6 READ/WRITE Bit 06 of the interrupt vector output by the DMA gate array is selected by writing this bit. VECTOR BASE 6 bit (06) is reset when the signal pin QINIT H is asserted. BIT 05: VECTOR BASE 5 READ/WRITE Bit 05 of the interrupt vector output by the DMA gate array is selected by writing this bit. VECTOR BASE 5 bit (05) is reset when the signal pin QINIT H is asserted. BIT 04: VECTOR BASE 4 READ/WRITE Bit 04 of the interrupt vector output by the DMA gate array is selected by writing this bit. VECTOR BASE 4 bit (04) is reset when the signal pin QINIT H is asserted. BIT 03: INTERRUPT VECTOR 3 READ ONLY The INTERRUPT VECTOR 3 bit (03) is priority encoded and is determined by the status of the LATCHED DMA IRQ bit (12), LATCHED IRQ1 bit (13), and the LATCHED IRQ2 bit (14) as shown in Table 3-6. Writing bit 03 has no effect. Table 3-6 Interrupt Vector 3 Determination | LAT | CHED<br>2 | LATCHED IRQ1 | LATCHED<br>DMA IRQ | | INTERRUPT<br>VECTOR 3 | INTERRUPT<br>VECTOR 2 | |-----|-----------|--------------|--------------------|---|-----------------------|-----------------------| | X | х | 0 | | 0 | 0 | | | X | 0 | 1 | | 0 | 1 | | | 0 | 1 | 1 | | 1 | 0 | | | 1 | 1 | 1 | | 1 | 1 | | | 1 | 1 | 1 | • | 1 | . 1 | | | | | | | | | | BIT 02: INTERRUPT VECTOR 2 READ ONLY The INTERRUPT VECTOR 2 bit (02) is priority encoded and is determined by the status of the LATCHED DMA IRQ bit (12), LATCHED IRQ1 bit (12), and the LATCHED IRQ2 bit (14) as shown in Table 3-6. Writing bit 02 has no effect. BIT 01: RESERVED READ ONLY When read, bit 01 is always reset. Writing bit 01 has no effect. BIT 00: RESERVED READ ONLY When read, bit 00 is always reset. Writing bit 00 has no effect. ### 3.5.6.10 Memory Base Address Register A power reset disables the address decoder in the DMA Gate Array. To enable the address decoder, a value must be written to the I/O Page Control Status Register (CSR) decoded external to the gate array by logic on the Base module. When this address is detected, the external decoder asserts the CONSEL L signal pin on the gate array. If the cycle is a write cycle, the DMA gate array writes the bus data into it's Memory Base Register, asserts the signal pin RPLYO H, and enables it's address decoding logic. If the cycle is a read cycle, the gate array asserts RPLYO H and the contents of the external I/O Page CSR are output (the gate array does not drive the data lines). The value written into the Memory Base Register selects the starting address, or base address, of a 56 kb block of addresses that are decoded by the DMA gate array. The base address is always on a 64 kb boundary in the QBUS Memory Address Space as selected by bits 00 through 05 of the Memory Base Register. Bits 05 through 00 are compared with the signal pins A(21:16) H during the address portion of QBUS memory cycles. Figure 3-58 shows the Memory Base Register bitmap. Figure 3-58 Memory Base Register Bitmap ### 3.5.7 Signal Description The signal pins on the DMA gate array can be separated into seven groups as listed in Table 3-7. The following sections describe the signals in each category. A functional description is given for each signal. # Table 3-7 DMA Gate Array Signals | Signal | Description | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | QBUS INTERFACE | The signals needed to interface to the QBUS both as a slave and master device. | | ADDRESS DECODES | These signals are decoded from the QBUS address lines whenever the DMA Gate Array is not the bus master. They can be used for selecting devices that need to be interfaced to the QBUS. | | INTERRUPT INPUTS | These are inputs that may be connected to interrupt sources external to the DMA gate array. | | ADDRESS PROCESSOR<br>CHIP INTERFACE | These are the address and control signals need to interface to the Address Processor chip. | | TEMPLATE RAM INTERFAC | E These are the address and control signals for the Template RAM. | | PRIVATE DATA BUS | This is a 16 bit bidirectional data bus that connects the DMA gate array, the Template RAM and the Address Processor chip. | | CURSOR SIGNALS | These are the cursor data outputs and the signals that control the timing of the cursor logic. | | MISCELLANEOUS SIGNALS | These are the signals common to the entire gate array and are not associated to any one group of signals. | #### 3.5.7.1 QBus Interface The signals described in this section are provided by the DMA gate array for interfacing to the QBUS. AD(15:00) H ADDRESS/DATA (input/output, 3-state) These multiplexed address and data lines are used for both master and slave cycles on the QBUS. During the address portion of a DMA transfer (master) cycle, the DMA gate array outputs the lower 16 bits of the DMA destination address on AD(15:00) H. When the gate array is a QBUS slave device, it latches the address infromation received on AD(15:00) when SYNC H is asserted. During the data portion of a QBUS cycle, these lines contain read or write data, depending on the type of transfer. Bits AD(15:08) are defined as the HIGH BYTE and bits AD(07:00) are the LOW BYTE of data. If the DMA Gate Array is the bus master, it outputs data on AD(15:00) during data out cycles (DOUT H asserted) and receives data on AD(15:00) during data in cyles (DIN H) asserted. If the Template RAM, the Address Processor chip, or a gate array register is being addressed during a slave cycle, the gate array receives data on AD(15:00) during data out cycles (DOUT H asserted) and drives data on AD(15:00) during data in cycles (DIN H asserted). ### A(17:16) H ADDRESS/PARITY (input/output, 3-state) During the address portion of QBUS cycles, these two lines are used as address lines. If the gate array is not the QBUS master (not performing DMA transfers), A(17:16) H are compared with bit 01 and bit 00 of the Memory Base Register (respectively). If the bits are not equal when SYNC H is asserted, the address decode logic is disabled. The DMA gate array drives addresses on these lines only during the address protion of cycles when it is the QBUS master (during DMA transfers). When the gate array is the Bus Master performing a data out cycle (DOUT H asserted) A(17:16) H are driven to the deasserted state (they are zero) during the data protion of the cycle. When gate array is a QBUS slave device responding to a data in cycle (DIN H asserted) it drives A(17:16) H to the deasserted state (this disables memory parity detection). The gate array receives these lines at all other times. When the DMA gate array is performing a DMA read cycle (DIN H asserted), these A(17:16) H are used to check for slave memory parity errors during the data protion of the cycle. A slave device asserts bit Al7 H to inform the gate array (the bus master) that it has parity error detection logic. If a parity error occurs on the slave memory device, the slave asserts bit Al6 H to indicate the error. A(21:18) H ADDRESS (input/output, 3-state) During the address portion of QBUS cycles, these lines are used as address lines. The DMA gate array outputs addresses on these lines only during the address protion of cycles when it is the QBUS master (during DMA transfers). When the gate array is the bus master performing a data out cycle (DOUT H asserted) A(21:18) H are driven to the deasserted state (they are zero) during the data portion of the cycle (this disables bus parity detection). When the gate array is a QBUS slave device responding to a data in cycle (DIN H asserted) it drives A(21:18) H to the deasserted state. The gate array receives these lines at all other times. If the gate array is not the QBUS master (not performing DMA transfers), A(21:18) H are compared with bit 05, bit 04, bit 03, and bit 02 (respectively) of the Memory Base Register. If the bits are not equal when SYNC H is asserted, the address decode logic is disabled. BS7 H BANK SELECT 7 (input/output, 3-state) During the address portion of QBUS cycles, BS7 H is asserted if the QBUS I/O page is being addressed. During the data protion of QBUS DATBI cycles, BS7 H is asserted to indicate to the slave device that the bus master wants to perform a block mode cycle. The Q-22 Bus specification does not require the assertion of BS7 during the data portion of QBUS DATBO cycles. The DMA gate array asserts BS7 H when it is the bus master (performing DMA) during the data portion of both DATBI and DATBO cycles. The gate array receives BS7 H at all other times. If the gate array is not the QBUS master (not performing DMA transfers), and BS7 H is asserted when SYNC H is asserted, the address decode logic is disabled (i.e. the address decode logic in the gate array is disabled whenever the QBUS I/O page is being addressed). WTBT H WRITE/BYTE (output, 3-state) The DMA gate array asserts WTBT H only when it is the bus master. WTBT H is asserted by the bus master during the address portion of a cycle to indicate that an output cycle (DATO, DATOB, DATBO) is to follow rather than an input cycle. WTBT H is asserted by the bus master during the data portion of a DATOB or DATIOB bus cycle, to indicate a byte rather than a word transfer is to take place. NOTE As a slave, the DMA gate array is word addressable only. As a master, the gate array can perform byte transfers. SYNC H SYNCHRONIZE (input/output, 3-state) SYNC H is asserted by the bus Master to indicate that it has placed an address on the bus. The transfer is in process until SYNC H is negated. When doing block moves, SYNC H remains asserted until the last transfer is completed. SYNC H is not asserted during interrupt acknowledge cycles. The DMA gate array drives SYNC H only when it is the bus master. SYNC H is an input at all other times. DIN H DATA INPUT (input/output, 3-state) If SYNC H was not asserted when DIN H is asserted the cycle is an interrupt acknowledge cycle. The gate array latches the interrupt request status on the leading edge of DIN H. If DIN H is asserted while SYNC H is asserted a QBUS read cycle is being performed. The addressed slave device drives the bus with data and the master inputs the data. When the gate array is a QBUS slave device it recives DIN H and asserts RPLYO H to complete the cycle. The DMA gate array outputs DIN H when it is the bus master (and is performing a read cycle). The slave device must respond by asserting RPLYI H to complete the read cycle. DOUT H DATA OUTPUT (input/output, 3-state) DOUT H is asserted by the bus master during data output (write) cycles. The bus master asserts DOUT H after it outputs the data to the bus. The slave device must respond by asserting RPLYI H to complete the write cycle. The DMA gate array outputs DOUT H when it is the bus master (and is performing a write cycle). When the gate array is a QBUS slave device receives DOUT H and asserts RPLYO H to complete the cycle. RPLYO H REPLY OUTPUT (output, 3-state) When the DMA gate array is selected as the bus slave it asserts RPLYO H in response to DIN H or DOUT H. RPLYO H indicates to the bus Master that the gate array has placed it's data on on the bus (when DIN H is asserted) or that it accepted data from the bus (DOUT H is asserted). If the DMA gate array is asserting IRQ H when IAKI H is received it places the approriate interrupt vector on the the bus and asserts RPLYO H to indicate that it has accepted the interrupt acknowledge. RPLYO H is never asserted when the DMA gate array is the bus Master. RPLYI H REPLY INPUT (input) When the DMA gate array is the bus master RPLYI H is monitored to determine when the selected bus slave is ready to complete the bus cycle. RPLYI H indicates to the gate array that the slave device has placed it's data on the bus (when DIN H is asserted) or that it accepted data from the bus (DOUT H is asserted). DMRO H DIRECT MEMORY ACCESS REQUEST OUTPUT (output, 3-state) The DMA gate array asserts DMRO H to request bus mastership of the QBUS. After the bus Mastership has been granted to the DMA gate array, the gate array asserts SACK H and deasserts DMRO H. DMRI H DIRECT MEMORY ACCESS REQUEST INPUT (input) When the DMA gate array is the bus master it monitors DMRI H to determine if another DMA device is requesting bus mastership. Under certain conditions (see the descriptions in the sections on DMA) the gate array relinquishes bus mastership to allow another DMA device to aquire it. DMGI H DIRECT MEMORY ACCESS GRANT INPUT (input) The MicroVAX CPU asserts DMGI H to indicate it is granting bus Mastership to a QBUS device. If the DMA Gate Array is asserting DMR H (requesting the bus) when DMGI H becomes asserted it waits for the deassertion of SYNC H and RPLYI H, asserts SACK H, and removes DMRO H (the gate array becomes the QBUS master). If DMRO H is not asserted by the gate array when DMRO H is received it asserts DMGO H and passes the DMA grant to the next OBUS device. DMGO H DIRECT MEMORY ACCESS GRANT OUTPUT (output, 3-state) The DMA gate array asserts DMGO H if the DMGI H signal is asserted and the DMA gate array is not asserting DMRO H (not requesting bus mastership). SACK H SACK (output, 3-state) SACK H is asserted by the DMA gate array when it has aquired bus mastership of the QBUS. The signal indicates that the gate array is accepting bus mastership. The gate array keeps SACK H asserted until it relinquishes bus mastership. The DMA gate array requests bus mastership by asserting DMRO $\,^{\mathrm{H}}$ . When DMGI $\,^{\mathrm{H}}$ is received and DMRO $\,^{\mathrm{H}}$ is asserted, the gate array waits for the deassertion of SYNC H and RPLYI H, asserts SACK H, and removes DMRO H (the gate array becomes the QBUS master). SACK H also controls the direction of the transceiver for the QBUS signals SYNC H, DIN H, DOUT H, WTBT H and BS7 H. When SACK H is asserted the the VCB02 Base Module transmits the control signals. When SACK H is deasserted the Base Module receives the control signals. REF H REFRESH (input) As a bus master, the DMA gate array monitors this signal to determine if the slave device is block mode device. Block mode slave devices assert this line along with RPLYI H, if they are able to do subsequent data transfers. Slave devices that do not support block mode do not assert this line. NOTE The DMA gate array is a block mode master, NOT a block mode slave device. IRQ H INTERRUPT REQUEST (output, 3-state) The DMA gate array asserts this line when it requires an interrupt on the QBUS. Two bits (01 and 02) in the Control Status register are provided to enable/disable the internally connected DMA interrupt and the external interrupts IRQl H and IRQ2 H (from the Address Processor chip and the Communications Controller). IRQ H deasserts when the interrupt request is removed or IAKI H is received acknowledging the interrupt. The interrupt priority level of the DMA gate array is Position-Dependent (see Appendix A QBUS Specification). IAKI H INTERRUPT ACKNOWLEDGE INPUT (input) The MicroVAX CPU asserts IAKI H to acknowledge an interrupt request. If the DMA gate array is asserting IRQ H when it receives IAKI H it outputs an interrupt vector and clears the highest priority interrupt. If IAKI H is received by the gate array when IRQ H is not asserted, the gate array outputs IAKO H to pass the interrupt acknowledge to the next QBUS slot. The interrupt priority level of the DMA gate array is Position-Dependent (see Appendix A QBUS Specification). IAKO H INTERRUPT ACKNOWLEDGE OUTPUT (output, 3-state) If the DMA gate array is not requesting an interrupt and receives IAKI H, the gate array asserts IAKO H. The assertion of this signal propagates the the interrupt acknowledge to the next QBUS slot. If the DMA gate array receives IAKO H and is requesting an interrupt, the gate array does not assert IAKO H. The interrupt priority level of the DMA gate array is Position-Dependent (see Appendix A QBUS Specification). OINIT H INITIALIZE (input) QINIT H is used by the DMA gate array as a software reset. When QINIT H is asserted, the following states are effected in the gate array: The address decoder is disabled. The Memory base register has to be rewritten before accesing any locations other than the VCB02's I/O Page Control Status Register. Control Status Register bit 15 is set. All other Control Status Register bits are reset. The DMA logic in the gate array is reset causing any DMA transfers in progress to be aborted. The 22 bits of the DMA Address Counter are reset. The 22 bits of the DMA Byte Counter are reset. The FIFO pointers are reset (the FIFO is empty). The Template Address counter is reset. All interrupts are disabled. The hardware cursor is disabled. The Cursor X Position Register is reset. The Cursor Y Position Register is reset. #### POK L POWER OKAY (input) POK L must be asserted to enable the DMA Gate Array to request bus mastership. When POK L is deasserted, the DMRO H output is disabled (the gate array can not request bus mastership). If POK L is deasserted while the DMA gate array is the bus master, it does not abort the DMA process. If POK L remains deasserted, the gate array is prevented from aquiring bus mastership again after it completes the current DMA process. BTIMEO L BUS TIME OUT (open collector output, 3-state) BTIMEO L is used to discharge a timing capacitor external to the gate array (connected through a current limit resistor). This capacitor is used to generate a bus time out error when the slave device fails to assert REPLYI H in response to a DIN H or DOUT H data strobe within 10 micro-seconds (approximate time constant of charging circuit). If REPLYI H is asserted before the 10 micro-second limit, the gate array deasserts the data strobe (DIN H or DOUT H) and asserts BTIMEO L which discharges the capacitor (preventing a bus time out error). BTIMEI H is used to monitor the voltage on the capacitor. When BTIMEO L is deasserted the capacitor begins to charge (beigns timing period). If the capacitor voltage exceeds the logic high input threshold of the BTIMEI H input a bus time out error occurs. When the gate array is a slave device BTIMEO L is always asserted. When the DMA gate array is the bus master BTIMEO L is asserted (when both DIN H and DOUT H are not asserted). BTIMEI H BUS TIME INPUT (input, schmitt trigger) BTIMEI H is used to detect when a QBUS time out has occurred. When the DMA gate array is bus master and asserts DIN H or DOUT H, the gate array stops driving BTIMEO L which allows an external timing capacitor to charge. If the slave device has not asserted RPLYI H by the time that this input exceeds the logic high input threshold a bus time out error occurs, the BUS TIMEOUT bit (05) in and the DMA ERROR bit (07) in the Control Status Register (CSR) get set. If the DMA INTERRUPT ENABLE bit (01) in the CSR is set, the DMA gate array will assert IRQ H (request interrupt service). DTIMEO L DMA DELAY TIME OUT (open collector output, 3-state) DTIMEO L is used to discharge a timing capacitor external to the gate array (connected through a current limit resistor). This capacitor is used to generate a delay between requests for bus mastership by the DMA gate array. DTIMEO L is asserted whenever SACK H is asserted (the gate array is the bus master). When the gate array gives up bus mastership (SACK H is deasserted), DTIMEO L deasserts and the timing capacitor begins to charge (begin timing the delay). DTIMEI H is used to monitor the voltage on the capacitor. Until the capacitor voltage reaches the logic high threshold for DTIMEI H the DMA gate array can not request bus mastership (DMRO H is disabled). When the capacitor voltage exceeds the logic high threshold of DTIMEI H, DMRO H is enabled and the gate array can request bus mastership again. DTIMEI H DMA DELAY TIME INPUT (input, schmitt trigger) DTIMEI H monitors the voltage on an external timing capacitor. When DTIMEI H is low the DMA gate array does not request bus mastership (DMRO H is disabled). The external capacitor is discharged by DTIMEO L whenever the gate array is the bus master. When the gate arry relinquishes bus mastership, the capacitor begins to charge. After a delay, the capacitor charges to a voltage that asserts DTIMEI H and enables the gate array to request bus mastership again. XVRENO L TRANSCEIVER ENABLE 0 (output, 3-state) XVRENO L is the enable for the transceiver for the QBUS control signals SYNC H, DIN H, DOUT H, WTBT H and BS7 H. XVRENO L disables the transceiver when the DMA gate array transitions from slave to master and master to slave. XVREN1 H TRANSCEIVER ENABLE 1 (output, 3-state) XVREN1 H is the enable for the address and data transceivers for the QBUS. XVREN1 H disables the transceivers when at the leading and trailing edges of DIN H (except for IAK cycles). XVREN1 H also disables the transceivers when the DMA gate array transitions from slave to master and master to slave. XVRRCV L TRANSCEIVER RECEIVE (output, 3-state) XVRRCV L controls the direction of the QBUS transceivers for address and data. When XVRRCV L is asserted the VCB02 Base Module receives data. When XVRRCV L is deasserted the Base Module transmits data. XVRRCV L is asserted/deasserted only when XVREN1 H is deasserted (except for IAK cycles). #### 3.5.7.2 Address Decodes This section describes the signals provided by the DMA gate array for decoding QBUS addresses. CONSEL L CONSOLE SELECT (input) CONSEL L is an external QBUS address decode for the VCB02's I/O Page Control Status Register (CSR). If the slave cycle accessing the I/O Page CSR is a write cycle , the DMA gate array writes the data into it's Memory Base Address Register and enables the address decoder. If the slave cycle accessing the I/O Page CSR is a read cycle the gate array does not drive the AD(15:00) signals. The DMA gate array responds by asserting the RPLYO H line for both read and write cycles when CONSEL L is asserted. IOENB L I/O ENABLE (output, 3-state) When the gate array is not the bus master it asserts IOENB L when it decodes an address is in the range from VCB02 MEMORY BASE ADDRESS + C400 (hex) to VCB02 MEMORY BASE ADDRESS + DFFF (hex). IOENB L is used as an enable for an external decoder on the Base Module that segments the 7 kb address block to provide register space for the Communications Controller, the Memory Page Control Status Register, and the color maps (red, green and blue). The DMA gate array does not drive the data bus lines when IOENB L is decoded. ### ROMENB L ROM ENABLE (output, 3-state) ROMENB L is an address decode for slave cycles that access the VCB02 Base Module's ROM. The address range for the ROM is from VCB02 MEMORY BASE ADDRESS + 0000 (hex) to VCB02 MEMORY BASE ADDRESS + 7FFF (hex). ### 3.5.7.3 Interrupt Inputs The interrupt inputs connected to the Address Processor chip interrupt output and the Communication Controller interrupt output are described in this section. An additional interrupt is provided internally to the DMA gate array for the DMA logic. Refer to the QBUS INTERFACE section for details on the signals IRQ H, IAKI H, and IAKO H. ### IRQ(2:1) L INTERRUPT REQUEST(2:1) (input) IRQ2 L is connected to the Communication Controller on the VCB02 Base Module. IRQ1 L is connected to the Address Processor chip on the VCB02 Base Module. The interrupt request signals are used by the external devices to indicate to the DMA gate array that service by the MicroVAX CPU is required. IRQ2 L and IRQ1 L are asynchronous inputs and are low level sensitive. Request for service must be held low until the interrupt has been acknowledged. An additional DMA interrupt is provided internal to the gate array. The interrupts are priority encoded as shown in Table 3-8. During an interrupt acknowledge cycle, only the highest priority interrupt is cleared. IRQ(2:1) L may be masked by the External Interrupt Enable bit (02) in the Control Status Register. The DMA Interrupt may be masked by the DMA Interrupt Enable bit (01) in the Control Status Register. Table 3-8 DMA Interrupt Priority Encoding Interrupt Priority Highest IRQ0 - Internal DMA interrupt IRQ1 - Address Processor chip interrupt Lowest IRQ2 - Communications interrupt 3.5.7.4 Address Processor Chip Interface The signals described in this section are the control signals between the DMA Gate Array and the Address Processor chip. AA(7:1) H ADDRESS PROCESSOR ADDRESS (output, 3-state) The VCB02 uses only AA(6:1) H. AA(7) H is reserved by Digital for future use. AA(6:1) H select the Address Processor chip register being accessed. ADDAS L ADDRESS/DATA STROBE (output, 3-state) ADDAS L is a combination of address strobe and data strobe for the Address Processor chip. The assertion of ADDAS L indicates that a valid address is present on the AA(7:1) H lines and that the signal ADDWR L is valid. For write cycles to the Address Processor, this indicates that valid data is on the PB(15:00) H lines. On read cycles from the Address Processor, ADDAS L enables data onto the data bus from the Address Processor. The Address Processor chip is word addressable only. ADDWR L ADDRESS PROCESSOR WRITE (output, 3-state) This line indicates to the Address Processor chip a read or write operation. If the signal is asserted when ADDAS L is asserted the gate array is writing the Address Processor. If the line is deasserted when ADDAS L is asserted the gate array is reading from the Address Processor. ADDRQ L ADDRESS PROCESSOR DMA REQUEST (input) ADDRQ L is a status line from the Address Processor chip that indicates that the Address Processor chip is ready for a secondary DMA transfer. The ADDRQ L signal is controlled by writting an enable mask to the Address Processor's Request Enable Register. If the lgoical and of the enable mask and the Address Processor's Status Register result in any bit being set, the ADDRQ L is asserted. ADDRQ L is used to synchronize secondary DMA transfers with the DMA gate array. ### 3.5.7.5 Template RAM Interface The signals described in this section are the control signals for the Template RAM generated by the DMA gate array. TA(13:01) H TEMPLATE ADDRESS (output, 3-state) The VCB02 only uses TA(11:01) H. TA13 H and TA12 H are reserved for future use by Digital. TA(11:01) H are address lines for the Template RAM. The Template RAM is word accessible only. RAMWR L RAM WRITE (output, 3-state) RAMWR L is the write strobe for the Template RAM. The data on PB(15:00) is written to the Template RAM on the trailing edge of RAMWR L. RAMOE L RAM OUTPUT ENABLE (output, 3-state) RAMOE L is the Template RAM output enable control line. RAMOE L is asserted when the DMA gate array is doing a read cycle from the Template RAM. RAMOE L is used to tristate the Template RAM's output drivers when it is not being read. #### 3.5.7.6 Private Data Bus The signals described in this section are the data lines that connect the DMA gate array to the Address Processor chip and the Template RAM. PB(00:15) H PRIVATE BUS (input/output, 3-state) These signals provide the data path between the DMA Gate Array, the Template RAM and the Address Processor chip. Any of these devices may receive or transmit data on these signal lines. All transfers on this bus are controlled by the gate array. #### 3.5.7.7 Cursor Signals The signals described in this section are used to generate a two plane cursor that can be integrated into the video data output logic. CURA(3:0) H CURSOR A PLANE DATA (3:0) (output) CURA(3:0) are the plane 'A' cursor data outputs. This parallel data is output at one fourth the frequency of the VCB02's video pixel clock and is connected to an external shift registers that generates a single bit stream at the full VCB02 video pixel clock rate. CURCLK H is the clocking signal for CURA(3:0) H. CURB(0:3) H CURSOR B PLANE DATA (3:0) (output) CURB(3:0) are the plane 'A' cursor data outputs. This parallel data is output at one fourth the frequency of the VCB02's video pixel clock and is connected to an external shift registers that generates a single bit stream at the full VCB02 video pixel clock rate. CURCLK H is the clocking signal for CURA(3:0) H. CURCLK H CURSOR CLOCK (input) CURCLK H is the clock used by all the cursor logic. This 50 percent duty cycle clock is one fourth of the frequency of the VCB02's video pixel clock. CSYNC L COMPOSITE SYNC (input) CSYNC L is used to generate horizontal and vertical load pulses for the Cursor X and Cursor Y counters. CSYNC L MUST HAVE horizontal sync pulses during the vertical sync interval. CSYNC L is connected to the Address Processor chips CMPSYN output. CSYNC L is clocked into the gate array on the rising edge of CURCLK H. BLANK H VIDEO BLANK (input) BLANK H is used to generate vertical load and count pulses for the Cursor Y counter and load pulses for the Cursor X counter. BLANK H is clocked into the gate array on the rising edge of CURLCK H. BLANK H MUST remain asserted during the vertical sync interval. BLANK H DOES NOT disable the CURA(3:0) or CURB(3:0) outputs. BLANK H is connected to the Address Processor chip's BLANK output. 3.5.7.8 Miscellaneous Signals The signals described in this section are those signals that are common to the entire gate array and are not associated with a particular signal group. CLOCK H CLOCK (input) System clock for the DMA gate array with a 50 percent duty cycle. The rising edge of CLOCK H is used to generate all timing in the gate array EXCEPT the cursor timing. In the VCB02, CLOCK H is one fourth the video pixel clock frequency. GOZ L GO Tri-state (input) When this line is drive low, all 3-state outputs are disabled (go tristate). This pin is only for manufacturing test. ### 3.5.8 Physical Description The following sections describe the package pin numbering and signal pin assignments for the DMA gate array. The package is a ceramic 120 PGA (Pin Grid Array). ### 3.5.8.1 Package Pin Numbering Figure 3-59 shows a top view diagram identifing the DMA gate array's pin numbers. Figure 3-60 shows the bottom view numbering of the DMA gate array. The bottom view is used when looking at the side of the gate array package that has the pins, or, when looking at the hole pattern for the gate array on the etch side of the printed circuit board. The top view is used when looking at the hole pattern for the gate array on the component side of the printed circuit board. #### TOP VIEW | 120 | 117 | 116 | 113 | 111 | 108 | 107 | 104 | 101 | 99 | 96 | 93 | 90 | Α | |-----|-----|-----|------|-----|-----|------|-----|-----|-----|----|------|-----|---| | 3 | 2 | 119 | 115 | 112 | 109 | 105 | 103 | 100 | 97 | 95 | 92 | 87 | В | | 6 | | | | | | 106 | 102 | 98 | 94 | 91 | 89 | 86 | С | | 9 | | ; | + | | | | | ! | * ' | 88 | 85 | 83 | D | | 11 | 10 | 8 | * | • | | | | - | ! | 84 | 82 | 81 | Ε | | 14 | 13 | 12 | •••• | • | | 120 | | | : | | 79 | | F | | | | | | | | PIN | | | , | | | | _ | | 17 | 15 | 16 | | | | | | | i | 76 | 75 : | 77 | G | | 1 | 10 | | | | | GRID | | | į | 72 | 73 | 741 | ш | | | 19 | | | | | ARRA | v | | į | 12 | /3 | 74 | H | | | 22 | | | | | mu | • | | | 68 | 70 | 71 | J | | | | | | • | | | | • | | | | , | | | 23 | 25 | 28 | * | | | | | ! | * | 64 | 67 | 69 | K | | 26 | 29 | 31 | 34 | 38 | 42 | 46 | 50 | 54 | 58 | 61 | 65 | 66 | L | | 27 | 32 | 35 | 37 | 40 | 43 | 45 | 49 | 52 | 55 | 59 | 62 | 63 | М | | 30 | 33 | 36 | 39 | 41 | 44 | 47 | 48 | 51 | 53 | 56 | 57 | 60 | N | | | | | | | | | | | | | | | • | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | | | | | | | | | | | | | | | | | NOTE: The letters along the side and the numbers along the bottom of the diagram identifies the grid coordinate of the pin. The numbers in the squares identify the pin number. The + symbol indicates an extra pin for keying the package orientation. The \* symbol indicates an insulated standoff for holding the package up off the board surface. Figure 3-59 DMA Gate Array Pin Diagram (Top View) #### BOTTOM VIEW | A | 90 | 93 | 96 | 99 | 101 | 104 | 107 | 108 | 111 | 113 | 116 | 117 | 120 | | |----|----|-----|-----|----|-------|-----|---------|-----|-----|-----|-----|-----|-----|-------------| | В | 87 | 92 | 95 | 97 | 100 | 103 | 105 | 109 | 112 | 115 | 119 | 2 | 3 | | | С | 86 | 89 | 91 | 94 | 98 | 102 | 106 | 110 | 114 | 118 | 1 | 5 | 6 | | | D | 83 | 85 | 88 | * | | | | | | • | | 7 | | : | | E | 81 | | | | | | | | | * | 8 | 10 | 11 | | | F | 78 | | 801 | • | | | 120 | | | i | • | 13 | | | | G | 77 | 75 | | | | | PIN | | | | | 15 | | • | | Н | 74 | 73: | 72: | | | | GRI | ) | | | 2.0 | 19 | 18 | ! | | 11 | | | | | | | ARR | AY | | | | | | | | I | 71 | 70 | 68 | | | | | | | | 24 | 22 | 21 | ;<br>;<br>; | | J | 69 | - 1 | 1 | * | | | | | | * | 28 | 25 | 23 | • | | K | 66 | 65 | 61 | 58 | 54 | 50 | 46 | 42 | 38 | 34 | 31 | 29 | 26 | | | L | 63 | 62 | 59 | 55 | 52 | 49 | 45 | 43 | 40 | 37 | 35 | 32 | 27 | | | N | 60 | 57 | 56 | 53 | 51 | 48 | 47 | 44 | 41 | 39 | 36 | 33 | 30 | | | | | | | | • • • | | • • • • | | | | | | | • | | | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | NOTE: The letters along the side and the numbers along the bottom of the diagram identifies the grid coordinate of the pin. The numbers in the squares identify the pin number. The + symbol indicates an extra pin for keying the package orientation. The \* symbol indicates an insulated standoff for holding the package up off the board surface. Figure 3-60 DMA Gate Array Pin Diagram (Bottom View) # 3.5.8.2 Pin Signal Assignments Table 3-9 lists the signal assignments of each pin in numerical pin order. For each pin, the package pin grid coordinate, signal name, and the gates used for the receiver and/or driver is given. Table 3-9 DMA Gate Array Pin Signal Assignments (Sheet 1 of 3) | PIN NUMBER SIGNAL NAME FOR RECEIVER FOR DRIVER | | | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------|-------------------------| | 1 C 3 VCC 2 B 2 PB10 H TLCHTI BTS7L 3 B 1 PB09 H TLCHTI BTS7L 4 D 3 PB08 H TLCHTI BTS7L 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | PIN | | | | 1 C 3 VCC 2 B 2 PB10 H TLCHTI BTS7L 3 B 1 PB09 H TLCHTI BTS7L 4 D 3 PB08 H TLCHTI BTS7L 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 20 H BTS1 21 J 1 TA03 H BTS1 22 K 2 TA01 H BTS1 23 K 3 TA02 H BTS1 24 J 3 TA04 H BTS1 25 K 2 TA01 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | NUMBER | NUMBER SIGNAL NAME | FOR RECEIVER FOR DRIVER | | 2 B 2 PB10 H TLCHTI BTS7L 3 B 1 PB09 H TLCHTI BTS7L 4 D 3 PB08 H TLCHTI BTS7L 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 <td></td> <td></td> <td></td> | | | | | 3 B 1 PB09 H TLCHTI BTS7L 4 D 3 PB08 H TLCHTI BTS7L 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMW L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND BTS1 16 G 3 VCC VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 | | | pmc7r | | 4 D 3 PB08 H TLCHTI BTS7L 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 29 L 2 TA01 H BTS1 20 H BTS1 21 J GND | | | | | 5 C 2 PB07 H TLCHTI BTS7L 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 29 L 2 TA01 H BTS1 20 L 2 TA01 H BTS1 21 J 1 TA03 H BTS1 22 J 2 TA04 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | | | | 6 C 1 PB06 H TLCHTI BTS7L 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 20 L 2 TA01 H BTS1 20 L 2 TA01 H BTS1 21 J 1 GND | | | | | 7 D 2 PB05 H TLCHTI BTS7L 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND BTS1 16 G 3 VCC VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS | | | | | 8 E 3 PB04 H TLCHTI BTS7L 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND GND 16 G 3 VCC VCC VCC VCC VCC 17 G 1 TA13 H BTS1 | | | | | 9 D 1 PB03 H TLCHTI BTS7L 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | | | | 10 E 2 PB02 H TLCHTI BTS7L 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | • | | | 11 E 1 PB01 H TLCHTI BTS7L 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | | | | | 12 F 3 PB00 H TLCHTI BTS7L 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | | | | 13 F 2 RAMWR L BTS1 14 F 1 RAMOE L BTS1 15 G 2 GND GND 16 G 3 VCC VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND GND | | | | | 14 F 1 RAMOE L 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | | PB00 H TLCHTI | | | 15 G 2 GND 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | | RAMWR L | | | 16 G 3 VCC 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | 14 F 1 | RAMOE L | BTS1 | | 17 G 1 TA13 H BTS1 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 30 N 1 GND | 15 G 2 | GND . | | | 18 H 1 TA12 H BTS1 19 H 2 TA11 H BTS1 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND GND | 16 G 3 | vcc | | | 19 H 2 TAll H BTSl 20 H 3 TAl0 H BTSl 21 J 1 TA09 H BTSl 22 J 2 TA08 H BTSl 23 K 1 TA07 H BTSl 24 J 3 TA06 H BTSl 25 K 2 TA05 H BTSl 26 L 1 TA04 H BTSl 27 M 1 TA03 H BTSl 28 K 3 TA02 H BTSl 29 L 2 TA01 H BTSl 30 N 1 GND | 17 G 1 | TAl3 H | BTS1 | | 20 H 3 TA10 H BTS1 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | 18 H 1 | TA12 H | BTSl | | 21 J 1 TA09 H BTS1 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | 19 H 2 | TAll H | BTS1 | | 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | 20 H 3 | TAlO H | BTSl | | 22 J 2 TA08 H BTS1 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | 21 J 1 | ТА09 Н | BTS1 | | 23 K 1 TA07 H BTS1 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | TA08 H | BTS1 | | 24 J 3 TA06 H BTS1 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | та07 н | BTS1 | | 25 K 2 TA05 H BTS1 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | та06 н | BTS1 | | 26 L 1 TA04 H BTS1 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | TA05 H | BTS1 | | 27 M 1 TA03 H BTS1 28 K 3 TA02 H BTS1 29 L 2 TA01 H BTS1 30 N 1 GND | | | BTS1 | | 28 K 3 TA02 H BTS1<br>29 L 2 TA01 H BTS1<br>30 N 1 GND | | | BTS1 | | 29 L 2 TA01 H BTS1<br>30 N 1 GND | | | BTSl | | 30 N 1 GND | | | BTS1 | | | | | | | | 31 L 3 | VCC | | | 32 M 2 A21 H TLCHTI BTS7L | | | BTS7L | | 33 N 2 A20 H TLCHTI BTS7L | | | | | 34 L 4 Al9 H TLCHTI BTS7L | | • | | | 35 M 3 Al8 H TLCHTI BTS7L | | | | | 36 N 3 Al7 H TLCHTI BTS7L | | | | | 37 M 4 Al6 H TLCHTI BTS7L | | | | | 38 L 5 AD15 H TLCHTI BTS7L | | | | | 39 N 4 AD14 H TLCHTI BTS7L | | | | | 40 M 5 AD13 H TLCHTI BTS7L | | | | | 40 M D MDID M INCHII DIDIU | 40 M 2 | WDIO U IDCUII | | Table 3-9 DMA Gate Array Pin Signal Assignments (Sheet 2 of 3) | | CDID | | | CAME MEED | |--------------------|----------------------------|--------|-----------|-----------| | | GRID<br>NUMBER SIGNAL | | GATE USED | | | | | | | | | 41 N 5 | AD12 H<br>AD11 H<br>AD10 H | TLCHTI | BTS7L | | | 42 L 6 | AD11 H | TLCHTI | BTS7L | | | 43 M 6 | AD10 H | TLCHTI | BTS7L | | | 44 N 6 | AD09 H | TLCHTI | | | | 45 M 7 | AD08 H | TLCHTI | BTS7L | | | | GND | | | • | | | VCC | | | | | | AD07 H | | | | | 49 M 8 | | | BTS7L | | | 50 L 8 | | | BTS7L | | | | | TLCHTI | | | | | AD03 H | TLCHTI | | | | 53 N 10 | | TLCHTI | | | | 54 L 9 | AD01 H | TLCHTI | | | | | | TLCHTI | | | | | | TLCHTI | | | | | WTBT H | | BTS1 | | | | SYNC H | | | | | | | TLCHTI | BTS7L | | | 60 N 13 | GND | | | | | 61 L 11 | VCC | | 20071 | • | | 62 M 12 | | TLCHTI | BTS7L | | | 63 M 13 | | TLCHT | 5001 | | | | RPLYO H | | BTS1 | | | 65 L 12 | SACK H | | BTSl | | | | XVREN1 H | | BTS1 | | | | XVRENO L | | BTS1 | | | 68 J 11<br>69 K 13 | XVRRCV L | mr cum | BTSl | | | 70 J 12 | | TLCHT | BTSl | | | | REF H | TLCHT | D131 | | | | DMRI H | | | | | 72 H 11<br>73 H 12 | DMRO H | ILCHI | BTSl | | | 74 H 13 | IOENB L | | BTS1 | | | 74 H 13 | ROMENB L | | BTS1 | | | 76 G 11 | GND | | 9131 | | | 77 G 13 | CONSEL L | TLCHT | | | | 78 F 13 | QINIT H | TLCHT | | | | 70 F 13 | 50 | TLCHT | | | | | GOZ L | TLCHT | | | | | | | | | Table 3-9 DMA Gate Array Pin Signal Assignments (Sheet 3 of 3) | NUMBER | GRID<br>NUMBER | SIGNAL NAME | GATE USED<br>FOR RECEIVER | FOR DRIVER | |--------------------|--------------------|--------------------|---------------------------|--------------| | 81 E 13<br>82 E 12 | DTIMEO L | | BloD | | | 84 E 11 | BTIMEO L | | BlOD | | | 86 C 13 | IRQ H | SCHMDTl | BTS1 | | | 87 B 13<br>88 D 11 | | | BTS1 | | | 89 C 12 | IRQ2 L | SCHMDT1 | | | | | IRQ1 L<br>VCC | SCHMDTl | | | | 92 B 12 | CURB3 H | | Bl<br>Bl | | | 93 A 12<br>94 C 10 | | | Bl | | | 95 B 11 | CURBO H | | Bl<br>Bl | | | | CURA3 H<br>CURA2 H | | Bl | | | 98 C 9<br>99 A 10 | CURAL H | | Bl<br>Bl | | | 100 | В 9 | CURCLK H | TLCHT | | | 101 | A 9 | <del></del> | TLCHT | . • | | | | CYSNC H<br>ADDRQ L | TLCHT | | | | A 8 | | · · | BTS1 | | | в 7 | | | | | 106 | C 7 | GND | | _ | | 107 | A 7<br>A 6 | ADDAS L | | BTS1 | | 108 | A 6 | AA07 H | | BTS1 | | | B 6 | AA06 H | | BTS1<br>BTS1 | | 110 | C 6 | AAU5 H | | BTS1 | | | A 5 | | | BTS1 | | 112 | B 5 | AAO3 H | • | BTS1 | | 113 | A 4<br>C 5 | AA02 H<br>AA01 H | | BTS1 | | 114 | | PB15 H | TLCHTI | BTS7L | | 115<br>116 | B 4<br>A 3 | PB13 H | TLCHTI | BTS7L | | 117 | A 2 | PB13 H | TLCHTI | BTS7L | | 118 | C 4 | PB12 H | TLCHTI | BTS7L | | 119 | B 3 | PB11 H | TLCHTI | BTS7L | | 120 | A 1 | GND | - <del></del> | , | ### 3.5.9 Input/Output Specifications Specified for Vdd = 4.75 to 5.25 volts and Ta = 0 to 70 degrees Celsius. Table 3-10 lists the I/O specifications. Vil = low level input voltage Vih = high level input voltage Vt+ = schmitt trigger postive edge threshold Vt- = schmitt trigger negative edge threshold Iil = low level input current Iih = high level input current Vol = low level output voltage Voh = high level output voltage Ioz = tristate leakage output current Table 3-10 Input/Output Specifications | Symbol | I/O Gate Type | Condition | Min. | Max. | Unit | |--------|-----------------------|-------------|------|------|------| | Vil | TLCHT, TLCHTI | | Vss | 0.8 | ٧ | | Vih | TLCHT, TLCHTI | | 2.0 | Vdd | V | | Vt+ | SCHMDTl | | | 4.0 | V | | Vt- | SCHMDTl | | 1.0 | | V | | Iil | TLCHT | Vin = Vss | -0.5 | - 20 | uA | | 111 | TLCHTI, SCHMDTl | VIII - V55 | | -10 | uA | | Iih | TLCHT | Vin = Vdd | | 20 | uA | | 1111 | TLCHTI, SCHMDTl | VIII – Vaa | | 10 | uA , | | Vol | Bl, BlOD, BTS1, BTS7L | Iol = 2.0mA | ! | 0.4 | ٧ | | Voh | Bl, BTSl, BTS7L | Ioh =-1.6mA | 2.4 | 1 | ٧ | | VOII | BlOD (open collector) | | N/A | | V | | Ioz | BTS1,BTS7L,BlOD | | -10 | +10 | uA | # 3.5.10 Timing Diagrams The following sections contains timing diagrams for selected DMA Gate Array signals. 3.5.10.1 Private Bus Timing The timing diagrams for all cycles on the private bus are provided below. The 'state' changes on the rising edge of CLOCK H. 3.5.10.1.1 Template RAM Write Cycle - Figure 3-61 shows the timing diagram for write cycles to the Template RAM caused by slave writes to the Template RAM or FIFO Register, or by DMA writes to the FIFO. #### NOTES: - 1. RAMOE L is not asserted during this cycle. - Signals that are appended with an \* are internal to the gate array. Figure 3-61 Template RAM Write Cycle Timing Diagram 3.5.10.1.2 Template RAM Read Cycle - Figure 3-62 shows the timing diagram for read cycles from the Template RAM caused by slave reads from the Template RAM or FIFO Register, or by DMA reads from the FIFO. #### NOTES: - 1. RAMWR L is not asserted during this cycle. - 2. Signals that are appended with an \* are internal to the gate array. Figure 3-62 Template RAM Read Cycle Timing Diagram 3.5.10.1.3 Template RAM Read, Address Processor Write Cycle - Figure 3-63 shows the timing diagram for cycles that read from the Template RAM and write to the Address Processor chip (caused by the execution of display lists or Processor to Bitmap DMA). #### NOTES: - 1. RAMWR L is not asserted during this cycle. - Signals that are appended with an \* are internal to the gate array. Figure 3-63 Template RAM Read - Address Processor Write Cycle Timing Diagram 3.5.10.1.4 Address Processor Write Cycle - Figure 3-64 shows the timing diagram for write cycles to the Address Processor chip caused by slave writes. #### NOTES: - 1. RAMOE L and RAMWR L are not asserted during this cycle. - Signals that are appended with an \* are internal to the gate array. Figure 3-64 Address Processor Write Cycle Timing Diagram 3.5.10.1.5 Address Processor Read Cycle - Figure 3-65 shows the timing diagram for read cycles from the Address Processor chip caused by slave reads. | state | i x | 1 . O . | 1 | 2 | 3 | 4 | ) 5<br> | 0 | l x | |---------|----------------------|---------------------|--------------------|-----------------------|---------------------|-------------|--------------|------------------|------------| | BCNTA* | ·<br>· | <br> | /<br>/ | | | <br>i | \<br> \==== | | / | | BCNTB* | 1 | i<br>\<br>.\==== | <br> <br> | :<br> <br> /:<br>/ | ,<br> <br> | <br> | <br> <br> | <br> <br> \ | | | BCNTC* | 1 | .\ | i<br>I | l<br> <br> , | <br> /<br>/ | <br> <br> | i<br>\ | \<br>\<br> \-= | i<br> <br> | | BCNTD* | | \<br>• \====: | i<br> <br> | <br> <br> | <br> <br> | <br> /<br>/ | !<br>\<br>i | | <br> | | AAXX | <br> /////<br> \\\\\ | <br>//////<br>\\\\\ | <br>/////<br>\\\\- | <br> | <br> | i<br> | i<br>\ | -<br> \\\\\\<br> | <br> | | ADDWR L | 1 | *. | <br> | <br><br> | i<br> | <br> <br> | i | <br> \<br> | <br> <br> | | ADDAS L | 1 | | <br> <br> | <br> <br> <br> \ | <br> | i<br> | <br> , | <br> /<br> | | | PBxx | | <br>\<br>/ | | <br> //////<br> \\\\\ | <br>//////<br>\\\\\ | | i<br>\ | \<br>' | <br> <br> | | BDONE L | 1 | ./ | <br> | <br> | )<br> | | <br> <br> \ | i<br> /<br>/ | | | | | Í | | I . | | | | • | İ | #### NOTES: - 1. RAMOE L and RAMWR L are not asserted during this cycle. - 2. Signals that are appended with an \* are internal to the gate array. Figure 3-65 Address Processor Read Cycle Timing Diagram 3.5.10.1.6 Address Processor Read, Template RAM Write Cycle - Figure 3-66 shows the timing diagram for cycles that read from the Address Processor chip and write to the Template RAM (caused by Bitmap to Processor DMA). #### NOTES: - 1. RAMOE L is not asserted during this cycle. - 2. Signals that are appended with an \* are internal to the gate array. Figure 3-66 Address Processor Read - Template RAM Write Cycle Timing Diagram #### 3.5.10.2 QBus Timing The timing diagrams for DMA gate array QBUS master cylces are provided below. The 'state' changes on the rising edge of CLOCK H. Timing diagrams for the slave to master and master to slave transceiver enable and direction signals are also provided. 3.5.10.2.1 Slave To Master Transition - Figure 3-67 shows the slave to master transition. | INTERNAL DMA<br>MACHINE STATES | . 0 | |--------------------------------|-----------------------------------------| | CTOCK H | /=\_/=\_/=\_/-\_/-\_/ | | DMRO H | 9 = 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | DMGI H | pm/000000000000000000000000000000000000 | | XRVEÑO L | | | SACK H | | | XVREN1 H | | | XVRRCV L | | Figure 3-67 QBus Timing Diagram - Slave To Master Transition 3.5.10.2.2 Master To Slave Transition - Figure 3-68 shows the master to slave transition. | INTERNAL DMA<br>MACHINE STATES | 1 2 1 | |--------------------------------|----------------------------------------| | CLOCK H | /-\_/-\_/-\_/-\_/-\_/ | | DMRO H | # # # # # # # # # # # # # # # # # # # | | DMGI H | ********************************* | | XRVENO L | | | SACK H | ************************************** | | XVREN1 H | \ <sub></sub> | | XVRRCV L | | Figure 3-68 QBus Timing Diagram - Master To Slave Transition Figure w 69 QBus Timing Diagram Ma ົທ te Ħ DIN Cycle #### FUNCTIONAL DESCRIPTION ## Figure 3-69 NOTES: - For Block Mode Transfers, the DMA Machine State changes from State 23 to State 7. For Non-Block Mode Transfers, the DMA Machine State changes from State 23 to State 0. - 2. If REF H is asserted by the slave device during any DMA cycle, the DMA Gate Array will attempt 16 transfers provided that the DMA Byte Count is greater than or equal to 31. If REF H is not asserted by the slave device during any transfers, the DMA Gate Array will attempt a maximum of 8 transfers provide that the DMA Byte Count is greater than or equal to 7. - 3. BUSRQ H and BUSDON H are internal signals and are presented on this timing diagram for reference only. - 3.5.10.2.4 Master DOUT Cycle Figure 3-70 shows the master DOUT cycle. # Figure 3-70 NOTES: - For Block Mode Transfers, the DMA Machine State changes from State 23 to State 7. For Non-Block Mode Transfers, the DMA Machine State changes from State 23 to State 0. - 2. If REF H is asserted by the slave device during any DMA cycle, the DMA Gate Array will attempt 16 transfers provided that the DMA Byte Count is greater than or equal to 31. If REF H is not asserted by the slave device during any transfers, the DMA Gate Array will attempt a maximum of 8 transfers provided that the DMA Byte Count is greater than or equal to 7. - 3. BUSRQ H and BUSDON H are internal signals and are presented on this timing diagram for reference only. Figure w .70 QBus Timing Diagram Mas ter DOUT Cycle . .. AD00 --- AD15 H TRANSMIT ZEROS -- A21 H WORD TRANSFER DIN H DOUT H RPLYI H \* REF H XVREN1 H NO SYTE PACKING - NO BYTE UNPACKING #### CHAPTER 4 #### PROGRAMMING INFORMATION #### 4.1 PROGRAMMING THE VCB02 VIDEO SUBSYSTEM ## 4.1.1 Hardware Support The VCB02 video subsystem hardware provides support for the following features: - The ability to transform, manipulate and create images through a set of bitmap operations called raster operations (rasterops) at rates between 0.5 million and 8 million pixels per second. - A dedicated parallel datapath processor for each plane of physical memory, resulting in a maximum bandwidth of 256 million bits per second. - Support for viewports by providing clipping along with horizontal and vertical smooth scrolling within a rectangular region - 4. Text writing rate of up to 20 thousand characters per second - 5. Tiling, pattern and half-tone generation - 6. Polygon fill - Z-Axis read and write operations to set the value of a pixel in a single operation - 8. DMA of address processor commands from MicroVAX memory to the address processor - 9. Storage and execution of address processor command "subroutines" in VCB02 template RAM Figure 4-1 shows a simplified block diagram of the VCB02 video subsystem. The essential subsystem components are: - 1. Four or eight planes of bitmap memory. The bitmap is not directly accessible from the MicroVAX. - 2. One Video Processor (datapath) chip for each plane of bitmap memory. This chip receives input data from the bitmap or I/D interconnect, operates on it as directed by its control registers and makes the result available for screen refresh and rewrite into the bitmap. - 3. Chip select hardware that determines which set of Video Processor chips (bitmap planes) will participate in a scrolling or bitmap update operation - 4. The Address Processor chip (microsequencer); a custom LSI chip that implements the rasterop and scrolling algorithms. The outputs of this chip are memory addresses and commands to the Video Processor chips to perform rasterops, scrolling and screen refresh. - 5. The I/D interconnect connecting the Address Processor chip to all Video Processor chips. This interconnect is used to broadcast commands and data to all Video Processor chips, transfer bitmap data from the Video Processor chips to the address processor chips, and to load the update and scroll chip select registers. - 6. The DMA gate array to accelerate the transfer of data and commands between the MicroVAX CPU and the Address Processor. Figure 4-1 VCB02 Video Subsystem Block Diagram The VCB02 hardware executes a set of raster operations to manipulate and create images, and performs horizontal or vertical scrolling of any rectangular region on the screen. The VCB02 has a two plane programable cursor, a 256 x 12 bit color map, support for a keyboard and a mouse, and a DMA interface. # 4.1.2 Bitmap Memory Organization Figure 4-2 shows each two-dimensional plane of bitmap memory under control of a separate video chip. Figure 4-2 Multiplane Bitmap Memory Organization A pixel is addressed by its cartesian coordinates referenced to the upper left hand corner of the memory space. The X coordinate increases to the right. The Y coordinate increases downwards. A bit within a plane of memory is addressed by its cartesian coordinates and bitplane number. As indicated in Figure 4-3, the bitmap is divided into the screen refresh area and offscreen memory that can be used for font and image storage. Each plane consists of $1024 \times 2048$ pixels , of this $1024 \times 864$ are visible on the screen. The remainder is available for fonts and other off screen images. Figure 4-3 Offscreen and Visible Memory In addition to delineating the part of memory that is visible on the CRT, the screen refresh boundaries also mark that part of memory that can participate in scrolling. The actual scrolling boundries are set in the address processors scroll boundry registers. When scrolling occurs, the hardware achieves the visual effect by either moving data within the scroll boundaries or in the case of down scrolling, moving the data outside the scroll boundries up and shifting the screen down with respect to the memory origin. In either case the visual effect is that outside of the boundaries remains stationary and inside the boundries scrolls. ## 4.1.3 Overview of Rasterops In the VCB02 video subsystem, all image processing in the bitmap is done by means of rasterops. A raster is a set of pixels within the bitmap that are enclosed by a parallelogram of any orientation. A raster operation (rasterop) transforms a rectangular source raster, aligned with the X and Y axis, into a destination raster. As shown in Figure 4-4, the transformation consists of both a geometric and a logical component. The geometric transformations consist of rotation, scaling and translation. These are performed by the Address Processor chip. The logical component consists of masking, clipping and combining logic using pixels in the destination. These operations are performed by each Video Processor chip using codes placed in control registers by the MicroVAX CPU. Figure 4-4 Rasterop Functional Model In the general case illustrated in Figure 4-5, a rasterop is characterized by two source operands, a destination, a transformation between sources and destination and a clipping rectangle applied to the destination raster. All operands are optional and all can be used in one of the following ways: - o As a source of pixels to be logically combined with the destination - o As a mask applied to other operands - o As a source of data to be broadcast on the I/D interconnect Rasterop Overview Figure 4-5 Rasterop Operand Flow In its simplest form a rasterop copies a rectangular array of pixels from one location in the bitmap to another. As an example, text may be displayed by selecting the appropriate raster from a set of rectangular font patterns in an offscreen portion of the bitmap and moving it to the location defined by the cursor position. In this case, the source is an array of pixels in the font table, the destination is a rectangular area located at the cursor position and the transformation is a replacement of the destination with a copy of pixels from the source. Other, more complex transformations involve rotation, scaling and some logical combination of source and destination pixels. The use of these additional features allows the rasterop facility to be used for vector generation and a large class of text and graphics operations. The clipping rectangle facilitates the implementation of viewports. It is a mask that overlays the destination, preventing pixels outside the boundaries from being overwritten. The results of the clipping algorithm are available to the MicroVAX CPU to aid in operations such as picking an object or selecting a menu item. Resolution of the clipping boundaries is up to one bit vertically and 4 bits horizontally. The performance of a raster operation depends largely on the orientation of the destination raster. With one edge aligned to the X direction, data is written into the destination in up to 16 bit increments, resulting in a maximum rate of 8 million pixels per second. If neither edge is aligned with the X axis, data must be written one pixel at a time. Thus the overall rate decreases to 1/16 of the fast mode or 0.5 million pixels per second. #### 4.1.4 Overview of Scrolling In the VCB02 video subsystem, horizontal and vertical scrolling is accomplished by high speed logic within the Address Processor and Video Processor chips that can move an entire $1024 \times 905$ (screen hieght plus blank time) scroll region in either the upward or horizontal direction in a single frame time. scrolling boundaries may be set on any vertical pixel boundary and on a 4-pixel boundary horizontally. Up-scrolling within a rectangular region involves simply using the scrolling hardware to move the contents of the region upwards by the scroll increment. Conversely, since the scrolling logic does not shift the region downwards, the hardware creates the appearance of down-scrolling by leaving the data inside the scrolling region stationary and shifting the surrounding data upwards. illusion of down scrolling is produced by offsetting the start of screen refresh in the Y direction to compensate for the physical movement of the 'stationary' data. #### PROGRAMMING INFORMATION One way to visualize down scrolling is to consider a matte enclosed in a picture frame. If the matte is placed over a photo, it will outline some portion of the image. The image can be made to move downward with respect to the matte by either moving the photo downwards or the matte upwards. If the matte is moved, the appearance of the matte within the frame is held constant by shifting the matte and frame together. This is analogous to the way the VCB02 video subsystem performs down-scrolling. Relocating the start of the screen corresponds to shifting the picture frame. In addition to scrolling, this logic may be used to 'drag' a region across the screen. Dragging is performed by elongating the scrolling boundary in the direction that the image is to be moved, leaving the fill color in its wake. In reference to the previous example, it is analogous to moving the matte and photo together within the frame boundary. The scrolling rate, horizontaly, may vary from 1 to 15 pixels per frame; and verticly may vary from 1 to 905 pixels (lines) per frame; thus smooth or jump scroll may be performed in either the X or Y direction. ## 4.1.5 Coordinate Systems and Mapping Images in the VCB02 video subsystem can be referenced by their cartesian coordinates relative to: - The origin of bitmap memory - The origin of the screen - Any arbitrary point in the bitmap, usually a viewport or scrolling region - The origin of the destination raster As a rule, applications will want to specify the location of objects in a region relative to the region origin. Visible objects outside a region will be specified in screen coordinates. Objects in offscreen memory will be located with respect to memory coordinates. This section will discuss how the Address Processor chip performs coordinate conversions between these frames of reference in the absence of scrolling. Figure 4-6 shows the relationship of these spaces. Logically, the screen and memory coordinate systems overlay one another and have the same extent. The physical bitmap appears as a large rectangular coordinate system that is subdivided into the screen refresh area and offscreen memory. The mapping hardware makes it seem as if the origin of the screen is always co-incident with the bitmap. Figure 4-6 Viewports and Scrolling Regions Because of vertical scrolling, the actual position of the screen refresh area will be displaced in the Y direction from the memory origin as shown in Figure 4-7. The extent of this area is defined by the contents of X and Y limit registers within the Address Processor chip. The shaded area indicates the visible portion of memory. The unshaded part is the offscreen area reserved for scrolling. Down scrolling is actually performed by displacing the screen origin relative to the start of physical memory. This vertical displacement is contained in the Y offset register in the Address Processor chip. Figure 4-7 Screen to Memory Mapping During screen refresh or when a rasterop address is generated that is inside the screen refresh limits, the address is automatically mapped to physical memory by the following algorithm. RETURN Note the cylindrical screen to memory mapping resulting from the use of modulo arithmetic. Figure 4-8 shows the relationship of the scrolling region to the screen coordinate system. Figure 4-8 Scrolling Region The Address Processor chip locates the the scrolling region with respect to the screen origin by the four X and Y coordinates shown. The clipping region is specified similiarly to the scrolling region. To support viewports and windows, an object (raster) can have an address relative to an arbitrary reference point in the screen co-ordinate system. The coordinates of the reference point, the X and Y index values shown in Figure 4-9, can be conditionally applied by the Address Processor to translate a destination or first source address to screen coordinates. X Index Figure 4-9 Address Indexing If the translated value is inside the refresh area, the Y offset is automatically applied to convert the address to memory co-ordinates. As shown in the following algorithm, operand indexing and the index values are specified by the Microvax CPU. ROUTINE REGION TO MEMORY TRANSFORM (X, Y; X MEMORY, Y MEMORY) ``` ! X and Y are the object coordinates relative to the ! start of the scrolling region. ! ! First assume that indexing is disabled ! X SCREEN = X Y SCREEN = Y IF (Indexing is enabled for this raster operand) THEN BEGIN X SCREEN = X + X INDEX Y SCREEN = Y + Y INDEX END ! ! If the result is inside the screen refresh area, apply ! the screen to memory coordinate transform shown ! earlier. ``` SCREEN\_TO\_MEMORY\_TRANSFORM (X\_SCREEN,Y\_SCREEN; X\_MEMORY,Y\_MEMORY) RETURN Indexing may be selectively enabled only for the source 1 and destination operands. Figure 4-10 summarizes address translation for the screen refresh process, destination and source 1 raster operands. The output of the rasterop computation is an address in screen, memory or region coordinates. The interpretation is specified, in part, by the MicroVAX CPU which selectively enables indexing for either the first source or destination operands. Region coordinates cannot be used for the second source operand. The result, after indexing, may be further mapped by the Address Processor, if it is inside the screen refresh area. Figure 4-10 Address Translation When tiling is disabled, the origin of the destination raster defines the coordinate system for the second source operand. In this case, the MicroVAX CPU specifies the second source operand in terms of X and Y offsets from the destination. Figure 4-11 shows the computation of the second source physical memory address. Destination rasterop computation Region Coordinates V Add source 2 <--- Source 2 X offset offsets <--- Source 2 Y offset Memory coordinates V Figure 4-11 Source 2 Address Computation (Tiling Disabled) 4.1.5.1 Interactions Between Rasterops and Scrolling The effects of concurrent scrolling and rasterops are twofold. First, the process of down scrolling may alter the screen to memory mapping for data that appears stationary on the screen. Second, memory references by the rasterop process may 'collide' with the scrolling process. These interactions are explained below. 4.1.5.1.1 The Effect of Scrolling on Screen and Region Mapping - The bitmap is divided into the screen refresh area, the scrolling region, viewport area and offscreen memory. The Address Processor chip performs the following coordinate transformations: - Screen to memory mapping using the Y offset to map visible objects to physical memory. - Region to screen mapping using the X and Y index values If scrolling is ignored, the coordinate conversions can be performed by simply adding the appropriate constants. The effect of scrolling is threefold, first scrolling or dragging a viewport effectively changes its location with respect to the screen origin, hence the index values must be adjusted accordingly. Second, down scrolling requires adjustment of the screen to memory Y offset. Finally, the use of a single Y offset or set of indexes for coordinate mapping no longer works, when rasterops and scrolling are performed concurrently. To see why a single coordinate mapping fails during scrolling, recall that scrolling involves the movement of some portion of the visible data within the time required to scan one complete frame. During that time, the scrolling hardware makes a sweep of the bitmap in the downward direction, accessing the data to be moved one scan line at a time. At any instant then, the screen is divided into two pieces, the part above the current scan, consisting of data already moved and the part below the scan, containing data not yet moved. Thus, during this time, two mappings exist between the screen and the bitmap. One for shifted data above the scan and another for unshifted data. Therefore, without the features described below, scrambling would occur due to pixels being placed incorrectly in the destination raster or fetched incorrectly from the source. The hardware eliminates this 'scrambling' effect by providing an extra set of Y offset and index registers. These extra registers contain the new mapping for shifted data and are automatically referenced by the Address Processor chip when an address is generated which is in the scrolled part of the screen refresh area. The old mapping is automatically used for the unscrolled portion. The task of updating these registers is left to the MicroVAX CPU. To allow a full frame time for this operation, a third set of index and offset registers is provided to hold a set of pending values. At the completion of a frame, the Address Processor chip automatically advances the register values. Since all data has been scrolled, the 'new' values now represent the mapping for unscrolled data and are therefore copied to the 'old' registers. The pending values become the new values for scrolled data. The MicroVAX CPU will have a full frame time to compute and setup a new set of pending values for the next frame. The flow of data for this pipeline is illustrated in Figure 4-12 or the X and Y index registers. The index values are in the order X coordinate followed by Y coordinate. Note that at the completion of scrolling, the pending index value is simply allowed to propagate to the 'Old' and 'New' register sets. The index represents the screen co-ordinates of the upper left corner of a region. Scrolling or dragging a viewport effectively changes its location with respect to the screen origin, hence the index values must be adjusted accordingly. Conversely, if the viewport is not being scrolled, the index values are unchanged. 4.1.5.1.2 Collisions Between Rasterops and Scrolling - A collision occurs whenever a rasterop and the scroll process try to read or write the same memory locations in the bitmap. The hardware resolves collisions by suspending the rasterop until the scrolling process has moved on. Since scrolling accesses memory from the top of the screen to the bottom, the worst case for collisions occurs when the processing of one or more raster operands scans the screen refresh area in the downward direction. In this case, rasterop memory refrences, trailing behind the scroll process, repeatedly collide with scroll memory accesses. A way to limit such collisions is to specify the raster operand, so that it is scanned in the upward direction. In this way, only one collision per frame can occur during a rasterop. INDEXES AT START OF SCROLL From MicroVAX CPU | | V | | | | | | |-----------|-----------|---------------|------|--|--|--| | ++ | ++ | ++ | , | | | | | 10,34 < | 10,34 < | 10,35 Fram | ne N | | | | | ++ | ++ | ++ | | | | | | Old Index | New Index | Pending Index | | | | | INDEXES DURING SCROLLING From MicroVAX CPU From MicroVAX CPU INDEXES AT SCROLL COMPLETION ``` +----+ +----+ +----+ +----+ 10, 36 | Frame N + 3 +----+ Old Index New Index Pending Index ``` Figure 4-12 Index Registers for Two Pixel Down Scroll ## 4.1.6 Additional Operations on Bitmap Data In addition to conventional raster operations, and scrolling the following functions are supported by the hardware: o Polygon fill to fill the area between two vectors with any source of pixels such as a solid color, tile pattern or image #### PROGRAMMING INFORMATION - o Transferring data between the MicroVAX CPU and one plane in the bitmap to load a font or save and restore an occluded viewport - o A set of Z-axis operations for transferring one pixel value between the MicroVAX CPU and the bitmap in a single operation. This function is used to facilitate pixel operations that are not supported by the hardware, such as flooding or painting within the boundaries of a region having an arbitrary shape. In this case, the VCB02 hardware maps a pixel vector into a single 16-bit word to be read or written into the MicroVAX's address space. The VCB02 can map two pixel vectors into one 16 bit word when doing DMA. The above operations are all implemented as variations on the basic rasterop function. ## 4.2 Video Processor and Address Processor Chip Architecture The VCB02 video subsystem architecture divides all display operations into two orthogonal functions: the generation of addresses for bitmap data and logical operations on the data. The task of address generation is performed by the Address Processor chip. Logical operations on the data are performed by the Video Processor chip. The functional relationship between the Address Processor and Video Processor chips is shown in Figure 4-13. The Address Processor chip broadcasts memory addresses to the bitmap commands and data to each Video Processor chip on the I/D interconnect. Each Video Processor chip, running in lockstep, processes the bitmap data as directed by instructions on the I/D interconnect, control signals and instructions within its control registers. The I/D interconnect protocol allows any device to become bus master. Therefore, during raster operations, the video processor chips can serve as a source or destination for operands. This is useful for broadcasting common data, such as character fonts, to all the bit planes. Of course, only one Video Processor chip can serve as the source of data at any time while any number of chips can receive data. Figure 4-13 Address and Video Processor Chips Functional Diagram # 4.2.1 Address Processor Chip Architecture The Address Processor chip logically supports three separate and concurrent processes: - 1. CRT screen refresh - 2. Scrolling - 3. Raster operation and processor to bitmap transfers Figure 4-14 shows the relationships of these processes. Figure 4-14 Address Processor Chip Data Flow Each process, running concurrently, generates a bitmap address and an I/D interconnect command. The arbitrator resolves contention for access to shared resources, such as the I/D interconnect and bitmap based on the following requirements: - o Screen refresh cannot be interrupted - o Scrolling must not be visually disturbed - o Race conditions must be eliminated between the scroll and rasterop processes. Both screen refresh and scrolling share memory access on a "round robin" basis with the remaining time allocated for rasterops. During simultaneous raster operations and scrolling, the arbitrator will block the rasterop process when its memory accesses conflict with those of the scrolling process. # 4.2.2 Address Processor Chip Interface to the QBus The Address Processor chip is the gateway to the Video Processor chip, bitmap, and chipselect registers. As such, it provides access to this hardware through a set of register-level interfaces for commands and the interchange of data and status via the QBus. The register format and addressing is also designed to be an efficient interface to the DMA gate array. # 4.2.3 Video Processor Chip Architecture The function of the Video Processor chip is to process data appearing at its input pins as directed by instructions within in its control registers, commands on the I/D interconnect and hardwired signals from the Address Processor chip. Logically, the Video Processor chip has two data paths: one for rasterops and the other for scrolling and screen refresh. **4.2.3.1** Dataflow For Scrolling And Screen Refresh Figure 4-15 shows data flow through the Video Processor chip for scrolling and refresh. Figure 4-15 Video Processor Data Flow (Screen Refresh/Scrolling) The video processor chip will read 128 bits from the bitmap at a fast rate, storing the 128 bits in its internal FIFO. This allows the video processor to output the data on its video bus at a slower rate and while the memory bus is being used for updates and scrolling, untill another 128 bits is required. ## 4.2.3.2 Rasterop Data Flow Figure 4-16 shows the data flow for a rasterop. Operands are read and processed as directed by internal control registers by the following functional units: - o Operand fetch logic - o Combinatorial logic - o Masking and clipping logic Each rasterop cycle consists of the following events: #### PROGRAMMING INFORMATION - 1. The first and second source operands are read in sequence and routed to the appropriate functional unit as directed by the control store RAM. - 2. The destination is read and processed, additionally, it automatically becomes the second operand to the logic unit. - The logic function specified by Video Processor control registers is performed. - 4. The output of the logic unit is masked, clipped and written into the destination. Steps 2, 3 and 4 above are actually executed during in a single read-modify-write memory cycle. Figure 4-16 Dataflow For Rasterops **4.2.3.2.1** Video Processor Chip Operand Fetch - The purpose of the operand fetch logic is to route the operand to the appropriate functional logic within the Video Processor chip and optionally, to broadcast data on the I/D interconnect. Figure 4-17 shows how operands are processed. An operand fetch cycle is actually divided into two micro-cycles. During the first, internal input data from the bitmap is processed. During the second, external data from the I/D interconnect is read and optionally, a copy of the internal operand can be gated onto the interconnect. In Figure 4-17, the ganged switches indicate the data paths for each micro-cycle. The switch state shown is for the internal cycle. During this time, data from the bitmap is read, rotated into alignment with the destination raster and directed to a functional unit. During the external cycle, data from the I/D interconnect is also read and passed without rotation to the destination. Concurrently, a copy of the aligned internal operand can be output to the I/D interconnect. When this occurs, the output becomes the external operand for all Video Processor chips including the chip sourcing the data. The following parameters are specified by the control store RAM: - o The destination of the internal operand - o The destination of the external operand - Whether or not a copy of the internal operand will be placed on the I/D interconnect Figure 4-17 Operand Routing Functions 4.2.3.2.2 The Logic Unit - The logic unit is shown in Figure 4-18. The role of the input operand is to select either a foreground or background color to be displayed. A value of 1 will cause selection of the foreground color. A value of 0 will select the background. The foreground and background colors are parameters supplied by the MicroVAX CPU. The output becomes one of the input terms to the logic unit. The other term is always the destination operand. The logical function is determined by the logic function registers and may consist of any of the 16 possible functions of two operands and their complements. The result is sent to the masking and clipping logic. Figure 4-18 The Logic Unit 4.2.3.2.3 Masking and Clipping Logic - The masking and clipping section of the chip is shown in Figure 4-19. Figure 4-19 Masking and Clipping The mask registers can be setup with operands during each fetch micro-cycle by programming the appropriate operand destinations into the control store RAM. In most cases, both mask registers will require the same value, therefore, sending an operand to mask 1 automatically causes a copy to be written into mask 2. To set different mask values the control store RAM is programmed to write mask 1 followed by mask 2. Each mask is also controlled by a register that allows the mask register or its complement to be used to form the mask value. A mask value of '0' in a given bit position specifies than the corresponding bitmap location is to be unmodified. A 'l' indicates that the location is to be replaced with the output of the logic unit. - **4.2.3.2.4 Video Processor Chip Control Registers** The Video Processor chip contains two sets of registers that can be programmed by the MicroVAX CPU to control the execution of raster operations: - o Control store RAM (CSR's) that specify how operands will be transferred - Logic and mask control registers that determined the function of the logic unit and the polarity of the mask register output - 4.2.3.2.4.1 Control Store RAM Functions The operand fetch logic is controlled by a set of six control store ram divided into two banks of three locations. Within each bank, one location controls each operand. Every time a rasterop is performed, the MicroVAX must specify the bank of control store ram to be used. In this way, the software can preset two individual banks which will permit operations requiring two rasterop steps without reloading RAM locations. The following is a brief description of the control fields. - o Internal cycle destination: Specifies one of the following destinations for the internal operand: - The bit bucket - The Source register - Both Mask 1 and Mask 2 - Mask 2 only - External cycle destination: Specifies one of the following destinations for the external operand: - The bit bucket - The Source register - Both mask 1 and mask 2 - Mask 2 only - o I/D Interconnect Output Control: If set, place a copy of the aligned internal operand on the I/D interconnect during the external operand micro-cycle. Note that every operand fetch cycle involves the execution of an internal and an external micro-cycle. Therefore, for all CSR's referenced by an operation, the dispostion of data during both micro-cycles must be explicitly specified. If the data from either cycle is unwanted, the appropriate destination field to place the result in the bit bucket must be set. 4.2.3.2.4.2 Logic Unit Function Registers - The logic function control registers determine the operation performed by the logic unit and the polarity of the mask register output applied to the result. Four registers are available and can be preset by the MicroVAX CPU but only one is used for a given operation. The register number is a parameter of the rasterop command. The logic unit operates on the output of the background/foreground select register and the contents of the destination raster. The masks applied to the output determine which pixels in the destination raster will be modifed. The logic function control registers have the following fields: - o Logic unit function: - One of the following functions can be programmed: - Output = Zeros - Output = NOT (Destination OR SOURCE) - Output = NOT (Destination) AND SOURCE - Output = NOT (Destination) - Output = Destination AND NOT (SOURCE) - Output = NOT (SOURCE) - Output = Destination XOR SOURCE - Output = NOT (Destination AND SOURCE) - Output = Destination AND SOURCE - Output = NOT (Destination XOR SOURCE) - Output = SOURCE - Output = NOT (Destination) OR SOURCE - Output = Destination - Output = Destination OR NOT SOURCE - Output = Destination OR SOURCE - Output = ONES - o Mask Register 1 control If set, use the complement of mask register 1 - o Mask Register 2 Control If set, use the complement of mask register 2. - o Source Register Control If clear use complement of the source register. - o Resolution Mode Logic for Source Register Control If clear enables resolution mode logic for the Source register. ## 4.2.4 I/D Interconnect Protocol The I/D Interconnect is a multidrop interconnect that can be used by the Address Processor chip and any Video Processor chip to send and receive data. Update and scroll ship select registers are connected to the interconnect and specific Address Processor commands are available for sending data to them. The role of the Address Processor in an I/D interconnect transaction is implicitely determined by the function being performed. During a processor to bitmap transfer for instance, the Address Processor chip will be transmitting data from the I/D interconnect to one or more Video Processor chips. During a bitmap to processor transfer, it will act as a receiver. Otherwise, unless explicitely specified, the Address Processor chip neither sends or receives data. The role of each Video Processor chip is determined by the contents of its control store ram and logic function registers. During the processor to bitmap transfer, for example, at least one Video Processor chip must be programmed to receive external data during the appropriate operand cycle. During a full plane bitmap to processor transfer, one and only one Video Processor chip will be programmed to source data on the I/D interconnect. During a Z-axis transfer, when part or all of a pixel is being sent to the MicroVAX CPU, each Video Processor chip will be programmed to 'source' its portion of the pixel value at the appropriate bit position on the interconnect. This is the only case where multiple sources are allowed (with the restriction that no two Video Processor chips attempt to drive the same bit concurrently). Broadcasting data from one Video Processor chip to others during a rasterop requires the following actions: - 1. The processor selects a memory plane and its associated Video Processor chip to serve as the source of data for broadcast to other Video Processor chips during a raster operation. - 2. The appropriate operands are defined enclosing the data to be broadcast (first source, second source or destination). - 3. For the chip broadcasting the data, the CSR associated with the selected operands are programmed to place a copy of the data on the interconnect during the external micro-cycles. - 4. For each chip receiving the data, the CSR's associated with the selected operands are programmed to receive data during the external micro-cycle. For a given raster operation, the configuration of receivers and transmitter can be different for each operand. For example, in a system with four planes, numbered 0 through 3, the configuration for each operand cycle might be as follows: Cycle Transmitter Receiver Source 1 Video Processor Chip 0 Video Processor Chips 1, 2 Source 2 Video Processor Chip 2 Video Processor Chip 0 NOTE The hardware does not prevent multiple writers on the I/D interconnect. It is the responsibility of the programmer to insure that multiple writers do not attempt to place data on the I/D interconnect 'at the same time'; that is, during the same operand cycle. Should this occur, the interconnect contents will be garbled and there is a possibility that the inbut output circuits will fail electrically. #### 4.2.5 The Rasterop Process This section discusses the algorithms used by the Address Processor chip to generate operand addresses. #### 4.2.5.1 Raster Scanning Algorithm Figure 4-20 shows a raster defined by an origin and two vectors that enclose an area containing the pixels to be processed. | | ^ | |------------|---------------------------------------| | | | | Slow | | | Vector | · · · · · · · · · · · · · · · · · · · | | (Sweep | | | Direction) | · · · · · · · · · · · · · · · · · · · | | | Fast Vector | Figure 4-20 Raster Scanning The algorithm for generating pixel addresses within the raster involves moving one vector along a path traced out by the other vector. The vector defining the path is referred to as the slow vector; it is traversed only once per scan. The other edge vector, called the fast vector, is traversed at each point along the path traced out by the slow vector. Points along each vector are computed using Bresenham's algorithm. To allow an image to be created with multiple raster operations, the vector computation excludes the last point. This feature is intended to support 'complement mode' writing, in which an image is erased by writing its complement back into the bitmap. For this to work, all pixels in an image must be written an odd number of times. If vector generation included the last point, the first point of the adjoining raster would trace over the boundary a second time, leaving a residue of unerased pixels. For an ideal scanning algorithm, each pixel within the raster would be addressed once and only once during a raster operation regardless of the orientation of the edge vectors. In fact, under certain conditions one of the following will occur: - 1. A pixel within the raster boundaries will be addressed more than once during a rasterop. - 2. A pixel within the raster boundaries will not be addressed at all during a rasterop. These conditions never happen when a vector is parallel to the ${\tt X}$ or ${\tt Y}$ axis or at right angles to the other edge vector. Failure to address a pixel will leave holes in the resulting image. The appearance of the image can be partially corrected by a hardware feature that, optionally, fills in such holes. Hole-fill is particularly useful when text is written into the bitmap by rotating and transforming a rectangular font. Addressing a pixel more than once can affect the process of erasing an image by writing its complement into the bitmap. In such cases it is advisable to first create the image offscreen, then manipulate it with a rectangular rasterop. Other kinds of distortion arise when a rectangular raster is scaled, rotated or transformed into a parallelogram with edges at an angle other than 90 degrees. In these cases, information may be lost because the number of pixels in the destination raster is not the same as the source. ### 4.2.5.2 Specification of Operands for a Rasterop A rasterop may have the following operands: - O A destination raster, with fast and slow vectors of any size and orientation - o A primary source raster, called source 1, that can be used for spatial transformations on a rectangular raster (rotation, scaling etc.) and linear pattern generation. The fast vector is always parallel to the Y axis. o A secondary source raster, called source 2, that can be used to copy a raster of any shape or orientation or generate a tile pattern All operands are optional. The Address Processor chip allows the generation of a specific operand raster to be suppressed, when it is not required for a given function. In this case, the contents of the associated control store RAM locations in the Video Processor chip are not referenced and therefore need not be setup by the MicroVAX CPU. - **4.2.5.2.1 The Destination Operand** The destination operand is specified by the following parameters: - The coordinates of the origin - The coordinate system used (either screen or region coordinates) - The slope and extent (DX and DY) of the slow vector - The slope and extent (DX and DY) of the fast vector Region coordinates may be used when a raster is within a region or viewport. In this case, before executing the rasterop the MicroVAX CPU must setup the Address Processor chip index registers with the values required to translate the region coordinates to screen coordinates. - **4.2.5.2.2** The First Source Operand The first source operand is a rectangle with edges parallel to the X and Y axis. The fast vector is in the Y direction. The raster is defined by the following parameters: - The location of the origin - The direction of the fast and slow vectors ( + or ) - The coordinate system used (either region or screen coordinates) - A scale factor relating the length of fast source to fast destination vectors - A scale factor relating the length of slow source to slow destination vectors - When linear patterns are generated, the length of the pattern in the X and Y directions 4.2.5.2.2.1 Mapping and Scaling the Source 1 Operand - During each rasterop cycle, the Address Processor chip generates an address in the source 1 raster followed by an address for the destination. Within that cycle, the Video Processor chip will combine the pixels at the source and destination as directed by its control registers. The path traced by the source and destination address pairs over time determines the source to destination mapping. In Figure 4-21, pixels scaled in dimension by a factor of a thousand or so, shows this relationship for the simple case of two rectangular rasters having a width of one pixel and a scale factor of one. The lower case letters indicate pixels being copied from the source to the destination. | Time | Source 1 | Destination | Time | |------|--------------|-------------|------| | | ++ | ++ | | | 1 | : a ! | a' | 1 | | | ++ | ++ | _ | | | ++ | ++ | | | 2 | , <b>b</b> ; | b' - | 2 | | | ++ | ++ | _ | | | ++ | ++ | | | 3 | · C | c' | 3 | | | ++ | ++ | | | | ++ | ++ | | | 4 | đ | d' | 4 | | | ++ | ++ | - | Figure 4-21 Simple Rasterop The numbers indicate the time sequence in which each pair of source and destination addresses is computed. At a scale factor of 1, a new source address is generated in step with each new destination address. Figure 4-22 shows the mapping between the first source and a destination vector at some angle with respect to the X axis. | 1 | |---| | | | | | 2 | | | | | | 3 | | | | | | 4 | | | | | Figure 4-22 Rasterop With Rotation Observe that rotation has introduced an aberration in the length of the destination vector. This distortion can be be partially corrected by introducing a scale factor between the source and destination. To clarify the scaling process, recall that at a scale factor of l, precisely one new point in the source is sampled for each new point in the destination. That is, the source and destination addresses both have the same rate of change. A change in scaling is produced by increasing or decreasing the rate of change between the source and destination addresses. Figure 4-23 shows the variation of source and destination addresses with time when the source is scaled up by a factor of 2. The numbers indicate the time sequence of each sample. A new source sample is taken on every other destination sample, effectivly stretching each source pixel by the scale factor. | Time | Source | Destination | Time | |------|----------|-------------|------| | | ++ | ++ | | | 1,2 | a † | a' | 1 | | | ++ | ++ | | | | ++ | ++ | | | 3,4 | <b>b</b> | a'+ | 2 | | | ++ | ++ | | | | | ++ | | | | | <b>b'</b> | 3 | | | | ++ | | | | | ++ | | | | | b' | 4 | | | | ++ | | Figure 4-23 Scaling Up The Source By Two Figure 4-24 shows what happens when the source is scaled down by a factor of 2. In Figure 4-24 at time 1, the address of the source points to pixel "a". It is copied to the destination as shown. At time 2, the source address is incremented to pixel "b". The destination address is unchanged. The copy function overwrites the destination with "b'". Because the destination address changes at half the rate of the source, two source pixels will be compressed into one destination pixel as shown. A side effect of down-scaling is that 'complement' writing will not properly erase an image, since a point in the destination is addressed more than once. This problem can be solved by manipulating the image in a staging area, then using a rectangular rasterop to update the screen refresh area. As the previous figures illustrated, regardless of the scale factor, the extent of a rasterop is governed by the dimensions of the destination raster. That is, the rasterop process completes, when one pass over the destination raster is made. | Time | Source | Destination | Time | |------|------------|-------------|------| | • | ++ | ++ | 1 2 | | 1 | a ++ | b' <br>++ | 1,2 | | | ++ | ++ | | | 2 | <b>b</b> • | d' | 3,4 | | | ++ | ++ | | | | ++ | ++ | | | 3 | C | f'; | 5,6 | | | ++ | ++ | | | | ++ | ++ | | | 4 | d | h ' | 7,8 | | | + + | ++ | | | | ++ | | | | 5 | <b>e</b> | | | | | ++ | | | | | ++ | | | | 6 | <b>f</b> | | | | | ++ | | | | | ++ | | | | 7 | <b>g</b> | | | | | ++ | | | | | ++ | | | | 8 | <b>h</b> | | | | | ++ | | | Figure 4-24 Source Scaled Down By A Factor Of Two 4.2.5.2.2.2 Linear Pattern Generation - This section discusses how the linear pattern mode in the Address Processor chip can be used to generate a pattern aligned with the destination raster boundaries. The source I raster is a rectangle whose extent is usually proportional to the size of the destination fast and slow vectors. In this case, a rasterop simply transforms the source into a scaled and rotated copy in the destination. In linear pattern mode, the source I raster contains a pattern that is scaled and replicated within the destination raster limits. The parameters of the pattern are the co-ordinates of the source I origin and the source I extent in the X and Y directions. The process for generating a pattern is shown in Figure 4-25. Figure 4-25 Linear Pattern Basically, linear pattern generation is produced by a simple modification of the source 1 raster algorithm which resets a source edge vector, when the appropriate pattern limit is reached. All other aspects of source 1 operand address computation are unchanged, therefore the pattern can be scaled by applying the scale factors. The pattern repeat cycle is determined by the extent of the source DX and DY vectors and the scale factor. In Figure 4-25, a scale factor of one is used. During a fast scan, source addresses are incremented in the X direction at a rate determined by the scale factor. When the DX limit is reached, the source address is reset to the beginning and the source fast vector is scanned again to create the pattern effect along the destination fast vector. Similarly, during a slow scan step, the slow source vector is incremented until the DY limit is reached. At that time, the slow vector is reset and the pattern is scanned again from the origin. - **4.2.5.2.3** The Second Source Operand The second source operand can be used in one of the following ways: - o To generate a tile pattern from a rectangular raster o To copy pixels from a source raster having the same shape as the destination. When used to generate tile patterns, this operand is defined by the following parameters: - o The origin of the pattern in memory co-ordinates - o The length and width of the pattern When used to copy a raster, the source origin is specified by an offset relative to the unindexed co-ordinates of the destination. The fast and slow source vectors have the same length and orientation as the destination vectors and there is no scaling between source and destination. Figure 4-26 shows the mapping of source 2 to destination pixels for a destination raster having a width of 1. Source 2 Destination Figure 4-26 Mapping of Source 2 to Destination During each rasterop address cycle, the hardware computes the source 2 operand address by applying the offset to the unindexed destination address. 4.2.5.2.3.1 Tiling - Unlike a linear pattern, a tile is always aligned with the X and Y axis. The function of the tiling logic is to generate a textured surface that has an origin coinciding with the coordinate system of the screen. In this way, the tiling of overlapping images is always in registration. Tiling an image is equivalent to uncovering the surface, revealing the tiled pattern underneath. The tile dimensions are independent of each other and are restricted to powers of two, ranging from 2^2 to 2^9. The tile width may never be less than the memory bus width, but smaller tile elements can be defined by repeating the tile elements within the cell. For proper alignment of adjoining tiles, the dimensions of the imbedded pattern must be a multiple of two. The key to tile pattern generation is the use of modulo arithmetic in the tile address computation. The tile pattern is generated as follows: - 1. The destination address is computed using the raster scan algorithm. - 2. The destination address is reduced to a modulus of the tile size. - 3. The result of step 2 is added to the source 2 origin. Note that tiling is disabled simply by omitting step 2. ## 4.2.5.3 Model of Raster Operations The model shown in Figure 4-27 summarizes the rasterop capabilities described in previous sections. Figure 4-27 Simplified Rasterop Model The operands in Figure 4-27 are defined as follows: Operand A: = Operand B, Source 1 raster or linear pattern, Source 2 raster or tile, Destination raster, Constant, I/D Interconnect data Operand B, Operand C := Source 1 raster or linear pattern, Source 2 raster or tile, Destination raster, Constant, I/D Interconnect data The functional units consist of: - o The map function which includes the logic register and foreground/background selection - o Mask logic functions that can form the mask from the operand or its complement. #### 4.2.6 Polygon Fill The polygon fill feature uses the rasterop logic to generate a sequence of addresses that cover the space between two edge vectors. The enclosed space can be filled with a solid color, tile pattern or image. A fill operation is defined by the two edge vectors and a fill vector that is parallel to the X or Y axis. The first edge vector, called the A vector, is defined by the parameters normally used to specify the origin and slope of the slow destination vector. The second edge vector, called the B vector, is specified by the source 1 origin, DX and DY parameters. The fill vectors connect points on the A vector to corresponding B vector points as shown in Figure 4-28. To permit joining of fill areas, the fill stops one point shy of the endpoint. At completion, the Address Processor chip retains the final source and destination addresses. These can be used as the origins for a subsequent fill operation. In this case, only the new slopes would have to be specified. The fill operation is defined by the following parameters: - The fill direction, which is parallel to either the X or Y When there is a choice, the X axis should be selected for performance reasons - The 'A' edge vector, specified using the destination slow vector origin, DX and DY - The 'B' edge vector, specified using the source 1 origin, DX The source origin need not be coincident with the destination, however, it must be possible to connect the source and destination origins with the first fill vector. Also, the edge vectors may intersect. When this occurs, filling continues, but the direction of the fill vector is reversed. The destination pixels are within the trapezoid enclosed by the A and B vectors. The source pixels are determined by the second source operand specified. A special case of the fill operation allows a polygon to be filled from a baseline that is parallel to the X or Y axis. this instance, only the X or Y component of the source 1 vector must be specified depending on the fill baseline. The fill operation is a variant of the basic raster operation and shares most of the rasterop logic, therefore the following parameters should be set as follows: o Address Processor Chip: -Source 1 Operand: -Scale factors: -Source 2 Operand: -Clipping mask: Disabled Set to 1 As required, can be disabled, set for tiling or image modes As required o Video Processor Chip: -Destination control store RAM - Setup to process the pixels addressed by the Address Processor chip parameters -Source 2 control store RAM - Required if the source 2 operand is used for tiling or image generation 4.2.6.1 Polygon Fill Model The model shown in Figure 4-29 summarizes the polygon fill functions described in the previous section. The operands in Figure 4-29 are defined as follows: Operand A: Operand B, Source 2 raster or tile, Destination trapezoid, Constant, I/D Interconnect data Operand B, Operand C: Source 2 raster or tile, Destination trapezoid, Constant, I/D interconnect data +-----+-----Operand A Operand B Operand C +------+----Logic Function | V -----> Mask l Logic -----> Mask 2 Logic Figure 4-29 Polygon Fill Model +----- +----- Destination | -->-- **4.2.6.2** Side Effects of the Fill Algorithm When filling a polygon, the program must account for the following side effects: - Filling does not include the last point on the edge vector, therefore, the firmware must account for any unfilled vertices that result. - 2. When regions are abutted or the edge vectors intersect, interior points may be addressed twice with the usual adverse effect on complement writing. To understand the problem with adjoining areas, a closer look at the algorithm is required. In minimizing the occurance of doubling, the fill algorithm attempts to draw one and only one fill vector between edge vectors at a given X or Y coordinate. Figure 4-30 shows succesive points along the unfilled edge vectors. Because of the finite resolution, any vector approximation algorithm will occasionally generate two points in succession that have the same X or Y coordinate. To insure that only one fill vector is drawn between edges, the Address Processor chip connects only the OUTERMOST points along the fill direction. | vector | B vecto | |--------------|---------| | 1 | 1 | | + | + | | 2 | 2 | | + | + | | 3 | 3 | | <del>+</del> | + | | 4 5 6 | 4 5 6 | | + + + | + | | 789 | 789 | | + + + | + | | | | Figure 4-30 Edge Vectors Before Fill Figure 4-31 replicates Figure 4-30, but with the fill vectors drawn in. The "X" marks the last point on each edge vector. | A | vector | В | vector | |---|--------|-------|-----------| | | 1 | | 1 | | | 2 | • • • | 2 | | | 3 | • • | 3 | | | 4 5 6 | | 4 5 6 | | | 7 8 9 | • • • | <br>7 8 9 | | | x | | x | Figure 4-31 Filled Area If the fill is continued from the end points shown in Figure 4-31, the next fill vector will be coincident with the last vector drawn. This is illustrated in Figure 4-32. The 'doubled' points are marked with an asterisk "" | A vector | B vector | |-----------------|----------| | 1 | 1 | | 2 | 2 | | 3 | 3 | | 4 5 6 | 4 5 6 | | 7 8 9 10 | 7 8 9 10 | | *********<br>11 | 11 | | | | Figure 4-32 Filled Area Continuation to Show Doubling Since only the outermost points are connected, doubling will not occur when the edge vectors are outbound. This is shown in the Figures 4-33 and 4-34 which illustrate successive fill operations with diverging edge vectors. | A Vector | В | Vε | ector | |----------------|---|--------|-------| | 3 2 1 | 1 | 2 | 3 | | 6 5 4<br>X + + | | 5<br>X | 6 | Figure 4-33 Diverging Edge Vectors In Figure 4-33, point 6 is the A vector end point. The fill operation terminates one point before this, at point 5. Since this is not the outermost point along the fill axis, no fill vector is drawn. Continuing the fill as shown in Figure 4-34, does not result in doubling. | A Vector | | Vec | tor | |-------------------|-------|-----------|-----| | 3 2 1 | | 1 2 | 3 | | 6 5 4 | • • | 4 5 | 6 | | 9 8 7 | • • • | 7 8 | 9 | | 12 11 10<br>X + + | 12 | 2 11<br>X | 10 | Figure 4-34 Filled Area With Diverging Edges In general, joining two fill areas will result in doubling anytime at least one of the previous edge vectors approaches the opposite vector with a slope of less than 1:2, with the longer component in the fill direction. One way to compensate for doubling in complement mode is to write the doubled pixels an 'odd' number of times. A partially effective algorithm involves preceding the next area fill with a fill command, using a unit vector inbound followed by a unit vector outbound. The inbound vector draws a single fill. The outbound vector repositions the edge vector without drawing a fill vector. The first fill vector drawn by the area fill command will address the doubled points for the third time. This approach fails, when the edge vector has a slope that results in three or more points along the same fill vector at the endpoint. Basically, it is recommended that you avoid complement mode writing for polygon fill. #### 4.2.7 Processor/Bitmap Transfers Processor/Bitmap transfers allow the MicroVAX CPU to copy the contents of a rectangular raster, aligned with the X and Y axis, to or from system memory. These operations are similar to rasterops, except that the source or destination is the Q-BUS. The following kinds of operation can be performed: - Transferring the portion of a raster that resides in a single plane of memory - o Transferring the value of each pixel in a raster. Single plane transfers provide a bit-efficient way to save and restore an image. Pixel transfers are efficient, when an image is to be processed in the MicroVAX CPU, as would be the case for a flood operation. Like rasterops, the actual logical operations are determined by a control register in the Video Processor chip. Also, data written into the bitmap will be masked by the clipping rectangle. # **4.2.7.1** Single-Plane Bitmap to Processor Transfers A single plane bitmap to processor transfer moves data from a raster in the bitmap to the MicroVAX CPU by way of the Address Processor chip. This operation is defined by the following parameters: - Origin Source 1 operand coordinates - Fast vector Destination fast vector aligned with the X axis - Slow vector Destination slow vector aligned with the Y axis - Destination origin : Determines the alignment of data placed on the I/D interconnect for transmission to the MicroVAX CPU - Video Processor chip control store RAM location to be used (can be CSR 1 or 2 in either bank) Alignment of the fast and slow vector is required to allow the MicroVAX CPU to easily compute the space required for raster storage. Although the destination parameters are specified, no data is actually written into the bitmap. Instead, the destination origin is simply used to establish the correspondence between bits in memory and data on the I/D interconnect. For the Video Processor chip transmitting the data, the control store RAM location specified in the Address Processor chip must have the I/D interconnect output enabled. The corresponding CSR in all other Video Processor chips must have the I/D interconnect output disabled. Alternatively, the other Video Processor chips can be deselected by means of the chip select register. The series of raster addresses are generated by traversing the fast and slow destination vectors. The source address is computed by adding the offsets from the destination raster to the source 1 origin. Each time the fast vector is exhausted, a step along the slow vector is taken. As mentioned earlier, the mapping between data in the bitmap and the contents of the I/D interconnect is determined by the origin supplied for the destination raster. To see how this works, realize that the smallest unit of transfer between the bitmap and Video Processor chip is a single 16 bit word whose bitmap address is a multiple of 16. These limits are termed 'natural memory boundaries'. For a normal rasterop, the Video Processor chip has to align the source operand so that the position of a bit relative to the raster boundaries is preserved when the data is copied to the destination. This almost always results in a difference between the location of the bit relative to the natural boundaries of the source and destination. The effect is shown in Figure 4-35. The '+' character denotes word boundaries in the bitmap. Figure 4-35 Source to Destination Alignment As indicated in Figure 4-35, the alignment of raster contents can be preserved by shifting the data relative to the natural word boundaries. The shift amount is equal to the difference between the X coordinate of the source and the X coordinate of the destination, converted to a modulus of 16. The resulting I/D interconnect data word is a copy of the source, after it has been aligned with the corresponding word in the destination raster. Since, as mentioned earlier, the destination is not written, the destination address can therefore be used simply to align the raster within the I/D interconnect data word. In some cases, it is desirable to align the Y edge of the raster with bit 0, hence a destination origin of 0,0 is used and destination indexing is disabled. To further show the effect of shifting, Figure 4-36 illustrates how a source raster is packed into system memory for various Bitmap destination raster X addresses. Note that increasing pixel addresses in X correspond to increasing bit positions. Each character represents the state of one bit in refresh memory. MicroVAX CPU | Source l origin | at | 15,0 | | | | | | | |------------------------------------------------|----|------|-------------------------|-------------------------------------------------------------------------|----------------|-------------|----|------| | 15<br>V<br>10000000000000000000000000000000000 | | •••• | | 0000000000 | | Destination | at | 0,0 | | 10000000000000000000000000000000000000 | • | | 00000<br>XXXXX<br>00000 | 0000000000<br>KXXXXXXXXX<br>1000000000<br>KXXXXXXXXXXXXXXXXXXXXXXXXXXXX | LX<br>CO<br>LX | Destination | at | 1,0 | | | | | X0000 | XXXXXXXXX<br>000000000<br>XXXXXXXXX<br>000000000 | 00<br>KX | Destination | at | 15,0 | Figure 4-36 Bitmap to Processor Mapping (Simple Case) The 'X' symbol in Figure 4-36 represents bits read in from areas to the left or right of the source due to the shifting needed to align the source raster with the destination. Observe how the destination alignment effects the number of MicroVAX memory locations required to store the data. When the left edge of the source raster is aligned with bit 0 of the destination, 16 bits of source data are contained in a single 16 bit word in the destination. When the left edge is not aligned, the source data spans two 16 bit words in local memory. Figure 4-37 shows a more general case, where the source raster is larger than the memory bus width and local memory word size. MicroVAX CPU Bitmap Source 1 origin at 15,0 15 33 15 0 1000000000000000011 00000000000000001 --> Destination at 0,0 100000000000000011 XXXXXXXXXXXXXX11 0000000000000001 XXXXXXXXXXXXX11 Raster Width 000000000000001X Destination at 1,0 XXXXXXXXXXXXX110 00000000000001X XXXXXXXXXXXXX110 1XXXXXXXXXXXXX Destination at 15,0 10000000000000000 XXXXXXXXXXXXXXX 1XXXXXXXXXXXXXX 10000000000000000 Figure 4-37 Bitmap to Processor Mapping (General Case) XXXXXXXXXXXXXXX From the example shown in Figure 4-37, it is clear that the space to store a raster in local memory depends partly on the alignment of the destination raster origin. The space computation is performed by: - 1. Determining the number of natural words in the bitmap that would be spanned by the destination fast vector - Multiplying this value by the height of the destination raster Based on the above, the following procedure can be derived: ! ! Compute the number of natural words spanned by the ! fast vector. Only integer division is used. ! ! Truncate the starting address to a word boundary ! Xl := (DESTINATION X/16) \* 16 ! ! Compute the endpoint in the X axis and round up to ! the nearest word boundary ``` ! Compute the end point co-ordinate ! X2 := DESTINATION X + DESTINATION X LENGTH ! ! Round up to a multiple of the word size ! X2 := ((X2 + 16)/16 ) * 16 ! ! Compute the number of words spanned by the X vector ! X WORDS = (ABS (X2 - X1))/16 ! ! Compute the total number of words required ! N WORDS = X WORDS * ABS (DESTINATION Y LENGTH) ``` Of course, all of the above can be simplified by suitable optimization. - **4.2.7.2** Processor to Bitmap Single Plane Transfers The following parameters are required for a single plane processor to bitmap transfer: - Origin and extent of the destination raster defining the pixels to be transferred. The fast vector must be aligned with the X axis. The slow vector is aligned with the Y axis. - o The clipping rectangle - o The logic function register to be used. - o The logic function programmed appropriately - o A Video Processor chip control store RAM location that is setup as follows: - -Internal cycle destination field As required by the function - -External cycle destination field Setup to receive data from the I/D interconnect and process it as required by the function. - -I/D interconnect output Must be disabled All other Video Processor chips can be excluded from the transfer by either programming the CSR or update chip select register accordingly. Data supplied from the MicroVAX CPU is placed on the I/D interconnect and from there is written into the bitmap without rotation. The sequence of bitmap locations is determined by the by the destination raster scanning algorithm. The mapping from host memory or I/D interconnect to bitmap memory is shown in Figure 4-38. Figure 4-38 Processor to Bitmap Mapping The portion of the data word that is outside the raster boundaries is masked out. Since the output is not rotated, it is the responsibility of the local processor to ensure that the data is aligned properly before being written to the bitmap. To visualize the problem, consider the example shown in Figure 4-39. The '+' character marks addresses in the bitmap that are multiples of the memory bus width. Step 1 - Bitmap to Processor Transfer Step 2 - Processor to Bitmap Transfer Figure 4-39 Alignment Error Example In Step 1 of Figure 4-39, data is transferred from the bitmap that results in each 16-bit bitmap segment being shifted into alignment with bit 0 in local memory. In Step 2 of Figure 4-39, the contents of local memory is later written back into the bitmap at the same location from which it was read, but without the shifting required for proper alignment. Since each memory word is written into the bitmap, so that it is aligned with the natural boundaries; the image is shifted left with respect to its original position. The part outside of the raster limits is actually masked and the part of the image adjacent to the right boundary is replaced with the random data that was in the high order bits of local memory. The corrective alignment of output data can be accomplished by: 1. Aligning the data on input from the bitmap based on knowledge of where the output raster will be located. - 2. Emulating the Video Processor chip barrel shifter function on output - 3. Forcing a raster to be aligned on natural bus width boundaries The first method is suitable for saving and restoring an image in place using a DMA device. In this case, the number of words to be transferred is computed as shown in the previous section. On the bitmap to processor transfer, the Video Processor chip will automatically perform the required alignment. The resulting raster is then transferred to local memory and the following parameters are saved: - The parameters of the original raster, including the origin and dimensions. - The number of words transferred To restore the image, the output raster is defined using the parameters saved earlier and the DMA device is requested to transfer the specified number of words. The output is automatically masked to the raster boundaries. In the second case, the goal is to emulate the Video Processor chip barrel shifter by shifting the data based on the difference between the X coordinate of the input and output rasters (modulo 16). During the bitmap to processor transfer, the data may be aligned in any convenient manner by specifying the destination raster address appropriately. On output to the bitmap, the shift is performed by the MicroVAX CPU, concatenating adjacent words as required. The net shift amount, between input and output, must equal the difference computed as described above. The disadvantage of this method is that, on output, it is not amiable to processing by a DMA engine. The third method is also useful when the ultimate destination is not known. This procedure lends itself to a DMA processor, but incurs added overhead for an additional rasterop. In this case, the input raster parameters for the bitmap to processor transfer are modified by truncating the origin and rounding up the X dimension; so that both are a multiple of 16. The raster is stored in system memory using the modified dimensions. Restoring the image is a two step process. First, the image is transferred to a staging area in offscreen memory using the adjusted dimensions; then it is moved to the ultimate destination using the original raster dimensions. Data outside of the raster limits is masked out (i.e., the external area is not modified). #### 4.2.7.3 Z-Axis Processor/Bitmap Transfers Z-axis transfers move the contents of a raster, aligned with the X and Y axis, to or from local memory one pixel at a time. Each data word represents up to 8 bits of pixel value. Since each transfer involves only one pixel, there are no requirements for shifting or alignment. Data is transferred by scanning the fast vector which sweeps out a path defined by the slow vector. Like a rasterop, the scanning algorithm does not trace out the last point, therefore the raster parameters must be adjusted accordingly. - 4.2.7.3.1 Z-Axis Bitmap to Processor Transfers Z-axis transfers from the bitmap to the processor move the contents of a source raster that is aligned with the X and Y axis. The operation is defined by the following parameters: - The raster size Defined by the magnitude of the fast and slow destination vectors. The fast vector must be parallel to the X axis and the slow vector parallel to the Y axis. - The raster origin Defined by the coordinates of the source l operand. The number of words transferred is equal to the total number of pixels enclosed by the raster. - **4.2.7.3.2 Z**·Axis Processor to Bitmap Transfers Z-Axis transfers from the processor to the bitmap fill a destination raster with pixel values contained in local memory. The following parameter defines the transfer: - A destination raster defined by the origin and extent of the destination operand As for the bitmap to processor transfer, the number of pixels is defined by the total number of pixels enclosed by the raster. #### 4.3 Address Processor Chip Description The interface from the MicroVAX CPU to the video processor chips and bitmap is through a set of Address Processor chip registers that: - 1. Set system and CRT timing - 2. Hold rasterop and scrolling parameters - 3. Control Address Processor chip operation Unless otherwise specified, all registers are write only and numerical registers contain a 14-bit, two's complement value (including sign). The upper 2 bits are unused and must be set to zero. In some cases, loading a register causes a specific system action to be taken. This is noted in the register's description. #### 4.3.1 Coordinate Systems In the VCB02 video subsystem, images are referenced through two cartesian coordinate systems: - Memory coordinates, referenced to the origin of the physical bitmap memory space - 2. Screen coordinates, referenced to the upper left hand corner of the CRT. In either case, X increases to the right and Y increases downward: #### 4.3.2 Address Processor Chip Commands All Address Processor chip commands are written into one of the following registers: - o The COMMAND register, for update commands - o The ID\_SCROLL COMMAND register, to load an I/D interconnect command while a rasterop is in progress. The contents of the high byte are ignored. The scroll command port is provided for the Video Processor chip registers to perform loading of various scrolling functions without interfering with rasterops that are in progress. The sole function of this port is to issue I/D interconnect commands. Therefore, the contents of the high byte are ignored. #### 4.3.2.1 Rasterop Command Implicit Inputs: The following Video Processor chip registers must be setup: o For each enabled operand The appropriate CSR in the selected bank. Within each bank, the Address Processor chip makes the following assignment of CSR's to operands: Bank 0 or 1, CSR 1 = Source 1Bank 0 or 1, CSR 2 = Source 2 Bank 0 or 1, CSR 3 = Destination o The logic function register specified in the command word. The following Address Processor chip registers must be setup: o Destination operand parameters: DESTINATION X - Destination X origin DESTINATION Y - Destination Y origin FAST DEST DX - Destination fast DX FAST DEST DY - Destination fast DY SLOW DEST DX - Destination slow DX SLOW DEST DY - Destination slow DY o If the source l operand is enabled: FAST\_SOURCE\_1 DX - Fast source 1 DX increment SLOW SOURCE 1 DY - Slow Source 1 DY increment SOURCE 1 X - Source 1 X origin SOURCE 1 Y - Source 1 Y origin FAST SCALE - Fast vector scale factor SLOW SCALE - Slow vector scale factor o If the source 2 operand is enabled: SOURCE 2 X - Source 2 X origin SOURCE 2 Y - Source 2 Y origin SOURCE 2 SIZE - Source 2 height, width and tiling enable flag - o MODE set as follows: - <1:0> Set to one of the following values: - 00 = Normal mode. Source area is determined from the scaled destination area - 10 = Linear pattern mode - <4> - Hole fill enable, as required. - <5> - First source indexing enable, as required. Will - usually be set, if the first source is within a region. - Destination indexing enable, as required. Will usually be set, if the destination is within a region. - Pen Down, as required. Set based on whether or not the destination raster is to be written. - 4.3.2.1.1 Rasterop Protocol The following protocol is used to initiate a rasterop. ROUTINE NEW RASTEROP (Video Processor chip parameters, Address Processor chip parameters) - ! This entry point is called, when starting a new rasterop. That is, - ! when the last function issued through the command register is - ! different than the one to be issued - ! Wait until it is safe to load all registers WAIT UNTIL STATUS <address output complete> IS SET Load Video Processor chip parameters Load Address Processor chip parameters Load Rasterop Command #### Return The following protocol is used when continuing a rasterop. Continuation is defined as a repetition of the last rasterop command, modifying only the source l and destination operands. ROUTINE CONTINUE A RASTEROP (COMMAND, SOURCE 1 X, SOURCE 1 Y, DESTINATION X, DESTINATION Y) - ! This routine is called when a rasterop command is to be continued - ! with the only change being the origin of the first source and - ! destination operands. This mode is useful when writing text into - ! the bitmap. - ! Wait until it is safe to reload the source l and destination origins. WAIT UNTIL STATUS <Initialization complete> IS SET LOAD Address Processor chip with SOURCE 1 X, SOURCE 1 Y, DESTINATION X, DESTINATION Y ! COMMAND must be identical to the last command. LOAD Address Processor chip with COMMAND #### RETURN The following protocol is used, when any Address Processor chip rasterop parameter is to be modified. To improve throughput, it is executed while addresses from the previous rasterop are still in the pipeline. The parameters that may be modified are: ``` FAST SOURCE 1 DX FAST SOURCE 1 DY SOURCE 1 X SOURCE 1 Y DESTINATION X DESTINATION Y FAST DEST DX FAST DEST DY SLOW DEST DX SLOW DEST DY SLOW DEST DY FAST SCALE SLOW SCALE SOURCE 2 X SOURCE 2 Y SOURCE 2 SIZE RASTEROP MODE ``` ROUTINE MODIFY A RASTEROP (COMMAND, Address Processor chip parameters) - ! This command allows the next rasterop to be started as soon as the - ! Address Processor chip has completed address generation from the - ! previous rasterop, but before all the previous addresses have been - ! used by the Video Processor Chip. - ! The command word must be identical with the last command - ! Wait for rasterop address computation to finish WAIT UNTIL STATUS <rasterop complete> IS SET LOAD Address Processor chip parameters LOAD command register with next rasterop function (COMMAND) RETURN #### 4.3.2.2 Processor/Bitmap Transfers The following commands transfer the contents of a single plane or a series of pixel values between the MicroVAX CPU and a raster in the bitmap. #### 4.3.2.2.1 Processor To Bitmap Single Plane Command - Implicit Inputs: The planes not receiving data are disabled, either through the chip select hardware or by programming the CSR in each Video Processor chip appropriately. The following Video Processor chip registers must be setup: - o Control Store RAM Setup to receive data from the I/D interconnect during the external cycle. Other fields are setup as required. - o Logic Function Control Register The following Address Processor chip parameters must be setup: #### MODE - Setup as follows: ``` <1:0> Rasterop Mode = 00 (normal mode). ``` - $\langle 4 \rangle$ Hole fill enable = 0 - <6> Destination indexing as required - <7> Pen Down as required ``` DESTINATION X - X origin of output raster DESTINATION Y - Y origin of output raster FAST DEST DX - Length of output fast vector FAST DEST DY - Y component of fast vector = 0 ``` SLOW DEST DX - X component of slow vector = 0 SLOW DEST DY - Length of output slow vector FAST | SCALE = Unity SLOW | SCALE = Unity #### 4.3.2.2.2 Bitmap to Processor Single Plane Command - #### Implicit Inputs: The planes not transmitting data are disabled, either through the chip select hardware or by programming the CSR in each Video Processor chip appropriately. The following Video Processor chip register must be setup: Control Store RAM - Setup to transmit data to the I/D interconnect during the external cycle. Other fields are ignored. The following Address Processor chip parameters must be setup: #### 4.3.2.2.3 Z-Axis Processor To Bitmap Command - #### Implicit Inputs: The following Video Processor chip register must be setup: Logic Function Control Register '10' must be setup to copy the pixel value into the bitmap. The following Address Processor chip parameters must be setup: ``` MODE - Setup as follows: <1:0> Rasterop Mode = 00 (normal mode) = 0 Hole fill enable <6> Destination indexing - as required as required <7> Pen Down DESTINATION X - X origin of output raster DESTINATION Y - Y origin of output raster FAST DEST DX - Length of output fast vector FAST DEST DY - Y component of fast vector = 0 SLOW DEST DX - X component of slow vector = 0 SLOW DEST DY - Length of output slow vector FAST SCALE = Unity SLOW SCALE = Unity ``` #### 4.3.2.2.4 Z-Axis Bitmap To Processor Command - Implicit Inputs: The following Address Processor chip parameters must be setup: <5> Source l Indexing - As required <7> Pen Down - As required ``` SOURCE 1 X - X origin of input raster SOURCE 1 Y - Y origin of input raster FAST DEST DX - Length of input fast vector FAST DEST DY - Y component of fast vector = 0 SLOW DEST DX - X component of slow vector = 0 SLOW DEST DY - Length of input slow vector FAST SCALE = Unity SLOW SCALE = Unity ``` SOURCE 1 DX - Must have the same sign as the input fast vector SOURCE 1 DY - Must have the same sign as the input slow vector #### 4.4 Video Processor Chip Description #### 4.4.1 Z-Axis Addressing Mode The purpose of the Z-axis addressing mode is to reduce and, in most cases, eliminate the adverse effect on performance caused by the addition of more bitmap memory planes. Certain graphics operations executed by the MicroVAX CPU, such as flooding or painting an area, require that the value of a pixel be processed in the MicroVAX's memory. Without hardware assistance, assembling all the components of a pixel requires intervention by the MicroVAX CPU to: - 1. Read the data in every plane or subplane - 2. Perform the required shifting and masking functions to extract each component of the pixel - 3. Combine the extracted pixel component with the result. Once the operation is complete, a reverse procedure is needed to set the state of the bitmap. Obviously, therefore, system performance degrades as the number of memory planes increases. With Z-axis addressing, on the other hand, logic within each Video Processor chip can be used to assemble or dis-assemble up to 16 bits of pixel value in a single transaction. A further performance improvement can be achieved by using the DMA support to perform the actual processor to bitmap transfer. The function of the Video Processor chip Z-axis logic is to: - O Insert bitmap data at the correct position in the word for a bitmap to processor transfer, - O Extract data from the correct position in the word for a processor to bitmap transfer The relationship of address to position is shown in Figure 4-40 for a 4-plane system. Figure 4-40 Z-Axis Addressing Each Video Processor chip is numbered with its Z-axis address. As illustrated in Figure 4-40, bits 4 through 15 of the data word are unused. NOTE On a Z-Axis bitmap to processor transfer, the value of unused bits are undefined. The maximum value of a pixel is determined by the number of physical memory planes. Some things to remember about Z-axis processing: - A Video Processor chip can have any Z-Axis address, if it does not overlap the address assigned to another Video Processor chip. - 2. The state of unused bits are undefined. These bits must be set to some known state before referencing the pixel value. #### 4.4.2 Z-Axis Register Loads The Video Processor chip foreground, background, source, and scroll fill registers are set to specific colors by the MicroVAX CPU. To facilitate this, the Z-Axis register load function has been provided which performs similar to the Z-Axis procesor to bitmap transfers. Namely, in one I/D interconnect transaction each Video Processor chip in a block extracts data from that portion of the I/D interconnect specified by the bit address. The bits of the selected register will either be set to all one's or all zero's, coresponding to a one or zero in it's bit position in the data word. 4-64 CHAPTER 5 DIAGNOSTICS #### 5.1 OVERVIEW This chapter contains Diagnostic and Console I/O firmware information which will aid the user in isolating faults to the VCB02 FRU module level. The diagnostics for the VCB02 video subsystem is a set of 16K ROMs located on the VCB02 Base Module. The diagnostics will provide power up self-test and console I/O support. The power up self-test is a concise test invoked by the KA630 ROM that verifies the VCB02 video chipset, bitmap memory, analog signals, interrupts, DMA, DUART, keyboard, and mouse or tablet. The console I/O support will provide sufficient functions to support the KA630 ROM console program input and output. Some of the functions include initialization, get character, put character poll, and put character. #### 5.2 OPERATION When the KA630 is powered on, the CPU begins executing the Console Program that resides in the KA630 ROM. After determining that it was invoked on power up, the KA630 performs the following sequence before any video display device is referenced. - TOY chip verification. If the battery is too low or the battery backed-up RAM contains an invalid checksum then the clock is stopped and the time is zeroed. The console language and keyboard information is cleared causing a query for the language by the operator later. - Each page of memory is checked until five good pages are found. These pages will be used for the Console Page, Console Stack, System memory bitmap, and diagnostic scratch space. # 3. A diagnostic is run to verify that the QBus is arbitrating. The next step is to determine what type of video display device is The types of video display devices include the primary alternate console display device (VCB01-MicroVAX I/II) console device alternate such as VCB02 (MicroVAX workstations) or none at all. The Console Program reads address 20001E92H followed by address 20001F00H. If either address responds correctly then the base address of the US font table, base address of the Multinational font table, address of the keycode translation routine, and keyboard flag are loaded into the proper entries of the Console Page by the Console Program. 一 パクフラウルビエ If address 20001E92H responded correctly, then control will be passed to the VCB01 power up self-test. The VCB01 power self-test resides in the KA630 ROM. The VCB01 power up self-test will test VCB01 and update the missing entries of the Console Page. If address 20001E92H responded incorrectly and address 20001F00H responded correctly, then the Console Program will map the VCB02's ROM, checksum the VCB02's ROM, find and checksum the VCB02 power up self-test file, and pass control to the VCB02 power up self-test. The VCB02 power up self-test will test the VCB02 and update the missing entries of the Console Page. No other VCB02 in the system will be affected. After the console device has been selected and tested, the KA630 ROM will use that device for console input and console output. Other software applications will have the ability to use the console I/O functions indirectly through the KA630 ROM via specified KA630 ROM addresses or the Console Page. #### 5.3 IMPLEMENTATION #### 5.3.1 Performance The power up self-test will provide 90 percent fault coverage and also isolate faults to the Field Replaceable Unit (FRU) which include the VCB02 Base Module, the first 4-Plane Module, the second 4-Plane Module (for an 8-plane configuration), the Keyboard, and the Mouse or Tablet. Under one minute is estimated for the power up self-test execution time. The code will be contained in 16 kilobytes of ROM space. # 5.3.2 Compatibility The diagnostic program code will be compatible with the KDQ32-A processor, the KA630-A console program, the self-test for the keyboard, mouse, tablet, and the MicroVAX Diagnostic ROM format. ## 5.3.3 Error Processing There are two types of failures; non-fatal error and fatal error. non-fatal error inhibits further testing of an operation or function of the device. This is specifically for manufacturing where external loopback connectors substitute for manual input devices such as keyboard and mouse. When a non-fatal error occurs, the power up self-test will save the error information and continue testing the subsystem. If no other error occurs then the power up self-test will update the lights and pass control to the KA630 ROM with the error information. A non-fatal error will not override a fatal error or a second non-fatal error. A fatal error is an error that inhibits further testing of the device. Most of the power up self-test's errors will be categorized as fatal errors. When a fatal error occurs, the power up self-test will save the error information, update the VCB02 lights, and pass control to the KA630 ROM with the error information. Fatal errors will override non-fatal errors. following list of restrictions apply: - 1. The diagnostic program must be executed on a KA630 system. If this restriction is not met then the code could be improperly invoked or not invoked at all. - 2. The diagnostic product will test a single VCB02 subsystem residing in the secondary alternate console address, 2001F000H. The diagnostic will not test any VCB02 subsystems residing at other addresses. - 3. The power up self-test will not guarantee intermittent fault detection. - 4. The power up self-test will not isolate faults to the component level. #### 5.4 OPERATIONAL REQUIREMENTS The operational requirements of the VCB02 are: - 1. KA630 system - 2. VCB02 Base Module, first VCB02 4-Plane Module, and optional second VCB02 4-Plane Module. - 3. LK200 series Keyboard and optional Digital Equipment Corporation Mouse or optional Digital Equipment Corporation Tablet. External loopback connectors can be attached to the keyboard port and mouse port. - 4. VR260 monochrome or VR290 Color monitor ## 5.5 FUNCTIONAL DESCRIPTION #### 5.5.1 Assumptions The diagnostic program is dependent upon the following assumptions relative to the KA630 environment: - o The KA630 system is expected to supply the US ASCII font table, Multinational font table, and keyboard translation table. - o The KA630 system is expected to supply the keyboard translation routine. - o The KA630 system has stored the base address of the above tables and routines in the Console Page as shown in Figure 5-1 and Table 5-1. - o The KA630 system has provided a millisecond stall routine that is called by its physcial address: PUSHAB @#20040038 JSB (SP)+ - o The KA630 system lights are updated. Note the power up self-test will not update the KA630 system lights. It will update the VCB02 lights, only. - o Rll contains the base address of the Console Page. - o Memory is configured as shown in Figure 5-1. - o The Console Page is configured as indicated in Table 5-1. - o The correct value has been written to the secondary alternate console, address 20001F00H. - o The VCB02 ROM and diagnostic file reside in the proper address space and have been verified by the checksum specified in the MicroVAX Diagnostic ROM format 1.0. | | High memory | |-----------------------------|----------------------------------------| | | | | Console Page | Rll | | Stack | | | : | ;<br>; | | | | | Uninitialized bitmap | System memory bitmap base address | | Diagnostic scratch (2 of 2) | System memory bitmap base address-200H | | Diagnostic scratch (1 of 2) | System memory bitmap base address-400H | | :<br>: | | | | Low memory | Figure 5-1 Memory Configuration Before Power Up Self-Test ``` Table 5-1 Console Page Configuration Interrupt and exception vectors ............. 00H(R11) - 04H(R11) 08H(R11) 0CH(Rll) > Reserved 10H(R11) 14H(R11) 18H(R11) - ............ Console I/O vectors ...... lCH(Rll) Get Character 20H(Rll) Put Character Poll 24H(Rll) Put Character 28H(Rll) Console Map 2CH(Rll) Console Reset 30H(Rll) Console Bus Reset 34H(Rll) Reserved 38H(Rll) Reserved ...... Console I/O state memory ...... 3CH(Rll) - 40H(Rll) 44H(R11) 48H(R11) 50H(Rll) > Reserved 54H(R11) 58H(R11) 5CH(Rll) 60H(R11) ............ Memory base addresses ····· 64H(R11) 68H(R11) > Reserved 6CH(Rll) Console Private ..... 70H(R11) (R11) > Reserved (Rll) (Rll) 200H(R11) - ............ ``` #### 5.5.2 Power Up Self test 5.5.2.1 Parameters Passed And Returned If the power up self-test passes, then the procedure will return R0 with a value of l and Rl with a zero. If the power up self-test fails then the procedure will return R0 with a value of 0 and Rl with an error code. If external loopback connectors are attached and the power up self-test passes then the procedure will return R0 with a value of 2 and Rl with an error code. 5.5.2.2 VCB02 Lights The VCB02 Base Module hardware causes all module lights (06, 08, and 07) located on the module's edge alongside connector J4 (see Figure 1-1) to illuminate on power up. It is the responsibility of the power up self-test to update the VCB02 lights and inform the user of the status of the machine. When the power up self-test is invoked by the KA630 ROM, the VCB02 lights will be updated by the VCB02 ROM to indicate that the power up self-test is being executed. After power up self-test has been completed, the VCB02 lights will be updated to indicate the status of the subsystem. If the VCB02 lights are extinguished, then the system is functioning correctly or the lights are not working. Otherwise, the VCB02 lights will identify the FRU containing the problem. Refer to Table 5-2 for a list of VCB02 light definitions. 5.5.2.3 Register Access And Data This test will read each address on a word boundary within the register mapping space and verify that each address on a word boundary will respond properly. The test will not read the mapping CSR, VCB02 ROM, Template RAM, and "not used" address space. The mapping CSR and VCB02 ROM are assumed to be working correctly. The Template RAM will be verified in a succeeding test. This test will then write a set of patterns, read, and compare the patterns with all readable and writeable registers. The registers include DMA address counter, DMA byte count, FIFO register, vector base, and memory base register. The patterns include: 5555H AAAAH 3333H 0F0FH 00FFH Table 5-2 VCB02 Light Definitions | | | DURING POWER UP SELF-TEST EXECUTION | |-------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LIGH: | | STATE DESCRIPTION | | * * 0 0 x x | * | Hardware state on power up Executing power up self-test | | | | AFTER POWER UP SELF-TEST EXECUTION | | LIGHT<br>07 08 | | FAULT DESCRIPTION | | 0 0<br>0 *<br>0 * | *<br>0<br>*<br>0<br>* | No faults detected VCB02 Base Module fault First VCB02 4-plane Module fault Second VCB02 4-plane Module fault Reserved Keyboard fault Mouse or Tablet fault Catastrophic | | ( | ) = | ON<br>OFF | X = FAULT DESCRIPTION #### 5.5.2.4 Template RAM This test will write a set of patterns, read, and compare the patterns with the first Template RAM address. The patterns include: 5555H AAAAH 3333H 0F0FH 00FFH The remainder of this test consists of three passes. The first pass will write a 5555H pattern from the first Template RAM address through the last Template RAM address. The second pass will read, compare the pattern, and write a AAAAH pattern from the first Template RAM address through the last Template RAM address. The final pass will read, compare the pattern, and write a 5555H pattern from the last Template RAM address through the first Template RAM address. #### 5.5.2.5 Address Processor Chip This test will verify that the Address Processor chip is functional and can interrupt/initialize the screen format control registers of the chip. The test will set up the hardware to handle the Address Processor interrupts, issue the "cancel" command and wait for an interrupt generated by the "I/D data transmit ready" line. The test will then initialize the screen format control registers including the X scan count, the Y scan count, and the synchronization phase. # 5.5.2.6 Update Video Processor Enable Chip Select This test will verify the Video Processor chip selection and begins at initializing point [0,0] for all the planes as follows: - 1. Select all planes. - Using one processor to bitmap Z mode command, write a 0 to point [0,0] of all the planes. - 3. Using one bitmap to processor Z mode command, read point [0,0] from all planes. - 4. Compare the results for point [0,0] of each plane to 0. The Video Processor selection for the first plane will be tested with the following steps: - 1. Select the first plane and deselect the other planes. - 2. Using one processor to bitmap Z mode command, write a 1 to point [0,0] of all the planes. This operation will only effect the first plane because it was the only plane selected. - 3. Using one bitmap to processor Z mode command, read point [0,0] from all planes. - 4. Compare the results. Point [0,0] of the first plane should be a 1 and the remaining point for the other planes should be a 0. Point [0,0] will be initialized for all the planes, again. The same sequence performed for the first plane will be done for each of the remaining planes except any reference to the first plane will be replaced by the plane being tested. #### 5.5.2.7 Bitmap Memory This test will verify the hardware related to the bitmap memory for all the planes. The test consists of three sections data path and chip selection, data, and addressing. The data path and chip selection section will verify the data path to the bitmap memory and chip selection. Using a processor to bitmap X mode command, a set of 32-bit patterns will be written to point [0,0] through point [31,0] for all planes. Using a series of bitmap to processor X mode command, the pattern will be read from the first plane and compared to the pattern, read from the second plane and compared to the pattern and continue until every plane has been read and compared. The patterns include: 0000000H 1111111H 2222222H 4444444H 8888888H 7777777H BBBBBBBBBH DDDDDDDH EEEEEEEH FFFFFFFH 0F0F0F0FH 00FF00FFH 0000FFFFH 87654321H The data section will verify that all bits in all planes of the bitmap memory can be set and cleared correctly. Using one "scroll fill" command a OFH type pattern will be written to each address of the bitmap memory for all planes. Using a series of bitmap to processor X commands, the pattern will be read from each address of the first plane and compare, read from each address of the second plane and compare and continue until every address of every plane has been read and compared. Using the "scroll fill" command, a FOH type pattern will be written to each address of the bitmap memory for all planes. Using the same series of bitmap to processor X commands, the pattern will be read from each address of the first plane and compare, read from each address of the second plane and compare and continue until every address of every plane has been read and compared. The address section will verify the bitmap memory addressing. Using the processor to bitmap Z command, a set of 32-bit patterns will be written into a set of bitmap memory addresses for all planes. Using a rasterop function, each plane will be complemented. Using the bitmap to processor X command, the pattern will be read from the set of bitmap memory addresses for the first plane and compared to the 32-bit complemented pattern set. The remaining plane will read the complemented values exactly the same way. The address pattern is a floating zero and floating one. For readability, it is listed from the lowest value to the highest value in the Table 5-3. Table 5-3 Bitmap Memory Addresses | Byte | Pixel | | Write | Read | |---------|---------|-------|-----------------------|-----------------------| | Address | Address | | Pattern | Pattern | | 00000H | (0000, | 0000) | 0000000н | FFFFFFFH | | 00004H | | 000) | 11111111H | EEEEEEEH | | 00008н | • | 000) | 2222222Н | DDDDDDDDH | | 00010H | | 0000) | 3333333H | CCCCCCCH | | 00020н | , , | 0000) | 4444444H | BBBBBBBBH | | 00040H | | 0000) | 5555555H | HAAAAAAA | | 00080н | | 0001) | 6666666Н | 9999999н | | 00100н | | 0002) | 7777777H | 8888888H | | 00200н | (0000, | 0004) | 8888888H | 7777777Н | | 00400H | (0000, | (8000 | 9999999 | 6666666Н | | 00800н | (0000, | 0016) | HAAAAAAA | 5555555Н | | 01000H | (0000, | 0032) | BBBBBBBBH | 4444444H | | 02000H | (0000, | 0064) | CCCCCCCH | 3333333Н | | 04000H | • | 0128) | DDDDDDDDH | 2222222Н | | 08000н | , | 0256) | EEEEEEEH | 11111111H | | 10000H | | 0512) | FFFFFFFH | 0000000Н | | lfffCH | • | 1023) | 00000000Н | FFFFFFFH | | 20000H | • | 1024) | 11111111H | EEEEEEEH | | 2FFFCH | | 1535) | 2222222H | DDDDDDDDH | | 37FFCH | • | 1791) | 3333333H | СССССССН | | 3BFFCH | • • | 1919) | 4444444H | вввввввн | | 3DFFCH | , | 1983) | 5555555H | HAAAAAAA | | 3EFFCH | , | 2015) | 6666666Н | 99999999Н | | 3F7FCH | • | 2031) | 7777777H | 88888888H<br>7777777H | | 3FBFCH | (0992, | 2039) | H8888888 | 66666666H | | 3FDFCH | (0992, | 2043) | 9999999 | 5555555H | | 3FEFCH | (0992, | 2045) | НААААААА | 4444444H | | 3FF7CH | (0992, | 2046) | BBBBBBBBH | 33333333H | | 3FFBCH | (0480, | 2047) | СССССССН | 2222222H | | 3FFDCH | (0736, | 2047) | DDDDDDDDH | 11111111H | | 3FFECH | (0864, | 2047) | EEEEEEEH | 00000000Н | | 3FFF4H | (0928, | 2047) | FFFFFFFH | FFFFFFFH | | 3FFF8H | (0960, | 2047) | 00000000H<br>1111111H | EEEEEEEEH | | 3FFFCH | (0992, | 2047) | Tititit | | 5.5.2.8 Update Video Processor Scroll Enable Chip Select This test will verify the Video Processor chip selection related to the scroll function. The test will begin by erasing all planes as follows: - 1. Load zero into scroll fill register for each Video Processor - 2. Issue scroll command in erase mode - 3. Using bitmap to processor X mode command, read a byte starting at point [0,0] from each plane. 4. Compare the results to zero. The Video Processor selection related to the scroll function will be tested in the following steps: - Load a unique pattern into each scroll fill register for each Video Processor. - 2. Issue a scroll command in erase. - Using bitmap to processor X mode command, read a byte starting at point [0,0] from each plane. - 4. Compare the results. The patterns are: - l for Video Processor l - 2 for Video Processor 2 - 3 for Video Processor 3 - 4 for Video Processor 4 - 5 for Video Processor 5 - 6 for Video Processor 6 - 7 for Video Processor 7 - 8 for Video Processor 8 # 5.5.2.9 FIFO, DMA Operations, And DMA Interrupts The FIFO and DMA operations will be checked by performing a Processor to Bitmap transfer of 65 words immediately followed by a Bitmap to Processor transfer of 65 words, after which the data sent will be compared with the data received. To verify the interrupts, the test will be "interrupt driven". # 5.5.2.10 Video Synchronization Pulses The presence of horizontal and vertical synchronization pulses will be verified by monitoring the SYNC detect bit provided in the VCB02 module's Memory CSR at the last horizontal synchronization pulse before the vertical interval and again during the vertical interval. #### 5.5.2.11 Video Signal Level This test will check the data path from the QBus to the complementary output of the video digital to analog convertors (DACs). It will also check the accuracy of the video DACs to within 2 LSBs. The resolution of the comparators will determine the final delta value of that will be blasted into VCB02 ROM for the final diagnostic program. This means that the two LSBs of each Color Map Register (CMR) address may or may not be checked by the self-test. During this test, the Color Map Register's red, green and blue entries will be loaded three times; once for each group of 8 lines. This test will require 24 frames of displayed screen data to complete. Eight horizontal lines will be drawn on the screen as indicated in Table 5-4. Table 5-4 Color Map Register Pixel Values | | Pixel<br>Value | | |-------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------| | 0<br>1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | 0<br>1<br>2<br>4<br>8<br>10H<br>20H<br>40H<br>80H | <pre>8 plane, only 8 plane, only 8 plane, only 8 plane, only</pre> | To test the first set of pixel values, the Color Map Register will be loaded as listed in Table 5-5. Table 5-5 Color Map Register Loading (First Test) Expected Results CMR CMR Red CMR Green CMR Blue B-GT-R G-GT-B R-GT-G Address Value Value Value ..... G+DV 55H G-DV 1 0 G+DV AAH G-DV 1 0 G+DV 33H G-DV 1 0 G+DV CCH G-DV 1 0 G+DV 0FH G-DV 1 0 0 0 1 2 4 8 G+DV F0H G-DV 1 G+DV FFH-DV G-DV 1 G+DV 00H+DV G-DV 1 G+DV EFH G-DV 1 0 0 10H 0 20H 0 40H 80H 0 To test the second set of pixel values, the Color Map Register will be loaded as listed in Table 5-6. Table 5-6 Color Map Register Loading (Second Test) Expected Results | | | | | Expe | cted Res | uits | | |----------------|------------------|--------------------|-------------------|--------|----------|--------|---| | CMR<br>Address | CMR Red<br>Value | CMR Green<br>Value | CMR Blue<br>Value | B-GT-R | G-GT-B | R-GT-G | | | 0 | 55H | R-DV | R+DV | 0 | 1 | 0 | _ | | 1 | AAH | R-DV | R+DV | 0 | 1 | 0 | | | 2 | 33H | R-DV | R+DV | 0 | 1 | 0 | | | 4 | CCH | R-DV | R+DV | 0 | 1 | 0 | | | 8 | OFH | R-DV | R+DV | 0 | 1 | 0 | | | 10H | F0H | R-DV | R+DV | 0 | 1 | 0 | | | 20H | FFH-DV | R-DV | R+DV | 0 | 1 | 0 | | | 40H | 00H+DV | R - DV | R+DV | 0 | 1 | 0 | | | 80H | EFH | R-DV | R+DV | 0 | 1 | 0 | | | | | | | | | | - | To test the third set of pixel values, the Color Map register will be loaded as listed in Table 5-7. Table 5-7 Color Map Register Loading (Third Test) | | | | | Expe | cted Res | ults | |---------|-----------------|-----------|----------|--------|----------|--------| | CMR | CMR Red | CMR Green | CMR Blue | B-GT-R | G-GT-B | R-GT-G | | Address | Value | Value | Value | | | | | | • • • • • • • • | | | | | | | 0 | B-DV | B+DV | 55H | 0 | 0 | 1 | | 1 | B - DV | B+DV | AAH | 0 | 0 | 1 | | 2 | B-DV | B+DV | 33H | 0 | 0 | 1 | | 4 | B-DV | B+DV | CCH | 0 | 0 | 1 | | 8 | B-DV | B+DV | 0FH | 0 | 0 | 1 | | 10H | B-DV | B+DV | F0H | 0 | 0 | 1 | | 20H | B - DV | B+DV | FFH-DV | 0 | 0 | 1 | | 40H | B-DV | B+DV | 00H+DV | 0 | 0 | 1 | | 80H | B - DV | B+DV | EFH | 0 | 0 | 1 | | | | | | | | | The DV or delta value is 3. All other addresses are the complemented value. 5.5.2.12 Dual Universal Asynchronous Receiver and Transmitter (DUART) Using local loopback operating mode, this test will verify the DUART interface by transmitting and receiving a set of 8-bit patterns at 4800 baud. The patterns include: 55H AAH 33H 0FH To verify the interrupts, the test will be "interrupt driven". # 5.5.2.13 Manual Input Devices This test will verify the manual input devices connected to the DUART's ports. The test will send the "test command" (FDH) to the keyboard port to invoke its self-test and wait one second for a response from the device. If the device responds with four bytes and the third byte is zero the test will continue. If the device responds with one byte of value FDH the test will log it as a hard error and continue. Otherwise, the test will classify it as a device fatal error and return control to the KA630 ROM. The test will send the "test command" (T ASCII) to the other port. If the keyboard port received four bytes and the device responds with four bytes and the third byte is a zero or the device fails to respond the test will continue. If the keyboard port received one byte of value FDH and the device responded with one byte of value T ASCII, the test will log it as a hard error and continue. #### NOTE The device connected to the Mouse/Tablet port will be considered as an optional device. This means that in the customer's environment, a Mouse or Tablet that is improperly connected will not be reported as an error. # 5.5.2.14 Calling Sequence The calling sequence is as follows: ; MAP VCB02 ROM MOVW #^x3F,@#^x20001F00 - ; FIND BASE ADDRESS OF EXECUTABLE CODE IN "DIAGO" FILE ; AND RETURN IN Rn - : PASS CONTROL TO POWER UP SELF-TEST CALLS #0,(Rn) #### 5.6 CONSOLE INPUT/OUTPUT SUPPORT #### 5.6.1 Put Character Poll This routine is called to determine, if a character can be displayed. No parameters are passed to the routine. If a character can be displayed, then the routine will return RO with bit O set to one. If a character cannot be displayed, then the routine will return RO with bit 0 cleared to zero. # 5.6.1.1 Calling Sequence The calling sequence is as follows: - ; R11 CONTAINS THE BASE ADDRESS OF THE CONSOLE PAGE. - : RO AND RI ARE DESTROYED. ; WAIT TO DISPLAY A CHARACTER 20\$: JSB CP\$A\_PUTCHRPOLL(R11) ; PUT A CHARACTER? BLBC R0,20\$ ; NO, WAIT #### 5.6.2 Put Character This routine is called to display a character. Rl is passed containing the "zero extended longword" ASCII value of the character to be displayed. If the character is displayed successfully, then the routine will return RO with bit O set to one. If the character is displayed unsuccessfully, then the routine will return RO with bit 0 cleared to zero. NOTE The routine should be used with the Put Character Poll routine. The routine will use the US ASCII font table and Multinational font table in the KA630 ROM. # 5.6.2.1 Calling Sequence The calling sequence is as follows: - ; R11 CONTAINS THE BASE ADDRESS OF THE CONSOLE PAGE. - ; RO AND R1 ARE DESTROYED. ; DISPLAY A CHARACTER 20\$: JSB CP\$A PUTCHRPOLL(R11) ; PUT A CHARACTER? BLBC R0,20\$ ; NO, WAIT BLBC R0,20\$ MOVZBL #^A"A",R1 ; PASS ASCII VALUE OF "A" JSB CP\$A PUTCHR(R11) ; PUT THE CHARACTER BLBC R0,40\$ ; BRANCH IF ERROR 40\$: #### 5.6.3 Get Character This routine is called to determine if a character has been received and if so, return the character. No parameters are passed. If a character is available, then the routine will return Rl with the "zero extended" ASCII value of the character and R0 with bit 0 set to one. If a character is not available, then the routine will return Rl with arbitrary data and R0 will be cleared to zero. If the keyboard code is a shift code, like "control", "shift", and "lock" or introducer code like "compose character"; then the routine will return R0 with bit 0 cleared to zero. #### NOTE "Get Character" will call the translate routine and reference the keyboard translation table. There will be no provisions for time outs. # 5.6.3.1 Calling Sequence The calling sequence is as follows: ``` ; R11 CONTAINS THE BASE ADDRESS OF THE CONSOLE PAGE. ``` : RO AND RI ARE DESTROYED. ; ; READ A CHARACTER 10\$: JSB @CP\$A GETCHR(Rll) ; GET A CHARACTER? BLBC R0,10\$; NO, WAIT PUSHL R1 ; YES, STORE IT ; ECHO THE CHARACTER 20\$: JSB CP\$A PUTCHRPOLL(R11); PUT A CHARACTER? BLBC R0,20\$; NO, WAIT POPL R1; RESTORE R1 JSB CP\$A PUTCHR(R11) ; ECHO THE CHARACTER BLBC R0.40\$ ; BRANCH IF ERROR • 40\$: #### 5.6.4 Console Reset This routine is called to initialize the hardware for console output. The areas initialized include the keyboard, state variables, DUART, Address Processor defaults, Video Processor defaults, and color map. If the VCB02 is initialized successfully, then the routine will return R0 with bit 0 set to one. If the VCB02 is initialized unsuccessfully, then the routine will return R0 with bit 0 cleared to zero. #### 5.6.4.1 Calling Sequence The calling sequence is as follows: ``` ; R11 CONTAINS THE BASE ADDRESS OF THE CONSOLE PAGE. ; R0 AND R1 ARE DESTROYED. ; ; RESET THE CONSOLE JSB @CP$A RESET(R11) ; RESET CONSOLE BLBC R0,10$ ; BRANCH IF ERROR . . 105: ``` #### 5.6.5 Console Bus Reset This routine is intended to be called immediately after a bus reset. The areas initialized include DUART, Address Processor defaults, Video Processor defaults, and color map. If the VCB02 is initialized successfully, then the routine will return RO with bit 0 set to one. If the VCB02 is initialized unsuccessfully, then the routine will return RO with bit 0 cleared to zero. #### 5.6.5.1 Calling Sequence The calling sequence is as follows: ``` ; R11 CONTAINS THE BASE ADDRESS OF THE CONSOLE PAGE. ; R0 AND R1 ARE DESTROYED. ; ; BUS RESET THE CONSOLE JSB @CP$A BUSRESET(R11) ; RESET CONSOLE BLBC R0,10$ ; BRANCH IF ERROR . 10$: ``` APPENDIX A Q22 BUS SPECIFICATION #### A.1 GENERAL DESCRIPTION The Q22 Bus, also known as the Extended LSI-ll Bus, is the low-end member of DIGITAL's bus family. All DIGITAL microcomputers, such as the MicroVAX I/II and Micro/PDP-ll, use the Q22 Bus. The Q22 Bus consists of 42 bidirectional and 2 unidirectional signal lines. These form the lines along which the processor, memory, and I/O devices communicate with each other. Addresses, data, and control information are sent along these signal lines, some of which contain time-multiplexed information. The lines are divided as follows: - o Sixteen multiplexed data/address lines -- BDAL<15:00> - o Two multiplexed address/parity lines -- BDAL<17:16> - o Four extended address lines -- BDAL<21:18> - o Six data transfer control lines -- BBS7, BDIN, BDOUT, BRPLY, BSYNC, BWTBT - o Six system control line -- BHALT, BREF, BEVNT, BINIT, BDCOK, BPOK - o Ten interrupt control and direct memory access control lines -- BIAKO, BIAKI, BIRQ4, BIRQ5, BIRQ6, BIRQ7, BDMGO, BDMR, BSACK, BDMGI In addition, a number of power, ground, and space lines have been defined for the bus. For a detailed description of these lines, please refer to Table A-1. The discussion in this appendix applies to the general 22-bit physical address capability. All modules used with the KA630-A CPU module must use 22-bit addressing. Most Q22 Bus signals are bidirectional and use terminations for a negated (high) signal level. Devices connect to these lines via high-impedance bus receivers and open collector drivers. The asserted state is produced when a bus driver asserts the line low. Although bidirectional lines are electrically bidirectional (any point along the line can be driven or received), certain lines are functionally unidirectional. These lines communicate to or from a bus master (or signal source), but not both. Interrupt acknowledge (BIAK) and direct memory access grant (BDMG) signals are physically unidirectional in a daisy-chain fashion. These signals originate at the processor output signal pins. Each is received on device input pins (BIAKI or BDMGI) and conditionally retransmitted via device output pins (BIAKO or BDMGO). These signals are received from higher-priority devices and are retransmitted to lower-priority devices along the bus, establishing the position-dependent priority scheme. #### A.1.1 Master/Slave Relationship Communication between devices on the bus is asynchronous. A master/slave relationship exists throughout each bus transaction. At any time, there is one device that has control of the bus. This controlling device is termed the bus master or arbiter. The master device controls the bus when communicating with another device on the bus, termed the slave. The bus master (typically the processor or a DMA device) initiates a bus transaction. The slave device responds by acknowledging the transaction in pogress and by receiving data from, or transmitting data to, the bus master. Q22 Bus control signals transmitted or received by the bus master or bus slave device must complete the sequence according to bus protocol. The processor controls bus arbitration, i.e., which device becomes bus master at any given time. A typical example of this relationship is a disk, as master, transferring data to memory as slave. Communication on the Q22 Bus is interlocked so that for certain control signals issued by the master device, there must be a response from the slave in order to complete the transfer. It is the master/slave signal protocol that makes the Q22 Bus asynchronous. The asynchronous operation precludes the need for synchronizing with, and waiting for, clock pulses. Since bus cycle completion by the bus master requires response from the slave device, each bus master must include a time-out error circuit that will abort the bus cycle if the slave does not respond to the bus transaction within 10 microseconds. The actual time before a time-out error occurs must be longer than the reply time of the slowest peripheral or memory device on the bus. # A.2 Q22 BUS SIGNAL ASSIGNMENTS Table A-1 lists the signal assignments for the data/address, control, power/ground, and spare functions of the Q22 Bus. | Table A-1 | Signal Assignments (Sheet 1 of 3) | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | DATA AND ADDRES | | | Nomenclature | Pin Assignment | | BDAL0 BDAL1 BDAL2 BDAL3 BDAL4 BDAL5 BDAL6 BDAL7 BDAL8 BDAL9 BDAL10 BDAL11 BDAL12 BDAL12 BDAL13 BDAL14 BDAL15 BDAL14 BDAL15 BDAL15 BDAL15 BDAL16 BDAL17 BDAL16 BDAL17 BDAL18 BDAL19 BDAL10 BDAL10 BDAL11 | AU2 AV2 BE2 BF2 BF2 BH2 BJ2 BK2 BL2 BM2 BM2 BM2 BM2 BM2 BM2 BP2 BR2 BS2 BF2 BS2 BT2 BU2 BU2 BU2 BU2 BU2 BV1 AU1 BU1 BU1 BU1 BU1 BU1 BU1 BU1 | | CONTROL | | | Data C | | | BDOUT<br>BRPLY<br>BDIN<br>BSYNC<br>BWTBT<br>BBS7 | AE2<br>AF2<br>AH2<br>AJ2<br>AK2<br>AP2 | | | Table A-1 | l Signal | Assignments | (Sheet 2 o | f 3 | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------|---------------------|-----| | Interrupt | Control | • • • • • • • • | | • • • • • • • • • • | | | | Nomenclature | • | | n Assignmen | t | | | BIRQ7<br>BIRQ6<br>BIRQ5<br>BIRQ4<br>BIAKO<br>BIAKI | | BPI<br>ABI<br>AAI<br>AL2<br>AN2 | | ••• | | | Di | AA Contro | 1 | | | | | BDMR<br>BSACK<br>BDMGO<br>BMDGI | | AN]<br>BN]<br>AS2<br>AR2 | ? | | | | Sys | stem Cont | rol | | | | | BHALT<br>BREF<br>BEVNT<br>BINIT<br>BDCOK<br>BPOK | | API<br>ARI<br>BRI<br>AT2<br>BAI<br>BBI | | | | | POWER AND G | ROUND | | | | | | +5B (battery<br>+12B (batter)<br>+12B<br>+5B<br>+5<br>+5<br>+5<br>+12<br>+12<br>+12<br>-12<br>-12<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND<br>GND | | ASI BSI AVI AA2 BA2 BVI AD2 BD2 AB2 AB2 AB2 AB2 AB2 BB2 AC2 AJI AMI ATI BC2 BJI BMI BTI | | | Table A-1 Signal Assignments (Sheet 3 of 3) | <br>SPARES | | |---------------------------------------------------------------------------------|-----------------------------------------| | Nomenclature | Pin Assignment | | SSparel SSpare3 SSpare8 SSpare2 MSpareA MSpareB MSpareB MSpareB PSparel ASpare2 | AEl AHl BHl AFl AKl ALl BKl BLl AUl BUL | #### A.3 DATA TRANSFER BUS CYCLES Data transfer bus cycles are listed and defined in Table A-2. Table A-2 Data Transfer Operations | Bus Cycle<br>Mnemonic | Description | Function (with Respect to the Bus Master) | |-----------------------|-----------------------------|-------------------------------------------| | DATI | Data word input | Read | | DATO | Data word output | Write | | DATOB | Data byte output | Write-byte | | DATIO | Data word Input/Output | Read-modify-write | | DATIOB | Data word input/byte output | Read-modify-write byte | | DATBI | Data block input | Read block | | DATBO | Data block output | Write block | | | · <del></del> | | These bus cycles, executed by bus master devices, transfer 32-bit words or 8-bit bytes to or from slave devices. In block mode, multiple words may be transferred to sequential word addresses, starting from a single bus address. The bus signals listed in Table A-3 are used in the data transfer operations described in Table A-2. Table A-3 Bus Signals for Data Transfers | | • • • • • • • • • • • • • • • • • • • • | | |---------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonic | Description | Function | | | | • • • • • • • • • • • • • • • • • • • • | | BDAL<21:00> L | 22 Data/address lines | BDAL<15:00>L are used for word and byte transfers. BDAL<17:16> L are used for extended addressing, memory parity error (16), and memory parity error enable (17), functions. BDAL<21:18> L are used for extended addressing beyond 256 KB. | | BSYNC L | Bus Cycle Control | Indicates bus transaction in progress. | | BDIN L | Data input indicator | Strobe signals. | | BDOUT L | Data output indicator | Strobe signals. | | BRPLY L | Slave's acknowledge of bus cycle | Strobe signals. | | BWTBT 1 | Write/byte control | Control signals. | | BBS7 | I/O device select | Indicates address is in the I/O page. | Data transfer bus cycles can be reduced to five basic types: DATI, DATO(B), DATIO(B), DATBI, and DATBO. These transactions occur between the bus master and one slave device selected during the addressing portion of the bus cycle. #### A.3.1 Bus Cycle Protocol Before initiating a bus cycle, the previous bus transaction must have been completed (BSYNC L negated) and the device must become bus master. The bus cycle can be divided into two parts, an addressing portion, and a data transfer portion. During the addressing portion, the bus master outputs the address for the desired slave device, memory location or device register. The selected slave device responds by latching the address bits and holding this condition for the duration of the bus cycle until BSYNC L becomes negated. During the data transfer portion, the actual data transfer occurs. # A.3.2 Device Addressing The device addressing portion of a data transfer bus cycle comprises an address setup and deskew time and an address hold and deskew time. During the address setup and deskew time, the bus master does the following: - o Asserts BDAL<21:00> L with the desired slave device address bits - o Asserts BBS7 L if a device in the I/O page is being addressed - o Asserts BWTBT L if the cycle is a DATO(B) or DATBO bus cycle During this time the address, BBS7 L, and BWTBT L signals are asserted at the slave bus receiver for at least 75 ns before BSYNC goes active. Devices in the I/O page ignore the nine high-order address bits BDAL<21:13> and instead decode BBS7 L along with the thirteen low-order address bits. An active BWTBT L signal during address setup time indicates that a DATO(B) or DATBO operation follows, while an inactive BWTBT L indicates a DATI, DATBI, or DATIO(B) operation. The address hold and deskew time begins after BSYNC L is asserted. The slave device uses the active BSYNC L bus received output to clock BDAL address bits, BBS7 L, and BWTBT L into its internal logic. BDAL<21:00> L, BBS7 L, and BWTBT L will remain active for 25 ns (minimum) after BSYNC L bus receiver goes active. BSYNC L remains active for the duration of the bus cycle. Memory and peripheral devices are addressed similarly except for the way the slave device responds to BBS7 L. Addressed peripheral devices must not decode address bits on BDAL<21:13> L. Addressed peripheral devices may respond to a bus cycle when BBS7 L is asserted (low) during the addressing portion of the cycle. When asserted, BBS7 L indicates that the device address resides in the I/O page (the upper 4K address space). Memory devices generally do not respond to addresses in the I/O page; however, some system applications may permit memory to reside in the I/O page for use as DMA buffers, read-only memory bootstraps or diagnostics, etc. DATI -- The DATI bus cycle, illustrated in Figure A-1, is a read operation. During DATI, data are input to the bus master. Data consist of 16-bit word transfers over the bus. During the data transfer portion of the DATI bus cycle, the bus master asserts BDIN L 100 ns minimum after BSYNC L is asserted. The slave device responds to BDIN L active as follows: - O Asserts BRPLY L 0 ns minimum (8 ns maximum to avoid bus timeout) after receiving BDIN L and 125 ns (maximum) before BDAL bus driver data bits are valid. - O Asserts BDAL<21L00> L with the addressed data and error information 0 ns minimum after receiving BDIN and 125 ns maximum after assertion of BRPLY. When the bus master receives BRPLY L, it does the following: - o Waits at least 200 ns deskew time and then accepts input data at BDAL<17:00> L bus receivers. BDAL <17:16> L are used for transmitting parity errors to the master. - Negates BDIN L 200 ns (minimum) to 2 microseconds (maximum) after BRPLY L goes active. The slave device responds to BDIN L negation by negating BRPLY L and removing read data from BDAL bus drivers. BRPLY L must be negated 100 ns (maximum) prior to removal of read data. The bus master responds to the negated BRPLY L by negating BSYNC L. Conditions for the next BSYNC L assertion are as follows: - o BSYNC L must remain negated for 200 ns (minimum) - BSYNC L must not become asserted within 300 ns of previous BRPLY L negation Figure A-2 illustrates DATI bus cycle timing. Figure A-2 DATI Bus Cycle Timing #### NOTE Continuous assertion of BSYNC L retains control of the bus by the bus master, and the previously addressed slave device remains selected. This is done for DATIO(B) bus cycles where DATO or DATOB follows a DATI without BSYNC L negation and a second device addressing operation. Also, a slow slave device can hold off data transfers to itself by keeping BRPLY L asserted, which will cause the master to keep BSYNC L asserted. DATO(B) -- DATO(B), illustrated in Figure A-3, is a write operation. Data are transferred in 32-bit words (DATO) or 8-bit bytes (DATOB) from the bus master to the slave device. The data transfer output can occur after the addressing portion of a bus cycle when BWTBT L has been asserted by the bus master, or immediately following an input transfer part of a DATIO(B) bus cycle. The data transfer portion of a DATO(B) bus cycle comprises a data setup and deskew time and a data hold and deskew time. During the data setup and deskew time, the bus master outputs the data on BDAL<15:00> L at least 100 ns after BSYNC L assertion. BWTBT L remains negated for the length of the bus cycle. If the transfer is a byte transfer, BWTBT L remains asserted. If it is the output of a DATIOB, BWTBT L becomes asserted and lasts the duration of the bus cycle. During a byte transfer, BDAL<00> L selects the high or low byte. This occurs while in the addressing portion of the cycle. If asserted, the high byte (BDAL<15:08> L) is selected; otherwise, the low byte (BDAL<07:00> L) is selected. An asserted BDAL 16 L at this time will force a parity error to be written into memory if the memory is a parity-type memory. BDAL 17 L is not used for write operations. The bus master asserts BDOUT L at least 100 ns after BDAL and BDWTBT L bus drivers are stable. The slave device responds by asserting BRPLY L within 10 microseconds to avoid bus time-out. This completes the data setup and deskew time. MET DOD DIDCTITION Figure A-3 DATO or DATOB Bus Cycle During the data hold and deskew time, the bus master receives BRPLY L and negates BDOUT L must remain asserted for at least 150 ns from the receipt of BRPLY L before being negated by the bus master. BDAL<17:00> L bus drivers remain asserted for at least 100 ns after BDOUT L negation. The bus master then negates BDAL inputs. During this time, the slave device senses BDOUT L negation. The data are accepted and the slave device negates BRPLY L. The bus master responds by negating BSYNC L. However, the processor will not negate BSYNC L for at least 175 ns after negating BDOUT L. This completes the DATO(B) bus cycle. Before the next cycle BSYNC L must remain unasserted for at least 200 ns. Figure A-4 illustrates DATO(B) bus cycle timing. Figure A-4 DATO or DATOB Bus Cycle Timing DAITO(B) -- The protocol for a DATIO(B) bus cycle is identical to the addressing and data transfer portions of the DATI and DATO(B) bus cycles, and is illustrated in Figure A-5. After addressing the device, a DATI cycle is performed as explained earlier; however, BSYNC L is not negated. BSYNC L remains active for an output word or byte transfer [DATO(B)]. The bus master maintains at least 200 ns between BRPLY L negation during the DATI cycle and BDOUT L assertion. The cycle is terminated when the bus master negates BSYNC L, as described for DATO(B). Figure A-6 illustrates DATIO(B) bus cycle timing. Figure A-5 DATIO or DATIOB Bus Cycle Figure A-6 DATIO or DATIOB Bus Cycle Timing #### A.4 DIRECT MEMORY ACCESS The direct memory access (DMA) capability allows direct data transfer between I/O devices and memory. This is useful when using mass storage devices (e.g. disks) that move large blocks of data to and from memory. A DMA device needs to know only the starting address in memory, the starting address in mass storage, the length of the transfer, and whether the operation is read or write. When this information is available, the DMA device can transfer data directly to or from memory. Since most DMA devices must perform data transfers in rapid succession or lose data, DMA devices are provided the highest priority. DMA is accomplished after the processor (normally bus master) has passed bus mastership to the highest-priority DMA device that is requesting the bus. The processor arbitrates all requests and grants the bus to the DMA device located electrically closest to it. A DMA device remains bus master indefinitely until it relinquishes its mastership. The following control signals are used during bus arbitration. BDMGI L BDMGO L BDMR L BSACK L DMA Grant Input DMA Grant Output DMA Request Line Bus Grant Acknowledge #### A.4.1 DMA Protocol A DMA transaction can be divided into three phases: - 1. Bus mastership acquisition phase - 2. Data transfer phase - 3. Bus mastership relinquish phase During the bus mastership acquisition phase, a DMA device requests the bus by asserting BDMR L. The processor arbitrates the request and initiates the transfer of bus mastership by asserting BDMGO L. The maximum time between BDMR L assertion and BDMGO L assertion is DMA latency. This time is processor-dependent. BDMGO L/BDMGI L is one signal that is daisy-chained through each module in the backplane. It is driven out of the processor on the BDMGO L pin, enters each module on the BDMGI L pin and exits o the BDMGO L pin. This signal passes through the modules in descending order of priority until it is stopped by the requesting device. The requesting device blocks the output of BMDGO L and asserts BSACK L. If BDMR L is continuously asserted, the bus will be hung. During the data transfer phase, the DMA device continues asserting BSACK L. The actual data transfer is performed as described earlier. The DMA device can assert BSYNC L for a data transfer 250 ns (minimum) after it received BDMGI L and its BSYNC L bus receiver becomes negated. During the bus mastership relinquish phase, the DMA device relinquishes the bus by negating BSACK L. This occurs after completing (or aborting) the last data transfer cycle (BRPLY L negated). BSACK L may be negated up to a maximum of 300 ns before negating BSYNC L. Figure A-7 illustrates the DMA protocol and Figure A-8 illustrates DMA request/grant timing. Figure A-7 DMA Protocol NOTE If multiple data transfers are performed during this phase, consideration must be given to the use of the bus for other system functions, such as memory refresh (if required). Figure A-8 DMA Request/Grant Timing #### A.4.2 Block Mode DMA For increased throughput, block mode DMA may be implemented on a device for use with memories that support this type of transfer. In a block mode transaction, the starting memory address is asserted, followed by data for that address, and data for consecutive addresses. By eliminating the assertion of the address for each data word, the transfer rate is almost doubled. The DATBI and DATBO bus cycles are described below. #### A.4.2.1 DATBI The device addressing portion of the cycle is the same as described earlier for other bus cycles (see Figure A-9). The bus master gates BDAL<21:00>, BBS7, and the negation of BWTBT onto the bus. The master asserts the first BDIN 100 ns after BSYNC, and asserts BBS7 a maximum of 50 ns after asserting BDIN for the first time. BBS7 is a request to the slave for a block mode transfer. BBS7 remains asserted until a maximum of 50 ns after the assertion of BDIN for the last time. BBS7 may be gated as soon as the conditions for asserting BDIN are met. The slave asserts BRPLY a minimum of 0 ns (8 ns maximum to avoid bus timeout) after receiving BDIN. It asserts BREF concurrently with BRPLY if it is a block mode device capable of supporting another BDIN after the current one. The slave gates BDAL<15:00> onto the bus a minimum of 0 ns after the assertion of BDIN and 125 ns maximum after the assertion of BRPLY. The master receives the stable data from 200 ns maximum after the assertion of BRPLY until 20 ns minimum after the negation of BDIN. It negates BDIN a minimum of 200 ns after the assertion of BRPLY. The slave negates BRPLY a minimum of 0 ns after the negation of BDIN. If BBS7 and BREF are both asserted when BRPLY is negated, the slave prepares for another BDIN cycle. BBS7 is stable from 125 ns after BDIN is asserted until 150 ns after BRPLY is negated. The master asserts BDIN a minimum of 150 ns after BRPLY is negated and the cycle is continued as before. (BBS7 remains asserted and the slave responds to BDIN with BRPLY and BREF.) BREF is stable from 75 ns after BRPLY is asserted until a minimum of 20 ns after BDIN is negated. If BBS7 and BREF are not both asserted when BRPLY is negated, the slave removes the data from the bus a minimum of 0 ns and 100 ns maximum after negating BRPLY. The master negates BSYNC a minimum of 250 ns after the assertion of the last BRPLY and a minimum of 0 ns after the negation of that BRPLY. Figure A-9 DATBI Bus Cycle Timing ## A.4.2.2 DATBO The device addressing portion of the cycle is the same as shown in Figure A-10. The bus master gates BDAL<21:00>, BBS7, and the assertion of BWTBT onto the bus. A minimum of 100 ns after BSYNC is asserted, data on BDAL<15:00> and the negated BWTBT are put onto the bus. The master then asserts BDOUT a minimum of 100 ns after gating the data. The slave receives stable data and BWTBT from a minimum of 25 ns before the assertion of BDOUT to a minimum of 25 ns after the negation of BDOUT. The slave asserts BRPLY a minimum of 0 ns after receiving BDOUT. It also asserts BREF concurrently with BRPLY if it is a block mode device capable of supporting another BDOUT after the current one. The master negates BDOUT 150 ns minimum after the assertion of BRPLY. If BREF was asserted when BDOUT was negated and the master wants to transmit more data inn this block mode cycle, then the new data is gated onto the bus 100 ns minimum after BDOUT is negated. BREF is stable from 75 ns maximum after BRPLY is asserted until 20 ns minimum after BDOUT is negated. The master asserts BDOUT 100 ns minimum after gating new data onto the bus and 150 ns minimum after BRPLY negates. The cycle continues as before. If BREF was not asserted when BDOUT was negated or if the bus master does not want to transmit more data in this cycle, then the master removes data from the bus a minimum of 100 ns after negating BDOUT. The slave negates BRPLY a minimum of 0 ns after negating BDOUT. The bus master negates BSYNC a minimum of 175 ns after negating BDOUT, and a minimum of 0 ns after the negation of BRPLY. Figure A-10 DATBO Bus Cycle Timing #### A.4.3 DMA Guidelines - 1. Systems with memory refresh over the bus must not include devices that perform more than one transfer per acquisition. - Bus masters that do not use block mode are limited to four DATI, four DATO, or two DATIO transfers per acquisition. - 3. Block mode bus masters that do not monitor BDMR are limited to eight transfers per acquisition. - 4. If BDMR is not asserted after the seventh transfer, block mode bus masters that do monitor BDMR may continue making transfers until the bus slave fails to assert BREF or until they reach the total maximum of 16 transfers. Otherwise, they stop after eight transfers. #### A.5 INTERRUPTS The interrupt capability of the Q22 Bus allows may I/O device to temporarily suspend (interrupt) current program execution and divert processor operation to service the requesting device. The processor inputs a vector from the device to start the service routine (handler). Like the device register address, hardware fixes the device vector at locations within a designated range below location 001000. The vector indicates the first of a pair of addresses. content of the first address is read by the processor and is the starting address of the interrupt handler. The content of the second address is a new processor status word (PS). The new PS can raise the interrupt priority level, thereby preventing lower-level interrupts from breaking into the current interrupt service routine. Control is returned to the interrupted program when the interrupt handler is ended. The original interrupted program's address (PC) and its associated PS are stored on a stack. The original PC and PS are restored by a return from interrupt (RTI or RTT) instruction at the end of the handler. The use of the stack and the Q22 Bus interrupt scheme can allow interrupts to occur within interrupts (nested interrupts), depending on the PS. Interrupts can be caused by Q22 Bus options or the CPU. Those interrupts that originate from within the processor are called traps. Traps are caused by programming errors, hardware errors, special instructions, and maintenance features. The Q22 Bus signals used in interrupt transactions are: | BIRQ4 L | Interrupt request priority level 4 | |--------------|------------------------------------| | BIRQ5 L | Interrupt request priority level 5 | | BIRQ6 L | Interrupt request priority level 6 | | BIRQ7 L | Interrupt request priority level 7 | | BIAKI L | Interrupt acknowledge input | | BIAKO L | Interrupt acknowledge output | | BDAL <21:00> | Data/address lines | | BDIN L | Data input strobe | | BRPLY L | Reply | ## A.5.1 Device Priority The Q22 Bus supports the following two methods of device priority: - Distributed Arbitration -- priority levels are implemented on the hardware. When devices of equal priority level request an interrupt, priority is given to the device electrically closest to the processor. - Position-Defined Arbitration -- priority is determined solely by electrical position on the bus. The closer a device is to the processor, the higher its priority is. ## A.5.2 Interrupt Protocol Interrupt protocol on the Q22/23 has three phases: interrupt request phase, interrupt acknowledge, and priority arbitration phase, and interrupt vector transfer phase. Figure A-11 illustrates the interrupt request/acknowledge sequence. The interrupt request phase begins when a device meets its specific conditions for interrupt requests. For example, the device is ready, done, or an error has occurred. The interrupt enable bit in a device status register must be set. The device then initiates the interrupt by asserting the interrupt request line(s). BIRQ4 L is the lowest hardware priority level and is asserted for all interrupt requests for compatibility with previous Q22 processors. The level a device is configured at must also be asserted. A special case exists for level 7 devices which must also assert level 6. See the arbitration discussion below involving the 4-level scheme for an explanation. | Interrupt Level | Lines | As | serted | by | Device | 9 | |-----------------|-------|----|--------|----|--------|---| | 4 | BIRQ4 | L | | | | | | 5 | BIRQ4 | L, | BIRQ5 | L | | | | 6 | BIRQ4 | L, | BIRQ6 | L | | | | 7 | BIRQ4 | L, | BIRQ6 | L, | BIRQ7 | L | The interrupt request line remains asserted until the request is acknowledged. During the interrupt acknowledge and priority arbitration phase the LSI-11/23 processor will acknowledge interrupts under the following conditions: - 1. The device interrupt priority is higher than the current PS<7:5>. - The processor has completed instruction execution and no additional bus cycles are pending. Figure A-11 Interrupt Request/Acknowledge Sequence The processor acknowledges the interrupt request by asserting BDIN L, and 150 ns (minimum) later asserting BIAKO L. The device electrically closest to the processor receives the acknowledge on its BIAKI L bus receiver. At this point the two types of arbitration must be discussed separately, If the device that receives the acknowledge uses the 4-level interrupt scheme, it reacts as described: - If not requesting an interrupt, the device asserts BIAKO L and the acknowledge propagates to the next device on the bus. - 2. If the device is requesting an interrupt, it must check to see that no higher-level device is currently requesting an interrupt. This is done by monitoring higher-level request lines. The table below lists the lines that need to be monitored by devices at each priority level. In addition to asserting levels 7 and 4, level 7 devices must drive level 6. This is done to simplify the monitoring and arbitration by level 4 and 5 devices. In this protocol, level 4 and 5 devices need not monitor level 7 since level 7 devices assert level 6. Level 4 and 5 devices will become aware of a level 7 request since they monitor the level 6 request. This protocol has been optimized for level 4, 5, and 6 devices, since level 7 devices very seldom are necessary. | Device | Priority Leve | l Line(s) Monitored | |--------|---------------|---------------------| | 4 | | BIRQ5, BIRQ6 | | 5 | | BIRQ6 | | 6 | | BIRQ7 | | 7 | | • • | - 3. If no higher-level device is requesting an interrupt, the acknowledge is blocked by the device. (BIAKO L is not asserted.) Arbitration logic within the device uses the leading edge of BDIN L to clock a flip-flop that blocks BIAKO L. Arbitration is won, and the interrupt vector transfer phase begins. - 4. If a higher-level request line is active, the device disqualifies itself and asserts BIAKO L to propagate the acknowledge to the next device along the bus. Signal timing must be carefully considered when implementing 4-level interrupts (see Figure A-12). Figure A-12 Interrupt Protocol Timing If a single-level interrupt device receives the acknowledge, it reacts as follows: - o If not requesting an interrupt, the device asserts BIAKO L and the acknowledge propagates to the next device on the bus. - o If the device was requesting an interrupt, the acknowledge is blocked using the leading edge of BDIN L and arbitration is won. The interrupt vector transfer phase begins. The interrupt vector transfer phase is enabled by BDIN L and BIAKI L. The device responds by asserting BRPLY L and its BDAL<15:00> L bus driver inputs with the vector address bits. The BDAL bus driver inputs must be stable within 125 ns (maximum) after BRPLY L is asserted. The processor then inputs the vector address and negates BDIN L and BIAKO L. The device then negates BRPLY L and 100 ns (maximum) later removes the vector address bits. The processor then enters the device's service routine. ## NOTES - Propagation delay from BIAKI L to BIAKO L must not be greater than 500 ns per O22 Bus slot. - The device must assert BRPLY L within 10 microseconds (maximum) after the processor asserts BIAKI L. ## A.5.3 Q22 Bus Four Level Interrupt Configurations If you have high-speed peripherals and desire better software performance, you can use the 4-level interrupt scheme. Both position-independent and position-dependent configurations can be used with the 4-level interrupt scheme. The position-independent configuration is illustrated in Figure A-13. This allows peripheral devices that use the 4-level interrupt scheme to be placed in the backplane in any order. These devices must send out interrupt requests and monitor higher-level request lines as described. The level 4 request is always asserted a requesting device regardless of priority. If two or more devices of equally high priority request an interrupt, the device physically closest to the processor will win arbitration. Devices that use the single-level interrupt scheme must be modified or placed at the end of the bus for arbitration to function properly. Figure A-13 Position-Independent Configuration The position-dependent configuration is illustrated in Figure A-14. This configuration is simpler to implement. A constraint is that peripheral devices must be inserted with the highest-priority device located closest to the processor and the remaining devices placed in the backplane in decreasing order of priority, with lowest-priority devices farthest from the processor. With this configuration each device has to assert only its own level and level 4. Monitoring higher level request lines is unnecessary. Arbitration is achieved through the physical positioning of each device on the Single-level interrupt devices on level 4 should be positioned bus. last on the bus. Figure A-14 Position-Dependent Configuration #### A.6 CONTROL FUNCTIONS The following Q22 Bus signals provide control functions. BREF L Memory refresh (also block mode DMA) BHALT L Processor halt BINIT L Initialize BPOK H Power OK BDCOK H DC power OK ## A.6.1 Memory Refresh If BREF is asserted during the address portion of a bus data transfer cycle, it causes all dynamic MOS memories to be addressed simultaneously. The sequence of addresses required for refreshing the memories is determined by the specific requirements for each memory. The complete memory refresh cycle consists fo a series of refresh bus transactions. A new address is used for each transaction. A complete memory refresh cycle must be completed within 1 or 2 ms. Multiple data transfers by DMA devices must be avoided since they could delay memory refresh cycles. This type of refresh is done only for memories which do not perform on-board refresh. #### A.6.2 Halt Assertion of BHALT L for at least $25\,$ ns interrupts the processor, which stops program execution and forces the processor unconditionally into console I/O mode. #### A.6.3 Initialization Devices along the bus are initialized when BINIT L is asserted. The processor can assert BINIT L as a result of executing a RESET instruction as part of a power-up or power-down sequence. BINIT L is asserted for approximately 10 microseconds when RESET is executed. #### A.6.4 Power Status Power status protocol is controlled by two signals, BPOK H and BDCOK H. These signals are driven by some external device (usually the power supply). ## A.6.5 BDCOK H When asserted, this indicates that dc power has been stable for at least 3 ms. Once asserted, this line remains asserted until the power fails. It indicates that only 5 microseconds of dc power reserve remains. #### A.6.6 BPOK H When asserted, this indicates that there is at least an 8 ms reserve of dc power and that BDCOK H has been asserted for at least 70 ms. Once BPOK has been asserted, it must remain asserted for at least 3 ms. The negation of this line, the first event in the power-fail sequence, indicates that power is failing and that only 4 ms of dc power reserve remains. ## A.6.7 Power · Up/Down Protocol Power-up protocol begins when the power supply applies power with BDCOK H negated. This forces the processor to assert BINIT L. When the dc voltages are stable, the power supply or other external device asserts BDCOK H. The processor responds by clearing the PS, floating point status register (FPS), and floating point exception register (FEC). BINIT L is asserted for 12.6 microseconds and then negated for 110 microseconds. The processor continues to test for BPOK H until it is asserted. The power supply asserts BPIK H 70 ms (minimum) after BDCOK H is asserted. The processor then performs its power-up sequence. Normal power must be maintained at least 3.0 ms before a power-down sequence can begin. A power-down sequence begins when the power supply negates BPOK H. When the current instruction is completed, the processor traps to a power-down routine at location 24. The end of the routine is terminated with a HALT instruction to avoid any possible memory corruption as the dc voltages decay. When the processor executes the HALT instruction, it tests, the BPOK H signal. If BPOK H is negated, the processor enters the power-up sequence. It clears internal registers, generates BINIT L, and continues to check for the assertion of BPOK H. If it is asserted and dc voltages are still stable, the processor will perform the rest of the power-up sequence. Figure A-15 illustrates power-up/power-down timing. Figure A-15 Power-Up/Power-Down Timing ## A.7 Q22 BUS ELECTRICAL CHARACTERISTICS Signal Level Specification Input Logic Levels TTL Logical Low: 0.8 Vdc maximum TTL Logical High: 2.0 Vdc minimum Output Logic Levels TTL Logical Low: 0.4 Vdc maximum TTL Logical High: 2.4 Vdc minimum #### A.7.1 Load Definition AC loads comprise the maximum capacitance allowed per signal line to ground. A unit load is defined as 9.35 pF of capacitance. DC loads are defined as maximum current allowed with a signal line driver asserted or unasserted. A unit load is defined as 210 uA in the unasserted state. #### A.7.2 120 Ohm Q22 Bus The electrical conductors interconnecting the bus device slots are treated as transmission lines. A uniform transmission line, terminated in its characteristic impedance, will propagate an electrical signal without reflections. Since bus drivers, receivers, and wiring connected to the bus have finite resistance and nonzero reactance, the transmission line impedance is not uniform, and introduces distortions into pulses propagated along it. Passive components of the Q22 Bus (such as wiring, cabling, and etched signal conductors) are designed to have a nominal characteristic impedance of 120 ohms. The maximum length of interconnecting cable excluding wiring within the backplane is limited to $4.88\ m$ (16 ft.). #### A.7.3 Bus Drivers Devices driving the 120 ohm Q22 Bus must have open collector outputs and meet the following specifications. #### DC SPECIFICATIONS Output low voltage when sinking 70 mA of current: 0.7 V maximum. Output high leakage current when connected to 3.8 Vdc: 25 uA (even if no power is applied, except for BDCOK H and BPOK H). These conditions must be met at worst-case supply temperature, and input signal levels. #### AC SPECIFICATIONS Bus driver output pin capacitive load: Not to exceed 10 pf. Propagation delay: Not to exceed 35 ns. Skew (difference in propagation time between slowest and fastest gate): Not to exceed 25 ns. Rise/Fall Times: Transition time (from 10% to 90% for positive transition, and from 90% to 10% for negative transition) must be no faster than 10 ns. #### A.7.4 Bus Receivers Devices that receive signals from the 120 ohm Q22 Bus must meet the following requirements. #### DC SPECIFICATIONS Input low voltage (maximum): 1.3 V. Input high voltage (minimum): 1.7 V. Maximum input current when connected to 3.8 Vdc: 80 uA even if no power is applied. These specifications must be met at worst-case supply voltage, temperature, and output signal conditions. ## AC SPECIFICATIONS Bus receiver input pin capacitance load: Not to exceed 10 pF. Propagation delay: Not to exceed 35 ns. Skew (difference in propagation time between slowest and fastest gate): Not to exceed 25 ns. ## A.7.5 Bus Termination The 120 ohm Q22 Bus must be terminated at each end by an appropriate terminator, as illustrated in Figure A-16. This is to be done as a voltage divider with its Thevenin equivalent equal to 120 ohms and 3.4 V nominal. This type of termination is provided by an REV11-A refresh/boot/terminator, BDV11-AA, KPV11-B, TEV11, or by certain backplanes and expansion cards. Figure A-16 Bus Line Terminations Each of the several Q22 Bus lines (all signals whose mnemonics start with the letter B) must see an equivalent network with the following characteristics at each end of the bus: Input impedance (with respect to 120 ohm + 5%, -15% ground) Open circuit voltage 3.4 Vdc +5% Capacitance Load Not to exceed 30 pF NOTE The resistive termination may be provided by the combination of two modules (i.e., the processor module supplies 220 ohms to ground. This, in parallel with another 220 ohm card provides 120 ohms.) Both of these terminators must be physically resident within the same backplane. ## A.7.6 Bus Interconnecting Wiring ## A.7.6.1 Backplane Wiring The wiring that connects all device interface slots on the Q22 bus must meet the following specifications: - The conductors must be arranged such that each line exhibits a characteristic impedance of 120 ohms (measured with respect to the bus common return). - 2. Crosstalk between any two lines must be no greater than 5%. Note that worst-case crosstalk is manifested by simultaneously driving all but one signal line and measuring the effect on the undriven line. - DC resistance of the signal path, as measured between the near-end terminator and the far-end terminator module (including all intervening connectors, cables, backplane wiring, connector-module etch, etc.) must not exceed 20 ohms. - 4. DC resistance of common return path, as measured between the near-end terminator and the far-end terminator module (including all intervening connectors, cables, backplane wiring, connector-module etch, etc.) must not exceed an equivalent of 2 ohms per signal path. Thus, the composite signal return path dc resistance must not exceed 2 ohms divided by 40 bus lines, or 50 milliohms. Note that although this common return path is nominally at ground potential, the conductance must be part of the bus wiring. The specified low impedance return path must be provided by the bus wiring as distinguished from the common system or power ground path. ## A.7.6.2 Intra-Backplane Bus Wiring The wiring that connects the bus connector slots within one contiguous backplane is part of the overall bus transmission line. Owing to implementation constraints, the nominal characteristic impedance of 120 ohms may not be achievable. Distributed wiring capacitance in excess of the amount required to achieve the nominal 120 ohm impedance may not exceed 60 pF per signal line per backplane. ## A.7.6.3 Power and Ground Each bus interface slot has connector pins assigned for the following dc voltages. The maximum allowable current per pin is 1.5 A. +5 Vdc must be regulated to 5% with a maximum ripple of 100 mV pp. +12 Vdc must be regulated to 3% with a maximum ripple of 200 mV pp. - o +5 Vdc -- Three pins (4.5 A maximum per bus device slot) - o +12 Vdc -- Two pins (3.0 A maximum per bus device slot) - o Ground -- Eight pins (shared by power return and signal return) NOTE Power is not bused between backplanes on any interconnecting bus cables. #### A.8 SYSTEM CONFIGURATIONS Q22 Bus systems can be divided into two types: - 1. Systems containing one backplane - 2. Systems containing multiple backplanes Before configuring any system, three characteristics for each module in the system must be known. These characteristics are: - o Power consumption -- +5 Vdc and +12 Vdc current requirements. - o AC bus loading -- the amount of capacitance a module presents to a bus signal line. AC loading is expressed in terms of ac loads where one ac load equals 9.35 pF of capacitance. - o DC bus loading the amount of dc leakage current a module presents to a bus signal when the line is high (undriven). DC loading is expressed in terms of dc loads where one dc load equals 210 microamperes (nominal). Power consumption, ac loading, and dc loading specifications for each module are included in the Microcomputer Interface Handbook. NOTE The ac and dc loads and the power consumption of the processor module, terminator module, and backplane must be included in determining the total loading of a backplane. Rules for Configuring Single Backplane Systems - When using a processor with 220 ohm termination, the bus can accommodate modules that have up to 20 ac loads (total) before additional termination is required (see Figure A-17). If more than 20 ac loads are included, the other end of the bus must be terminated with 120 ohms, and then up to 35 ac loads may be present. - 2. With 120 ohm processor termination, up to 35 ac loads can be used without additional termination. If 120 ohm bus termination is added, up to 45 ac loads can be configured in the backplane. - 3. The bus can accommodate modules up to 20 dc loads (total). - 4. The bus signal lines on the backplane can be up to 35.6 cm (14 in.) long. Figure A-17 Single Backplane Configuration Rules for Configuring Multiple Backplane Systems - 1. As illustrated in Figure A-18, up to three backplanes may make up the system. - The signal lines on each backplane can be up to 25.4 cm (10 in.) long. - 3. Each backplane can accommodate modules that have up to 22 ac loads (total). Unused ac loads from one backplane may not be added to another backplane if the second backplane loading will exceed 22 ac loads. It is desirable to load backplanes equally, or with the highest ac loads in the first and second backplanes. - 4. DC loading of all modules in all backplanes cannot exceed 20 loads (total). - 5. Both ends of the bus must be terminated with 120 ohms. This means that the first and last backplane must have an impedance of 120 ohms. To achieve this, each backplane may be lumped together as a single point. The resistive termination may be provided by a combination of two modules in the backplane -- the processor providing 220 ohms to ground in parallel with an expansion paddle card providing 250 ohms to give the needed 120 ohm termination. Alternately, a processor with 120 ohm termination would need no additional termination on the paddle card to attain 120 ohms in the first box. The 120 ohm termination in the last box can be provided in two ways. The termination resistors may reside either on the expansion paddle card or on a bus termination card such as the BDV11. - 6. The cable(s) connecting the first two backplanes are 61 cm (2 ft.) or greater in length. - 7. The cable(s) connecting the second backplane to the third backplane are 122 cm (4 ft.) longer or shorter than the cable(s) connecting the first and second backplanes. - 8. The combined length of both cables cannot exceed 4.88 m (16 ft.). - 9. The cables used must have a characteristic impedance of 120 ohms. Figure A-18 Multiple Backplane Configuration ## A.8.1 Power Supply Loading Total power requirements for each backplane can be determined by obtaining the total power requirements for each module in the backplane. Obtain separate totals for +5 V and +12 V power. Power requirements for each module are specified in the Microcomputer Interfaces Handbook. When distributing power in multiple backplane systems, do not attempt to distribute power via the Q22 Bus cables. Provide separate, appropriate power wiring from each power supply to each backplane. Each power supply should be capable of asserting BPOK H and BDCOK H signals according to bus protocol; this is required if automatic power-fail/restart programs are implemented, or if specific peripherals require an orderly power-down halt sequence. The proper use of BPOK H and BDCOK H signals is strongly recommended. ## A.9 MODULE CONTACT FINGER IDENTIFICATION DIGITAL plug-in modules all use the same contact finger (pin) identification system. A typical pin is shown in Figure A-19. The Q22 Bus is based on the use of quad-height modules that plug into a 2-slot bus connector. Each slot contains 36 lines (18 each on component and solder sides of circuit board). Figure A-19 Typical Pin Identification System Slots, row A and row B include a numeric identifier for the side of the module. The component side is designated side 1 and the solder side is designated side 2. Letters ranging from A through V (excluding G, I, O, and Q) identify a particular pin on a side of a slot. Table A-4 lists and identifies the bus pins of the quad-height module. The bus pin identifier ending with a 1 is found on the component side of the board, while a bus pin identifier ending with a 2 is found on the solder side of the board. The positioning notch between the two rows of pins mates with a protrusion on the connector block for correct module positioning. Figure A-20 Quad-Height Module Contact Finger Identification Table A-4 Bus Pin Identifiers (Sheet 1 of 8) | Bus<br>Pin | Mnemonics | Descripton | |------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AAl | BIRQ5 L | Interrupt Request Priority Level 5 | | ABl | BIRQ6 L | Interrupt Request Priority Level 6 | | AC1 | BDAL 16 L | Extended address bit during addressing protocol; memory error data line during data transfer protocol | | ADl | BDAL 17 L | Extended address bit during addressing protocol; memory error logic enable during data transfer protocol. | | AEl | SSPARE1<br>(Alternate +5B) | Special Spare not assigned or bused in DIGITAL cable or backplane assemblies; available for user connection. Optionally, this pin may be used for +5 V battery (+5 B) backup power to keep critical circuits alive during power failures. A jumper is required on Q22 Bus options to open (disconnect) the +5 B circuit in systems that use this line as SSPARE1. | | AF1 | SSPARE2 | Special Spare not assigned or bused in DIGITAL cable or backplane assemblies; available for user interconnection. In the highest-priority device slot, the processor may use this pin for a signal to indicate its RUN state. | | AHl | SSPARE3<br>SRUN | Special Spare not assigned or bused in DIGITAL cable or backplane simultaneously assemblies; available for user interconnection. An alternate SRUN signal may be connected in the highest-priority set. | | AJl | GND . | Ground System signal ground and dc return. | | AKl | MSPAREA | Maintenance Spare Normally connected together on the backplane at each option location (not bused connection). | Table A-4 Bus Pin Identifiers (Sheet 2 of 8) | Bus Pin | Mnemonics | Description | |---------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ALl | MSPAREB | Maintenance Spare Normally connected together on the backplane at each option location (not bused connection). | | AMl | GND | Ground System signal ground and dc return. | | ANl | BDMR L | Direct Memory Access (DMA) Request A device asserts this signal to request bus mastership. The processor arbitrates bus mastership between itself and all DMA devices on the bus. If the processor is not bus master (it has completed a bus cycle and BSYNC L is not being asserted by the processor), it grants bus mastership to the requesting device by asserting BDMGO L. The device responds by negating BDMR L and asserting BSACK L. | | AP1 | BHALT L | Processor Halt When BHALT L is asserted for at least 25 us, the processor services the halt interrupt and responds by halting normal program execution. External interrupts are ignored but memory refresh interrupts in Q22 are enabled if W4 on M7264 and M7264-YA processor modules is removed and DMA request/grant sequences are enabled. The processor executes the ODT microcode and the console device operation is invoked. | | AR1 | BREF L | Memory Refresh Asserted by a DMA device. This signal forces all dynamic MOS memory units requiring bus refresh signals to be activated for each BSYNC L/BDIN L bus transaction. It is also used as a control signal for block mode DMA. | Table A-4 Bus Pin Identifiers (Sheet 3 of 8) | Bus Pin | Mnemonics | Description | |---------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | CAUTION | | | | The user must avoid multiple DMA data transfers (burst or "hot" mode) that could delay refresh operation if using DMA refresh. Complete refresh cycles must occur once every 1.6 msec if required. | | AS1 | +12B<br>or<br>+5 B | +12 Vdc or +5 V battery backup power to keep critical circuits alive during power failures. This signal is not bused to BSl in all DIGITAL backplanes. A jumper is required on all Q22 Bus options to open (disconnect) the backup circuit from the bus in systems that use this line at the alternate voltage. | | ATl | GND | Ground System signal ground and dc return. | | AUl | PSPARE 1 | Spare (Not assigned. Customer usage not recommended.) Prevents damage when modules are inserted upside down. | | AVl | +5 B | +5 V Battery Power Secondary +5 V power connection. Battery power can be used with certain devices. | | BAl | BDCOK H | DC Power OK Power supply-generated signal that is asserted when there is sufficient dc voltage available to sustain reliable system operation. | | BBl | BPOK H | Power OK Asserted by the power supply 70 ms after BDCOK negated when ac power drop below the value required to sustain power (approximately 75% of nominal). When negated during processor operation, a power fail trap sequence is initiated. | | BCl | SSPARE4<br>BDAL 18L<br>(22-bit<br>only) | Special Spare in the Q22 Bus Not assigned. Bussed in 22-bit cable and backplane assemblies; available for use interconnection. | Table A-4 Bus Pin Identifiers (Sheet 4 of 8) | Bus Pin | Mnemonics | Description | |------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BDl | SSPARE5<br>BDAL 19L<br>(22-bit<br>only) | CAUTION These pins ay be used as test points by DIGITAL in some options. | | BEl | SSPARE6<br>BDAL 20L | In the Q22 Bus, these bussed address lines are Address Lines <21:18> currently not used during data time. | | BFl | SSPARE7<br>BDAL 21L | In the Q22 Bus, these bussed address lines are Address Lines <21:18> currently not used during data time. | | вні | SSPARE8 | Special Spare Not assigned or bussed in DIGITAL cable and backplane assemblies; available for user interconnection. | | BJl | GND | Ground System signal ground and dc return. | | BK1<br>BL1 | MSPAREB<br>MSPAREB | Maintenance Spare Normally connected together on the backplane at each option location (not a bused connection). | | BMl | GND | Ground System signal ground and dc return. | | BNl | BSACK L | This signal is asserted by a DMA device in response to the processor's BDMGO L signal, indicating that the DMA device is bus master. | | BPl | BIRQ7 L | Interrupt request priority level 7. | | BRl | BEVNT L | External Event Interrupt Request When asserted, the processor responds by entering a service routine via vector address 1008. A typical use of this signal is a line time block interrupt. | | BSl | +12 B | +12 Vdc battery backup power (not bused to AS1 in all DIGITAL backplanes). | ## Q22 BUS SPECIFICATION Table A-4 Bus Pin Identifiers (Sheet 5 of 8) | Bus Pin | Mnemonics | | |---------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BTl | GND | Ground System signal ground and dc return. | | BUl | PSPARE2 | Power Spare 2 (not assigned a function, not recommended for use). If a module is using -12 V (on pin AB2) and if the module is accidentally inserted upside down in the backplane, -12 Vdc appears on pin BU1. | | BVl | +5 | +5 V Power Normal +5 Vdc system power | | AA2 | +5 | +5 V Power Normal +5 Vdc system power | | AB2 | -12 | -12 V Power12 Vdc (optional) power for devices requiring this voltage. | | | | NOTE | | | | Q22 modules which require negative voltages contain an inverter circuit (on each module) which generates the required voltage(s). Hence, -12 V power is not required with DIGITAL-supplied options. | | AC2 | GND | Ground System signal ground and dc return. | | AD2 | +12 | +12 V Power12 Vdc system power. | | AE2 | BDOUT L | Data Output BDOUT, when asserted, implies that valid data is available on BDAL <0:15>L and that an output transfer, with respect to the bus master device, is taking place. BDOUT L is deskewed with respect to data on the bus. The slave device responding to the BDOUT L signal must assert BRPLY L to complete the transfer. | Table A-4 Bus Pin Identifiers (Sheet 6 of 8) | Bus Pin | Mnemonics | Description | |---------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AF2 | BRPLY L | Reply BRPLY L is asserted in response to BDIN L or BDOUT L and during IAK transactions. It is generated by a slave device to indicate that it has placed its data on the BDAL bus or that it has accepted output data from the bus. | | AH2 | BDIN L | Data Input BDIN L is used for two types of bus operation: | | | | When asserted during BSYNC L time, BDIN L implies an input transfer with respect to the current bus master, and requires a response (BRPLY L). BDIN L is asserted when the master device is ready to accept data from a slave device. | | | | When asserted without BSYNC L, it indicates that an interrupt operation is occurring. | | | | The master device must deskew input data from BRPLY L. | | AJ2 | BSYNC L | Synchronize BSYNC L is asserted by the bus master device to indicate that it has placed an address on BDAL<0:17> L. The transfer is in process until BSYNC L is negated. | | AK2 | BWTBT L | Write/Byte BWTBT L is used in two ways to control a bus cycle: | | | | It is asserted at the leading edge of BSYNC L to indicate that an output sequence is to follow (DATO or DATOB), rather than an input sequence. | | | | It is asserted during BDOUT L, in a DATOB bus cycle, for byte addressing. | | AL2 | BIRQ4 L | Interrupt Request Priority Level 4 A level 4 device asserts this signal when its interrupt enable and interrupt request flips-flops are set. If the PS word bit 7 is 0, the processor responds by acknowledging the request by asserting BDIN L and BIAKO L. | Table A-4 Bus Pin Identifiers (Sheet 7 of 8) | Bus Pin | Mnemonics | Description | |------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | BIAKI L<br>BIAKO L | Interrupt Acknowledge In accordance with interrupt protocol, the processor asserts BIAKO L to acknowledge receipt of an interrupt. The bus transmits this to BIAKI L of the device electrically closest to the processor. This device accepts the interrupt acknowledge under two conditions: | | | | The device requested the bus by asserting BIRQXL, and 2) the device has the highest-priority interrupt request on the bus at that time. | | | | If these conditions are not met, the device asserts BIAKO L to the next device on the bus. This process continues in a daisy-chain fashion until the device with the highest-interrupt priority receives the interrupt acknowledge signal. | | AP2 | BBS7 L | Bank 7 Select The bus master asserts this signal to reference the I/O page (including that portion of the I/O page reserved for nonexistent memory). The address in BDAL<0:12>L when BBS7 L is asserted is the address within the I/O page. | | AR2<br>AS2 | BDMGI L BDMGO L | Direct Memory Access Grant The bus arbitrator asserts this signal to grant bus mastership to a requesting device, according to bus mastership protocol. The signal is passed in a daisy-chain from the arbitrator (as BDMGO L) through the bus to BDMGI L of the next priority device (electrically closest device on the bus). This device accepts the grant only if it requested to be bus master (by a BDMR L). If not, the device passes the grant (asserts BDMGO L) to the next device on the bus. This process continues until the requesting device acknowledges the grant. | ## CAUTION DMA device transfers must not interfere with the memory refresh cycle. Table A-4 Bus Pin Identifiers (Sheet 8 of 8) | Bus Pin | Mnemonics | Description | |------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | AT2 | BINIT L | Initialize This signal is used for system reset. All devices on the bus are to return to a known, initial state; i.e., registers are reset to zero, and logic is reset to state 0. Exceptions should be completely documented in programming and engineering specifications for the device. | | AU2<br>AV2 | BDALO L BDAL1 L | Data/Address lines These two lines are part of the 16-line data/address bus over which address and data information are communicated. Address information is first placed on the bus by the bus master device. The same device then either receives input data from, or outputs data to the addressed slave device or memory over the same bus lines. | | BA2 | +5 | +5 V Power Normal +5 Vdc system power. | | BB2 | -12 | -12 V Power (Voltage normally not supplied by DIGITAL)12 Vdc (optional) power for devices requiring this voltage. | | BC2 | GND | Ground System signal ground and dc return. | | BD2 | +12 | +12 V Power +12 V system power. | | BE2<br>BF2<br>BH2<br>BJ2<br>BK2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM2<br>BM | BDAL2 L BDAL3 L BDAL4 L BDAL5 L BDAL6 L BDAL7 L BDAL8 L BDAL9 L BDAL10 L BDAL11 L BDAL12 L BDAL12 L BDAL13 L BDAL14 L BDAL15 L | Data/Address Lines These 14 lines are part of the 16-line data/address bus previously described. | thou connector YEL BEN GRN BLY RED VIOL BUK BRN APPENDIX B LK201 KEYBOARD SPECIFICATION ## B.1 GENERAL DESCRIPTION The LK201 keyboard has 105-concave surfaced keys which are divided into four groups: typing keys, numeric keypad for data entry, screen/cursor control keys for editing, and special programmable command/function keys supported by an enclosed printed circuit board. There are four LEDs that indicate when a specific function is in operation. A 1.9 meters (6 feet) coiled cable connects the keyboard to a dedicated 4-pin MICRO-DIN connector on the monitor's rear panel. Figure B-l shows the LK201 keyboard. The keyboard is the user interface to the system. It detects keystrokes, encodes them, and transmits the information to the central processor. The keyboard also receives information from the central processor. Communication between the keyboard and the central processor in the system unit (BA23 or BA123) is full-duplex, serial asynchronous at a speed of 4800 baud. The communication lines conform to EIA Standard RS-423, which applies to unbalanced voltage interfaces. #### B.2 PHYSICAL DESCRIPTION The keyboard used with the MicroVAX workstation has 105 keys arranged in the following four groups (see Figure B-1). ## LK201 KEYBOARD SPECIFICATION - o Main keypad (57 keys) - o Numeric keypad (18 keys) - o Special function keypad (20 keys) - o Editing keypad (10 keys) Figure B-1 LK201 Keyboard The keycaps can be installed manually, but require a special tool for removal. The keyboard circuitry is contained in a low profile cabinet with a nominal height of 30 mm from table top to home row. The keyboard case is made of two plastic shells that can be separated with a screwdriver. Nonslip plastic strips along the bottom prevent the keyboard from sliding on a table top. Two feet can be manually inserted in holes to raise the back edge of the keyboard. A plastic window along the top edge above the special function keys can be lifted to insert a keyboard label strip. The label, a thin paper strip, fits into the indented space and varies according to the application program. There are four LEDs located beneath the plastic window. They are labeled HOLD SCREEN, LOCK, COMPOSE, and WAIT. A coiled cable (PN BCCO1), with a 4-pin modular connector on each end, connects the keyboard to the video monitor. The keyboard transmits four types of signals to the monitor that pass unchanged via the video cable to the system unit as shown in Figure B-2. The four signals are as follows: - o +12 V power to keyboard - o Ground to keyboard - o SERIAL OUT (transmit line from keyboard) - o SERIAL IN (receive line to keyboard) Figure B-2 Keyboard Cable Connections The cable can be placed in a channel in the bottom case and the modular type telephone connector fits into the jack, J4. The cable can be inserted in the channel to either side of the keyboard. #### B.3 BLOCK DIAGRAM DESCRIPTION Figure B-3 shows a simplified block diagram of the keyboard circuitry. All diagram blocks except the block marked KEYBOARD MATRIX is on the printed circuit board. This block represents the connections between the keyboard switches and the signals from the 8051 microprocessor. Figure B-3 Simplified Block Diagram of LK201 Keyboard Circuitry The firmware in the 8051 8-bit microprocessor controls the following three major keyboard operations at the same time: - Scans the keyboard to detect changes in the keyboard matrix - Transmits the results of the keyboard scan to the system central processor - 3. Receives information from the system central processor #### LK201 KEYBOARD SPECIFICATION #### B.3.1 Keyboard Scanning The keyboard switches are connected at the intersections of an 18 X 8 line matrix. This provides a fixed position identifier for each key. The firmware scans the 18-line axis and detects a depressed or newly released key by reading the 8-line axis. The firmware then verifies the detected keystroke and changes this positional information into an 8-bit code that is unique to that key. ## B.3.2 Control of Audio Transducer and Indicators Two circuits control the audio transducer and the indicators. One circuit receives its inputs from the 8051 and controls the transducer (beeper). A long beep represents the bell and a short beep represents the keyclick. A separate circuit, controlled by a signal from the 8051, controls each of the four indicators. The firmware, responding to commands received from the system central processor, turns the indicators on or off. #### B.3.3 Keyboard Firmware Functions This paragraph describes the keyboard firmware functions. The functions are divided into two categories: those that cannot be changed by instructions from the system central processor, and those that can be changed by instructions from the system central processor. # B.3.3.1 Functions Not Changed by System Central Processor Instructions The following functions cannot be changed by instructions from the system central processor: - o Power-up test - o Keycodes - o Special codes #### POWER-UP TEST Upon power-up, the firmware performs a selftest in less than 70 ms. The test results are transmitted to the system central processor in four bytes. The keyboard indicators are lit during the selftest. The indicators blink once during the selftest routine. The indicators go off if the test is passed, but remain lit if the test fails. The system module can also request selftest at any time. #### **KEYCODES** The keycodes represent fixed positions in the key switch matrix. The key associated with a particular matrix position is always represented by the same keycode. #### SPECIAL CODES There are 13 special codes transmitted by the keyboard. Four codes transmit the results of the power-up selftest. The other nine codes are status indicators or command acknowledgements. B.3.3.2 Functions Changed by System Central Processor Instructions The system central processor can issue instructions to change some keyboard transmission characteristics and to control the keyboard indicators and beeper. Upon completion of a successful power-up selftest, the firmware sets certain functions to predetermined conditions. They are referred to as default conditions. The conditions can be changed, but they always come up to the default condition after a successful power-up selftest. ## B.3.3.3 Firmware Functions That Can be Changed Certain firmware functions can be changed by commands (instructions) from the system central processor. These commands are categorized as transmission commands and peripheral commands. Transmission commands include a Mode Set command and an Auto-Repeat Rate Set command. Peripheral commands include a variety of commands. ## B.4 DETAILED KEYBOARD CIRCUIT DESCRIPTION The following section describes the keyboard circuitry shown in Figure B-3. ## B.4.1 Keyboard Matrix Scanning The key locations are arranged in an 18 X 8 line matrix. Each key switch is connected across a matrix intersection. This gives a fixed position for each key connected in the matrix. This matrix accommodates all 105 keys in the LK201 keyboard. Figure B-4 is a simplified block diagram of the matrix scanning circuit. Eight lines from port 1 of the 8051 microprocessor go to the binary coded decimal (BCD) inputs of two 74LS145 BCD-to-decimal decoders. Ten outputs from one decoder and eight outputs from the other decoder provide the drive lines for the matrix. These 18 lines are called KB DRIVE 0--17. The other axis of the matrix consists of eight lines tied to +5 V through pull-up resistors. These lines go to port 0 of the 8051 microprocessor and are called KB DATA 0--7. The 8051 scans the 18 drive lines. Key closures are detected by reading the eight data lines. The complete matrix is scanned every 8.33 ms. When a key closure is detected, it is scanned again to verify that it is a key closure and not electrical noise. Once the key closure is verified, the 8051 firmware translates the position information into a key code and transmits it to the system central processor. Transmission is handled by the Universal Asynchronous Receiver Transmitter (UART) in the 8051. Figure B-4 Simplified Block Diagram of Matrix Scanning Circuit A sneak path or ghost key indication can occur when three of the four corners of a matrix rectangle are closed as shown in Figure B-5. The key positions in the matrix are arranged to avoid sneak paths. However, if a sneak path does occur, the firmware prevents the keycode for the key (which caused the sneak path) to be transmitted until one of the involved keys is released. This prevents transmission of ghost keys entirely. - CONDITIONS ARE: SWITCHES 82, 83, AND C3 CLOSED, SWITCH C2 OPEN; LINE 2 IS BEING DRIVEN, AND LINE C IS BEING READ. - 2. INTERSECTION C2 IS BEING LOOKED AT, IT SHOULD NOT SHOW A KEY CLOSURE BECAUSE SWITCH C2 IS OPEN. - 3. HOWEVER, A SNEAK PATH IS PRESENT FROM LINE 2 THROUGH SWITCHES B2, B3, AND C3 TO LINE C. A GHOST KEY IS READ AT INTERSECTION C2. Figure B-5 Example of Ghost Key Generation Table B-l shows the keyboard matrix on the LK201-AA (U.S.A.) keyboard. Keycap designations are shown for reference only and can be compared to Figure B-6. Table B-1 Keyboard Matrix (LK201-AA) | KB<br>Drive | Kā Data<br>7 | 6 | 5 | 4 | 3 . | 2<br> | 1 | 0 | |-------------|--------------------------|-------------------------------|----------------|----------------|-------------------------|-------------|----------------|---------------| | 17 | Reserved | F19 | Reserved | F20 | <b>P</b> F4 | # | #,<br>(Note 1) | ·Ente: | | • | | 622 | | 623 | E23 | Ď33 | C23 | A23 | | 16 | F19<br>G21 | PF3<br>E22 | Reserved | 89<br>D22 | Ý<br>917 | C22 | N3<br>822 | #<br>A22 | | 15 | F17 | PF2 | Reserved | | <b>#5</b> | -> | W2 | NO<br>Note : | | | 620 | E21 | | D21 | C21 | 918 | 821 | | | 14 | PF1 | Next<br>Screen | Resove | • | N7 | #4 | <b>#1</b> | <b>M</b> O | | | £20 | D18 | E19 | Č17 | D20 | C20 | 320 | A20 | | 13 | Insert<br>Here | | <b>D</b> 0 | Prev<br>Screen | <b>(</b> | • | RSVd | REYD | | | £17 | E11 | G16 | D17 | Dļ1 | C11 | | | | 12 | Find | ÷ | Melp | Select | }<br>1 | Return | <b>&lt;-</b> | | | | E16 | E12 | G15 | D16 | D12 | C13 | 816 | C12 | | 11 - | Addtnl<br>Options<br>G14 | <x <br>(delet<br/>E13</x <br> | Reserved<br>e) | )<br>0<br>E10 | P<br>D10 | (Note 3) | 1<br>1<br>C10 | 7<br>/<br>B10 | | 10 | Reserved | F12 | Reserved | F13 | ι. | 0 | L | • | | - | | (B8)<br>G12 | | (LF)<br>Cl3 | <b>9</b><br><b>E</b> 09 | Ď0 <b>.</b> | C09 | 809 | | • | Reserved | F11<br>(ESC) | Reserved | Reserved | • | I | K. | • | | | | G11 | | | EOS | DOS | COS | 809 | | • | Reserved | Main<br>Screen | | Exit | £<br>7 | U | J . | × | | | | COS | | 609 | E07 | D07 | C07 | B07 | | 7 | Reserved | Cancel | Reserved | Resupe | i | Y | Ħ | 8 | | | ` | 607 | | 606 | E06 | D06 | C06 | 906 | | 6 | Ravd | Revá | RSVd | Inter-<br>rupt | <b>t</b><br>5 | . 2 | G | | | | | | | 605 | E05 | Đ05 | C05 | 805 | | 5 | <b>F4</b> | Break | Reserved | * | R | F | · <b>Y</b> | SPAC | | | 602 | C03 | | E04 | D04 | C04 | 804 | A01- | | 4 | Reserved | Print | Reserved | Set-Up | • | 3 | D | C | | | | Screet<br>600 | 1 | 601 | 3<br>203 | DO | E03 | 803 | | 3 | Hold ! | • | Reserved | Teb | ¥ | | x | <b>&gt;</b> | | | Screen<br>G99 | 2<br>E02 | | DOG | D02 | Coš | 802 | 800 | | 2 | Rsvd | Rayd | Revd | • | 1 | • | Ā | Z | | | | | | E00 | E01 | D01 | COL | 901 | | 1 | Ctrl | Lock | Compo | se Reser | ved | | | | | | ·C99 | COO | A99 | | | | | | | 0 | Shift | | | | | | | | | | 899,811 | | | | | - | | | # HOTES <sup>1.</sup> Note that NO--N9, N---, N, and N. refer to the numeric keypad. <sup>2.</sup> WO of the numeric keyped can be divided into two Keys. Mormally only the MO keyswitch is implemented as a double-size key. <sup>3.</sup> The Return key occupies two positions which are decoded as the Return (C13) key. Figure B-6 LK201 Keyboard Layout ## B.4.2 Audio Transducer Control Circuit Figure B-7 shows the audio transducer or beeper control circuit. The beeper is driven by a transistor whose base is connected to a 2 kHz square wave from a 556 timer IC. This signal is biased by a network of four type 74LS05 open collector inverters. The 8051 microprocessor controls all four inverters via the firmware. The ON/OFF inverter connects directly to the transistor base. When the 8051 puts a high on the ON/OFF inverter input, its output goes low and removes the 2 kHz square wave from the transistor base. This cuts off the transistor and disables the beeper. To turn on the beeper, the 8051 puts a low on the ON/OFF inverter input. Its output goes high and allows the 2 kHz signal to reach the transistor base. This turns on the beeper. The firmware generates a keyclick (on for 2 ms) or a bell tone (on for 125 ms). The 8051 sets up the three level control inverters by putting one of eight binary combinations on the inverter inputs. All highs give the softest sound and all lows give the loudest sound. The firmware controls the keyclick and the bell tone independently. The bell tone is sounded only upon request from the system control processor. The keyclick is sounded (unless disabled) under the following conditions: - 1. When a key is pressed - 2. When a metronome code is sent - 3. When a command to sound the keyclick is received from the system control processor Figure B-7 Audio Transducer (Beeper) Control Circuit # B.4.3 Indicator (LED) Control Circuit Figure B-8 shows the LED indicator control circuit. The control signal for each LED comes from port 2 of the 8051 to the input of a type 74LS05 open collector inverter. The inverter output goes to the LED cathode; its anode is connected to +5 V. A separate +5 V source relieves the LED's load on the main +5 V supply. Figure B-8 Indicator (LED) Control Circuit A low signal from the 8051 drives the inverter output high, which cuts off the LED. A high signal from the 8051 drives the inverter output low. This provides a path to ground from the +5 V through the LED. The LED then turns on. ## B.4.4 Keyboard Communication # B.4.4.1 Keyboard Transmit Mode The keyboard codes and a few other special codes are transmitted via a serial line output in port 3 of the 8051. The transmitted signal goes from the 8051 to a driver, through the keyboard cable, monitor, and video cable to the system central processor. A UART within the 8051 controls the transmission. Transmitted characters conform to a specific format. Each character is 10 bits long. The first bit is the START bit. It is always a logical 0 (space). The next eight bits represent the encoded data. The last bit is the STOP bit. It is always a logical 1 (mark). Figure B-9 shows the character format. Figure B-9 Keyboard Transmit and Receive Character Format ## B.4.4.2 Keyboard Receive Mode The firmware contains features that can be enabled by commands from the system central processor. There are two categories of features: one sets keyboard transmission characteristics, and the other controls the keyboard peripherals. A peripheral command covers indicator control, bell and keyclick volume, keyboard ID code, and reinstate keyboard. The commands come from the system central processor, through the video cable, monitor, and keyboard cable to the receiver and into the 8051 via port 3. They go to the UART in the 8051. Received characters conform to the same 10-bit format used for transmitted characters. The eight data bits are arranged in a specified protocol depending on the command type. # B.4.5 Reset Signal for 8051 Microprocessor Whenever the system is turned on, the 8051 microprocessor in the keyboard must be reset. This allows the 8051 to start operating. The reset signal generator is active only during power-up. The input is +5 V. The output is connected to the reset input of the 8051. When power is turned on, the +5 voltage starts to rise from zero. The reset signal circuit output follows it and drops off when a steady state of +5 V is reached. This circuit holds the 8051 reset input high (+3.5 V to +5 V) long enough to enable the reset action in the 8051. This action occurs only during power-up. # B.4.6 Hardware Keyboard Identification (ID) At power-up, the keyboard performs a selftest and sends the results to the system central processor. One piece of information to be sent is the keyboard hardware ID which is read from hardwired jumpers. There are six jumpers. Each jumper line goes from an input in port 3 of the 8051 to ground. All jumpers are installed so the keyboard hardware ID is zero. ## B.4.7 Voltage Supplies The only voltage sent to the keyboard is +12 V. However, +5 V and -10 V are also required. These voltages are derived from the +12 V. There is a +5 V supply that handles most of the requirements for this voltage. The four keyboard LEDs have their own +5 V supply. A --10 V supply provides voltage for the driver in the SERIAL OUT line. #### B.5 KEYBOARD PROGRAMMING This section describes the functions that the keyboard performs under system central processor control. It also describes keyboard programming machine language. High level user programming is not described here. # B.5.1 Keyboard Layout and Key Identification Each keyboard key has a unique location. Each location is scanned and when closure or release is detected, the location is verified. This is then decoded to an 8-bit keycode. Figure B-6 shows the keyswitch locations. Table B-2 shows the 14 functional divisions of the keyboard. Table B-3 shows the divisions, keycaps, and keycodes. | Table B-2 | Keyboard | Functional | Divisions | |-----------|----------------------|------------|-----------| | | - · - 4 ·- · · · · · | | | | Division | Description | Representation | |----------|-------------------------------------------------------------------|----------------| | 1 | 48 graphic keys, spacebar | | | 2 | Numeric keypad | 0010 | | 3 | Delete character (E12) | 0011 | | 4 | Return (Cl3) Tab (D00) | 0100 | | 5 | Lock (C00) Compose (A99) | 0101 | | 6 | Shift (B99 and Bll), Ctrl (C99) | 0110 | | 7 | Horizontal cursors<br>(Bl6 and Bl8) | 0111 | | 8 | Vertical cursors (B17 and C17) | 1000 | | 9 | Six keys directly above<br>the cursor keys (D16D18<br>and E16E18) | 1001 | | 10 | Function keys (G99G03) | 1010 | | 11 | Function keys (G05G09) | 1011 | | 12 | Function keys (GllGl4) | 1100 | | 13 | Function keys (G15G16) | 1101 | | 14 | Function keys (G20G23) | 1110 | Table B-3 Keycode Translation Table (Sheet 1 of 5) | Division | Position | Keycap* | Keycode-**<br>(decimal) | Keycode<br>(hexadecimal) | |-------------|---------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------| | Function Ke | ys | | | | | 10 | G99<br>G00<br>G01<br>G02<br>G03 | Hold Screen Print Screen Set-Up F4 Break Reserved | 086<br>087<br>088<br>089<br>090 | 56<br>57<br>58<br>59<br>5A<br>5B62 | | 11 | G05<br>G06<br>G07<br>G08<br>G09 | Reserved Interrupt Resume Cancel Main Screen Exit Reserved | 099<br>100<br>101<br>102<br>103<br>104<br>105110 | 63<br>64<br>65<br>66<br>67<br>68<br>696E | | 12 | G11<br>G12<br>G13<br>G14 | Reserved<br>F11 (ESC)<br>F12 (BS)<br>F13 (LF)<br>Addtnl Options<br>Reserved | 111<br>112<br>113<br>114<br>115<br>116<br>117122 | 6F<br>70<br>71<br>72<br>73 -<br>74<br>757A | | 13 | G15<br>G16 | Reserved<br>Help<br>Do | 123<br>124<br>125 | 7B<br>7C<br>7D | | 14 | G20<br>G21<br>G22<br>G23 | Reserved<br>F17<br>F18<br>F19<br>F20<br>Reserved | 126127<br>128<br>129<br>130<br>131<br>132135 | 7E7F<br>80<br>81<br>82<br>83<br>8487 | | Basic Edit | ing Keys | | | | | 9 | E16<br>E17<br>E18<br>D16<br>D17 | Reserved Find Insert Here Remove Select Prev Screen Next Screen Reserved | 136137<br>138<br>139<br>140<br>141<br>142<br>143 | 8889<br>8A<br>8B<br>8C<br>8D<br>8E<br>8F<br>90 | Table B-3 Keycode Translation Table (Sheet 2 of 5) | Division | Position | Keycap* | Keycode** | Keycode | |-------------|----------------------------------------|-------------|------------|---------------| | Numeric Ke | ······································ | | (decimal) | (hexadecimal) | | Nameric Re | y pad | | | | | 2 | | Reserved | 145 | 91 | | | A20 | 0 | 146 | 92 | | | - 00 | Reserved | 147 | 93 | | | A22 | • | 148 | 94 | | | A23 | Enter | 149 | 95 | | | B20 | 1<br>2<br>3 | 150 | 96 | | | B21<br>B22 | 2 | 151 | 97 | | | C20 | 3<br>4 | 152 | 98 | | | C21 | 5 | 153<br>154 | 99 | | | C22 | 6 | 155 | 9A | | | C23 | | 156 | 9B<br>9C | | | D20 | <b>7</b> | 157 | 9D | | | D21 | 8 | 158 | 9E | | | D22 | 9 | 159 | 9 F | | | D23 | • | 160 | A0 | | | E20 | PFl | 161 | Al | | | E21 | PF2 | 162 | A2 | | | E22 | PF3 | 163 | A3 | | | E23 . | PF4 | 164 | A4 | | | | Reserved | 165 | A5 | | Cursor Key | S | | | | | 7 | | Reserved | 166 | A6 | | | B16 | Left | 167 | A7 | | | B18 | Right | 168 | A8 | | 8 | в17 | Down | 169 | A9 | | | C17 | Up | 170 | AA | | | | Reserved | 171172 | AB AC | | Shift, Lock | k, Ctrl, A99 | , and AlO | | | | 6 | | Reserved | 173 | AD | | | B99,B11 | Shift | 174 | AE | | | C99 | Ctrl | 175 | AF | | 5 | C00 | Lock | 176 | в0 | | | A99 | Compose | 177 | Bl | | | | Reserved | 178 | B2 | Table B-3 Keycode Translation Table (Sheet 3 of 5) | | | Keycap* | | | |--------------|-------------|-----------------------------------------------|-----|-------------| | Special Code | | | | | | • | | | | | | | | | 179 | B3 | | | | Metronome | | В4 | | | | Output error | | B5 | | | | Input error | | В6 | | | | KBD LOCKED | 183 | в7 | | | | acknowledge | 104 | <b>#</b> 0 | | | | TEST MODE | 184 | В8 | | | | acknowledge | 105 | В9 | | | | PREFIX to keys down | 103 | DJ | | | | MODE CHANGE | 186 | ВА | | | | acknowledge | 100 | <b>D</b> 11 | | | | Reserved | 187 | ВВ | | | | Reserved | 20, | | | Delete | | | | | | | | | | | | 3 | E13 | Delete <x< td=""><td>188</td><td>BC</td></x<> | 188 | BC | | | | | | | | Return and | Tab | | | | | | | | • | | | 4 . | C13 | Return | 189 | BD | | | D00 | Tab | 190 | BE | | | | | | | | 48 Graphics | Keys and Sp | ace Bar | | | | 3 | E00 | ~ | 191 | BF | | 2 | E01 | !1 | 192 | D0 | | | D01 | Q | 193 | Cl | | | C01 | A | 194 | C2 | | | B01 | · Z | 195 | C3 | | | 501 | Reserved | 196 | C4 | | | E02 | @2 | 197 | C5 | | | D02 | W | 198 | C6 | | | C02 | S | 199 | <b>C</b> 7 | | | B02 | X | 200 | C8 | | | B00 | >< | 201 | C9 | | | | Reserved | 202 | CA | | | E03 | #3 | 203 | CB | | | D03 | E | 204 | CC | | | C03 | D | 205 | CD | | | B03 | C | 206 | CE | | | | Reserved | 207 | CF | Table B-3 Keycode Translation Table (Sheet 4 of 5) | Division | Position | Keycap* | Keycode**<br>(decimal) | <pre>Keycode (hexadecimal)</pre> | |----------|------------|---------------|------------------------|----------------------------------| | | E04 | \$4 | 208 | D0 | | | D04 | R | 209 | Dl | | | C04 | F | 210 | D2 | | | C04 | V | 211 | D3 | | | A01A09 | Space | 212 | D4 | | | | Reserved | 213 | D5 | | | E05 | <b>%</b> 5 | 214 | D6 | | | D05 | T | 215 | D7 | | | C05 | G | 216 | D8 | | | в05 | В | 217 | D9 | | | | Reserved | 218 | DA | | | E06 | ^ 6 | 219 | DB | | | D06 | Y | 220 | DC | | | C06 | H | 221 | DD | | | в06 | N | 222 | DE | | 1 | | Reserved | 223 | DF | | | E07 | & 7 | 224 | E0 | | | D07 | U | 225 | El | | | C07 | J | 226 | E2 | | | B07 | M | 227 | E3 | | | | Reserved | 228 | E4 | | | C08 | *8 | 229 | E5 | | | D08 | I | 230 | E6 | | | C08 | K | 231 | E7 | | | в08 | " | 232 | E8 | | | | Reserved | 233 | E9 | | | E09 | ( 9 | 234 | EA | | | D09 | 0 | 235 | EB | | | C09 | L | 236 | EC | | | в09 | <br>Danaman | 237 | ED | | | <b>510</b> | Reserved | 238<br>239 | EE | | | E10<br>D10 | ) 0<br>P | 240 | EF<br>FO | | | סדט | r<br>Reserved | 241 | F1 | | | · C10 | : ; | 242 | F2 | | | B10 | ? / | 243 | F3 | | | 210 | Reserved | 244 | F4 | | | E12 | + = | 245 | F5 | | | D12 | } ] | 246 | F6 | | | C12 | , , | 247 | F7 | | | | Reserved | 248 | F8 | | | Ell | . • | 249 | F9 | | • | Dll | = [ | 250 | FA | | | Cll | , , | 251 | FB | | | | Reserved | 252-255 | FC-FF | Table B-3 Keycode Translation Table (Sheet 5 of 5) #### NOTES: - \* The legends under Keycap are taken from the keycap legends of the LK201-AA (U.S.A.). - \*\* Keycodes 000 through 064 are reserved. Keycodes 065 through 085 are unused. are unuseu. ### B.5.2 Modes This section describes the function of the keycode transmission modes. The Mode Set command allows any one of the 14 keyboard divisions to be set to any one of the following three modes. (Division defaults are described in subsequent paragraphs.) - Down Only Mode The keyboard transmits a keycode when the key is pressed. - 2. Auto-Repeat Down The keyboard transmits a keycode when the key is first pressed. If the key is held down past the specified timeout period (usually 300 to 500 ms), a fixed metronome code is sent at the specified rate until the key is released. - The keyboard transmits a keycode when the key is pressed and an up code when the key is released. If any other down/up keys are pressed, the up code is a repeat of the down code. If no other down/up keys are pressed, the keyboard sends an ALL UPS code. B.5.2.1 Special Considerations Regarding Auto-Repeat The Auto-Repeat Rate Set command allows the following changes in the auto-repeat mode: - 1. The auto-repeat rate buffer association can be changed for the selected keyboard division. - The timeout and interval values can be changed in any one of the four auto-repeat rate buffers. - 3. If multiple auto-repeating keys are held down, metronome codes are still generated. The metronome codes apply to the keycode transmitted most recently. If the last key pressed down is released, and another key is still down, the keycode of the key still down is retransmitted. Example: The A key is held down. This produces the following transmission: A metronome metronome Now the B key is pressed. This produces the following transmission: A metronome metronome B metronome metronome Now the B key is released. This produces the following transmission: A metronome metronome B metronome metronome A metronome met..... While metronome codes are being generated for an auto-repeating key, a nonauto-repeating keycode or special code may be transmitted. The keyboard transmits this special code instead of the next metronome code and then returns to the auto-repeated code. The keycode to be auto-repeated is always the last byte transmitted. Example: The A key is held down. This produces the following transmission: A metronome metronome Now the SHIFT key is pressed. This produces the following transmission: A metronome metronome shift A metronome Now the SHIFT key is released. This produces the following transmission: A metronome metronome shift A metronome ALL UPS A metronome met..... - 4. If an auto-repeating key is not to auto-repeat (for example, Ctrl C), the system module must issue a Temporary Inhibit Auto-Repeat command. This halts the transmission of any metronome codes or keyclicks for that key only. Metronome codes continue when another key is pressed. The command must be issued after the keycode for the auto-repeating key is received. - 5. Auto-repeat can be enabled and disabled independently of the division settings by using the Enable/Disable Auto-Repeat commands. These commands apply to all keys on the keyboard. When auto-repeat is disabled, internally the keyboard continues to auto-repeat characters. However, it does not transmit metronome codes or keyclicks. When auto-repeat is enabled, the keyboard transmits the metronome codes from the point where they were before auto-repeat was disabled. This may be within either the timeout or interval period, depending upon the time elapsed since the key was pressed. - 6. If the keyboard receives a request to change a division mode to auto-repeat while a key is being pressed, the keyboard makes the change immediately. After the specified timeout period, the keyboard transmits metronome codes for the pressed key. In place of the first metronome code, the keyboard transmits the keycode of the auto-repeating key. All auto-repeating division modes can be changed to down only with one command. This and other auto-repeat commands are grouped with the peripheral commands. ## B.5.2.2 Special Considerations Regarding Down/Up Mode If two down/up keys are released simultaneously (within the same scan), and there are no other down/up keys down on the keyboard, only one ALL UPS code is generated. # B.5.2.3 Auto-Repeat Rates There are four buffers in the keyboard to store auto-repeat rates. They are numbered 0 through 3. Each buffer stores the following two values. These values can be changed by the system module. - 1. The timeout value - 2. The interval value Timeout is the amount of time that the keyboard waits before starting to auto-repeat a character. The timeout value is the amount of time between the detection of a down key and the transmission of the first metronome code (defaults range from 300 to 500 ms). The rate of auto-repeating a character is called the interval. The interval value is the number of metronome codes per second (defaults to 30). Each division is associated with one of the four buffers. Rates are taken from the associated buffer each time the auto-repeat timers are loaded. This buffer-to-division association can be changed by the system module or left to default. ## B.5.3 Keyboard Peripherals This section describes the peripherals available on the keyboard. The keyclick, bell, and LEDs are all considered keyboard peripherals. ## B.5.3.1 Audio The keyclick is a 2 ms beep and the bell is a 125 ms beep. The bell is sounded only upon request from the system module. The keyclick (if not disabled by the system module) is sounded under the following three conditions: - 1. When a key is pressed - 2. When a metronome code is sent - 3. When the system module receives a sound keyclick command If either the B11 or B99 keys (the left and right SHIFT keys on the LK201) or the C99 key (the Ctrl key on the LK201) are pressed, the keyclick is not generated. However, if a command is sent from the system module to enable the keyclick on the C99 key, the keyclick is generated. Figure B-6 shows the positions of these keys. The keyclick or bell (or both) may be disabled and will not sound. If the system module requests sound (see Peripheral Commands, the keyclick or the bell does not sound. Both the keyclick and bell may be set independently to one of the following eight volume levels: 000 -- highest 001 010 -- default 011 100 101 110 lll -- lowest ## B.5.3.2 Indicators (LEDs) The system module normally transmits indicator control commands. However, the following are exceptions: - 1. Upon power-up, the keyboard turns all LEDs off. - After receiving the Inhibit Transmission command, the keyboard turns on the LOCK LED. The LED is turned off after the keyboard receives a Resume Transmission command. ## B.5.4 Keyboard·to·System Module Protocol The following paragraphs describe the keyboard-to-system module protocol. ## B.5.4.1 Keycode Transmission The keyboard transmits single byte keycodes that reflect the keyboard matrix status. The 8-bit codes above 64 (decimal) are used for keycodes. Every key is identified by a unique keycode. There are no special codes for shifted or control keys. Refer to Figure B-6 and Tables B-1 and B-2 for the complete keycode matrix translation table. # B.5.4.2 Special Code Transmission There are 13 special codes: nine codes with values above 64 (decimal) and four codes below. Table B-4 lists the nine special codes above 64 (decimal) keycode value range: Table B-4 Special Codes Above 64 Decimal | | Keycode | | | | |---------------------|-----------|---------------|--|--| | Special Codes | (Decimal) | (Hexadecimal) | | | | | | | | | | ALL UPS | 179 | в3 | | | | METRONOME CODE | 180 | B4 | | | | OUTPUT ERROR | 181 | B5 | | | | INPUT ERROR | 182 | В6 | | | | KBD LOCKED ACK | 183 | в7 | | | | TEST MODE ACK | 184 | В8 | | | | PREFIX TO KEYS DOWN | 185 | В9 | | | | MODE CHANGE ACK | 186 | BA | | | | RESERVED | 127 | 7 <b>F</b> | | | The special codes in Table B-4 are explained below: ALL UPS -- Indicates to the system module that a down/up mode key was just released and no other down/up keys are being pressed. METRONOME CODE -- Indicates to the system module that an interval has passed, a keyclick has been generated, and the last key received by the system module is still being pressed. OUTPUT ERROR -- Indicates an output buffer overflow to the system module. The overflow occurred after receiving a Keyboard Inhibit command from the system module and some keystrokes may be lost. INPUT ERROR CODE -- Indicates to the system module that the keyboard received a meaningless command, too many, or too few parameters. KEYBOARD LOCKED ACKNOWLEDGE -- Indicates to the system module that the keyboard received an Inhibit Transmission command. TEST MODE ACKNOWLEDGE -- Indicates that the keyboard has entered test mode. This is a special mode used during the production test. If the system module receives this acknowledge, it sends 80 hexadecimal. This terminates the test mode and jumps to power-up. PREFIX TO KEYS DOWN -- Indicates that the next byte is a keycode for a key already down in a division which has been changed to down/up. MODE CHANGE ACKNOWLEDGE -- Indicates that the keyboard has received and processed a Mode Change command. RESERVED -- Keycode 7F is reserved for internal use. Table B-5 lists the four special codes below 64 (decimal) value range. Table B-5 Special Codes Below 64 Decimal | | Key | code | |---------------------------------|-----------|---------------| | Special Codes | (Decimal) | (Hexadecimal) | | KEYBOARD ID FIRMWARE | 01 | 01 | | KEYBOARD ID HARDWARE | 00 | 00 | | KEY DOWN ON POWER-UP ERROR CODE | 61 | 3D | | POWER-UP SELFTEST ERROR CODE | 62 | 3E | In explanation of the special codes in Table B-5: KEYBOARD ID -- This is a two byte identification code, transmitted after the power-up selftest (Power-Up Transmission. It is also sent on request from the system module. KEY DOWN ON POWER-UP ERROR CODE -- Indicates that a key was pressed on power-up. POWER-UP SELFTEST ERROR CODE -- Indicates to the system module that the ROM or RAM selftest of the system module failed. ## B.5.4.3 Power-Up Transmission Upon power-up, the keyboard performs a selftest in less than 70 ms. It transmits the selftest results to the system module in 4 bytes. - Byte 1: KBID (firmware) -- This is the keyboard identification (ID) that is stored in the firmware. - Byte 2: KBID (hardware) -- This is the keyboard ID that is read from hardware jumpers. - Byte 3: ERROR -- Two error codes indicate either failure of the ROM or RAM self-test within the processor (3E hexadecimal), or keydown on power-up (3D hexadecimal). No error is indicated by 00. - Byte 4: KEYCODE -- This byte contains the first keycode detected if there was a key down on power-up. No error is indicated by 00. If the ROM selftest (CHECKSUM) fails and the error is fatal, the keyboard is unable to transmit. Nonfatal errors permit the keyboard to continue operation. If the keyboard finds a key down on the first scan, it continues to look for an ALL UP condition. The keyboard sends the corrected 4-byte power-up sequence when the depressed key is released. This avoids a fatal error condition if a key is pressed by mistake while powering up. The keyboard LEDs are lit during the power-up selftest. If the selftest is passed, the keyboard turns the LEDs off. If a bell is selected on power-up, the system module can transmit a Sound Bell command to the keyboard. However, this should not be done until the system module receives the last byte of the 4-byte sequence. The request for selftest tests the serial line and system module connection. The power-up selftest takes 70 ms or less. The system module can request a jump to power-up at any time. This causes the LEDs on the keyboard to blink on and off (for the power-up selftest). ## B.5.5 System Module to Keyboard Protocol The system module controls both the peripherals associated with the keyboard and the keyboard transmit characteristics. Figure B-10 shows the protocol for the transmission of commands and parameters from the system module to the keyboard. Figure B-10 System Module To Keyboard Protocol # B.5.5.1 Commands Table B-6 lists the two kinds of commands: those that control keyboard transmission characteristics and those that control keyboard peripherals. The low bit of the command is the TYPE flag. It is clear if the command is a transmission command. It is set, if the command is a peripheral command. Table B-6 Command Types | Transmission Commands | Peripheral Commands | |-----------------------|--------------------------| | Mode Set | Flow Control | | Auto-Repeat Rate Set | Indicator | | • | Audio | | | Keyboard ID | | | Reinitiate Keyboard | | | Some Auto-Repeat Control | | | Jump to Test Mode | | | Reinstate Defaults | The high order bit of every command is the PARAMS flag. If there are any parameters to follow, this flag is clear. If there are no parameters, this flag is set. ### B.5.5.2 Parameters The high order bit of every parameter the PARAMS flag. It is clear if there are parameters to follow. It is set on the last parameter. The remaining seven bits of the parameter are for data. ## B.5.5.3 Peripheral Commands Two commands can turn the data flow from the keyboard off and on: - Inhibit Keyboard Transmission -- This command shuts off or locks the keyboard and turns on the LOCK LED. After receiving the Inhibit command, the keyboard sends a special command to the system central processor. If the system central processor receives this code without requesting it, this indicates that noise on the line was interpreted as the Inhibit command. The central processor then responds immediately with the Resume Keyboard Transmission command. - 2. Resume Keyboard Transmission -- This command turns on or unlocks the keyboard and turns off the LOCK LED. If any keystrokes are lost, the keyboard responds with an error code. Each keyboard LED can be turned on and off. The following are the eight commands that control the keyclick and bell sounds: - 1. Disable Keyclick - 2. Enable Keyclick and Set Volume - 3. Disable Ctrl Keyclick - 4. Enable Ctrl Keyclick - 5. Sound Keyclick - 6. Disable Bell - 7. Enable Bell and Set Volume - 8. Sound Bell The following four commands are related to the control of the auto-repeat mode: - Temporary Auto-Repeat Inhibit -- Auto-repeat is stopped for a specific key only. It resumes automatically when another key is pressed. - 2. Enable Auto-Repeat Across the Board -- Starts transmission of metronome codes without affecting auto-repeat timing or keyboard division. - 3. Disable Auto-Repeat Across the Board -- Stops transmission of metronome codes without affecting auto-repeat timing or keyboard division. - Change All Auto-Repeat to Down Only -- Changes all keyboard auto-repeating divisions to down only mode. The following are three other miscellaneous commands: - 1. Request Keyboard ID -- The keyboard sends the two-byte ID (firmware and hardware). The keyboard does not jump to the power-up sequence. - Reinitiate Keyboard -- The keyboard jumps to the power-up sequence. Transmission to the keyboard should be held until the host processor receives the last byte of the power-up selftest. - 3. Reinstate Defaults -- Sets the following functions back to the default settings after a successful completion of the power-up selftest: Division mode settings Auto-repeat interval and timeout rates Auto-repeat buffer selections Audio volume # Ctrl key keyclick To send a peripheral command, set the TYPE flag (low order bit). Bits 6-3 contain a command representation from the chart below. Bits 2 and 1 specify on (01), off (00), or sound (11). Bit 7 should be set if there are no parameters to follow. Table B-7 lists the peripheral commands (in hexadecimal) and Table B-8 indicates the representation for each command function. Table B-7 Peripheral Commands in Hexadecimal | Function | Hexadecimal | Parameters | |-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------| | FLOW CONTROL | | | | Resume Keyboard Transmission<br>Inhibit Keyboard Transmission | 8B<br>89 | None<br>None | | INDICATORS | | | | Light LEDs<br>Turn Off LEDs | 13<br>11 | Bit pattern<br>Bit pattern | | AUDIO | | | | Disable Keyclick Enable Click, Set Volume Disable Ctrl Keyclick Enable Ctrl Keyclick Sound Keyclick Disable Bell Enable Bell, Set Volume Sound Bell | 99<br>1B<br>B9<br>BB<br>9F<br>A1<br>23<br>A7 | None Volume None None None Volume None | | AUTO-REPEAT | | | | Temporary Auto-Repeat Inhibit<br>Enable Auto-Repeat Across Keyboard<br>Disable Auto-Repeat Across Keyboard<br>Change All Auto-Repeat to Down Only | C1<br>E3<br>E1<br>D9 | None<br>None<br>None | | OTHER | | | | Request Keyboard ID Jump to Power-Up Jump to Test Mode Reinstate Defaults | AB<br>FD<br>CB<br>D3 | None<br>None<br>None<br>None | | Enable 401 Mode | £9 | •••••• | Table B-8 Command Function Representation | Command | Representation | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------| | Flow Control Indicator (LEDs) Keyclick Bell Keyboard ID Keyclick for Ctrl Key Temporarily Inhibit Auto-Repeat Jump to Test Mode Change All Auto-Repeat Characters to Down Only Enable/Disable Auto-Repeat | 0001<br>0010<br>0011<br>0100<br>0101<br>0111<br>1000<br>1001 | | | | The Jump to Power-Up command is FD hexadecimal. The following are some of the peripheral commands: - Flow Control -- The system module can lock the keyboard with the Inhibit Keyboard Transmission command. When the keyboard is unlocked, it responds with an error code if any keystrokes were missed. - 2. Indicators (LEDs) -- Figure B-ll shows the LED parameter. Figure B-l2 shows the LED layout on the LK201 keyboard without the label strip installed. - 3. Audio -- Figure B-13 shows the audio volume parameter. | 07 | 06 | 05 | 04 | <u> </u> | 02 | 01 | .00 | |----|----|----|----|----------|----------|----------|----------| | 7 | 0 | 0 | 0 | LED<br>4 | LED<br>3 | S<br>LED | LED<br>1 | | | | | | | | | MR-1999 | Figure B-ll Indicator (LED) Parameter O O O O LED4 LED3 LED2 LED1 Figure B-12 Indicator (LED) Layout Figure B-13 Audio Volume Parameter The volume levels for the audio are as follows: 000 -- highest 001 010 011 100 101 110 111 -- lowest The keyclick or the bell (or both) can be disabled. When the keyclick or bell is disabled, it does not sound, even if the system module requests it. The following are additional peripheral commands: - Temporary Auto-Repeat Inhibit -- Stops auto-repeat for this key only. Auto-repeat automatically continues when another key is pressed. - Disable/Enable Auto-Repeat Across Keyboard --Stops/starts transmission of metronome codes without affecting auto-repeat timing or division settings. - Change All Auto-Repeat to Down Only -- Changes division settings for all auto-repeating divisions to down only. - 4. Request Keyboard ID -- Keyboard sends a 2-byte keyboard ID. Keyboard does not jump to power-up. - 5. Reinitiate Keyboard -- Keyboard jumps to its power-up routine. The system module should not try to transmit anything to the keyboard until the last byte of the power-up sequence is received. - 6. Jump to Test Mode -- Special test mode for manufacturing testing. - 7. Reinstate Defaults -- Set the following functions back to the default settings after a successful completion of the power-up selftest: Division mode settings Auto-repeat interval and timeout rates Auto-repeat buffer selections Audio volume Ctrl key keyclick # B.5.5.4 Mode Set Commands The following describe the Mode Set commands: - 1. Division mode settings -- Refer to subsection on "Modes". - Each division on the keyboard has a unique 4-bit representation. Table B-2 describes these representations. - 3. Each mode has a unique 2-bit code as indicated in Table B-9. Table B-9 Mode Representation | Modes | Representation | |------------------------------------|----------------| | Down only Auto-repeat down Down/up | 00<br>01<br>11 | | | | To set the key transmission mode on a particular keyboard division, the system module must send the PARAMS flag, then the keyboard division representation with the mode code, and then followed by the TYPE flag (cleared). Example: Set main array to down/up (see Figure B-14). Figure B-14 Setting Key Transmission Mode The PARAMS flag is set to 1 if there are no parameters. The PARAMS flag is clear if there are parameters. Auto-repeat rate buffer association -- If the auto-repeat mode is selected, the system module can transmit a parameter to change the buffer association of the selected division. Example: Set main array to auto-repeat, change buffer association to buffer 3 (see Figure B-15). Figure B-15 Setting Auto-Repeat Rate Buffer Association Auto-repeat rate buffer values -- At keyboard power-up time, the four auto-repeat rate buffers contain default values. The system module may change these values. In the command byte, bit 7 (PARAMS flag) should be clear, bits 6--3 are 1111 (to indicate that this is a Rate Set command), bits 2 and 1 should be the buffer number (0 to 3), bit 0 (TYPE flag) is clear. There should be two parameters carrying the rate set data. Example: Change rates in buffer 3 (see Figure B-16). | | RAN | <b>-</b> | | CHANG<br>MAND | E | BUF | | TYPE | |----------|-----|----------|----|---------------|---------|--------|------|---------| | | 07 | 06 | 05 | 04 | 04 03 | | 01 | 00 | | | 0 | 1 | , | , | , | 1 | 1 | 0 | | | 0 | | 74 | RAME | TER 1 ( | TIMEOL | Л | | | | 1 | | 7/ | RAME | TER 2 ( | INTER | /AL) | | | <b>.</b> | | I | | - | , | | | MA-1000 | Figure B-16 Setting Auto-Repeat Rate Buffer Values The first parameter specifies the timeout to the store in the selected buffer. The second parameter specifies the interval. For example, to set the auto-repeat rate in buffer 1, the system module firmware transmits 00000011 followed by two bytes of numeric parameters. The auto-repeat timeout is the transmitted number times 5 ms. To specify a rate of 5 ms delay, the first parameter received is 00000001. The maximum allowable time is 630 ms (01111110). The system module must not send 635 (01111111). NOTE The code (01111111) is reserved for internal keyboard use. 00 is an illegal value. Auto-repeat timeout is implemented as a multiple of 8.33 ms, the keyboard's internal scan rate. Timeout rates can vary + 4.15 ms. The auto-repeat interval is the number of metronome codes per second. In order to specify a speed of 16 Hz, the second parameter received is 10010000. Note that the high order bit is set because it is the last parameter. The highest value that may be sent is 124 (11111100). The lowest rate that can be implemented by the keyboard is $12~{\rm Hz}$ . Values as low as 1 can be transmitted, but are translated to $12~{\rm Hz}$ . NOTE The system module must not send 125 -- or 11111101. This code is the Power-Up command. # B.5.6 Special Considerations The following paragraphs describe the special codes and their considerations. ### B.5.6.1 Error Handling There are four error codes. The first two are sent at power-up, if the selftest fails. The other two codes are the INPUT ERROR code and the OUTPUT ERROR code. The OUTPUT ERROR (B5 hexadecimal) is sent after the keyboard receives a Resume Transmission command, if the output buffer overflowed while the keyboard was locked. The INPUT ERROR (B6 hexadecimal) is sent when the keyboard detects noise (unidentified command or parameter) on the line. B6 is also sent if the keyboard detects a delay of more than 100 ms when expecting a parameter. # B.5.6.2 Keyboard Locked Condition When the keyboard receives an Inhibit Transmission command, it lights the LOCK LED and transmits one more byte. This is a special code indicating that the keyboard is locked (KEYBOARD LOCKED ACKNOWLEDGE). If the system module receives this code without a request, it indicates that noise on the line was interpreted as an Inhibit Transmission command. The system module should immediately send the Resume Transmission command to unlock the keyboard. The output first in first out (FIFO) buffer in RAM is four bytes. When the keyboard is locked, it attempts to store characters received from the keyboard. The keyboard stops scanning its matrix. When the keyboard is unlocked by the system module, it transmits all four bytes in the output buffer. If any keystrokes have been missed due to buffer overflow, the keyboard transmits an error code as the fifth byte (OUTPUT ERROR). Any keys that were not transmitted and are being held down when the keyboard is unlocked are processed as new keys. An error code upon unlocking the keyboard indicates a possible loss of keystrokes to the system module. The keyboard stops scanning its matrix when its buffer is full. However, it processes all incoming commands. ## B.5.6.3 Reserved Code The number 7F (hexadecimal) is reserved for the internal keyboard input and output buffers handling routines. #### B.5.6.4 Test Mode The keyboard jumps into a test mode by command during production test. It transmits a special code to the system module to confirm the test mode. If the system module receives this code, it should send the byte 80 (hexadecimal) to continue. This causes a jump to power-up. ## B.5.6.5 Future Expansion Some keycodes are reserved for future use as special codes or keycodes. ## B.5.7 Default Conditions - 1. Certain keyboard divisions have specific default modes. Some divisions default to the auto-repeat mode; therefore, they have an associated buffer that contains the default values for timeout and interval. Table B-10 shows the default modes and Table B-11 shows the default rates in the four keyboard division auto-repeat rate buffers. - The volume level for the keyclick and bell has an eight step range. The default volume level for the keyclick and bell is the third loudest. Both keyclick and bell volumes are 2 decimal (010 binary) by default. The key in position C99 of the keyboard (the Ctrl key in the LK201) does not generate a click unless enabled by the system module. The keys in position B99 and B11 (SHIFT keys on the LK201) never generate a keyclick. - 3. For the LK201 keyboard, the Ctrl key defaults to the no keyclick state. Table B-10 Keyboard Division Default Modes | Keyboard Division | Mode | AR Buffer | |---------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------| | Main array Keypad Delete Cursor keys Return and Tab Lock and Compose Shift and Control Six basic editing keys | Auto-repeat Auto-repeat Auto-repeat Auto-repeat Down only Down only Down/up Down/up | 0<br>0<br>1<br>1 | Table B-ll Default Rates in Auto-Repeat Buffers | Buffer<br>Number | Timeout (ms) | Internal (Hz) | |------------------|--------------|---------------| | 0 | 500 | 30 | | 1 | 300 | 30 | | 2 | 500 | 40 | | 3 | 300 | 40 | # B.6 SPECIFICATIONS # FUNCTIONAL | Electronics | 8-bit microprocessor, 4K bytes of ROM, 256 bytes of RAM, 4 LEDs, transducer | |---------------------|-----------------------------------------------------------------------------------------------------------------| | Cord | <pre>1.9 m (6 ft), coiled, 4-pin telephone-type modular connectors, plugs into display monitor (PN BCC01)</pre> | | Keypad | Sculptured key array | | Home row key height | 3 cm (1.2 in) above desk top | | Keys | 105 matte, textured-finish keys | | Main keypad | 57 keys | | Numeric keypad | 18 keys | | Special | function | keypad | 20 | keys; | firmware | and | software | driven | |---------|----------|--------|----|-------|----------|-----|----------|--------| |---------|----------|--------|----|-------|----------|-----|----------|--------| Editing keypad 10 keys Spacing 1.9 cm (0.75 in) center-to-center (single-width keys) Wobble Less than 0.5 cm (0.020 in) Diagnostics Power-up selftest, generates identification upon passing test #### PHYSICAL Height 5 cm (2.0 in) at highest point Length 53.3 cm (21 in) Width 17.1 cm (6.75 in) Weight 2 kg (4.5 lb) #### **B.7** CHARACTER SETS ## B.7.1 Description The MicroVAX workstation recognizes all of the 8-bit character codes of the DEC Multinational Character Set shown in Figure B-17. It also recognizes the Special Graphics Character Set shown in Figure B-18 when it is preceded by a Select Character Set (SCS) sequence which are described in subsequent paragraphs. Using the DEC Multinational Character Set allows the MicroVAX workstation to process character codes from the keyboards listed in Table B-12. Table B-12 Multinational Character Set Keyboards | Keyboard | Part Number | Keyboard | Part Number | |--------------------|-------------|----------------|-------------| | American (English) | LK201AA | Finnish | LK201AF | | Austrian/German | LK201AG | Italian | LK201AI | | Belgian/Flemish | LK201AB | Norwegian | LK201AN | | Belgian/French | LK201AP | Spanish | LK201AS | | British | LK201AE | Swedish | LK201AM | | Canadian (French) | LK201AC | Swiss (French) | LK201AK | | Danish | LK201AD | Swiss (German) | LK201AL | | Dutch | LK201AH | | | Each of the 15 keyboards supported is used with corresponding language ROMs that are inserted into the system module depending on the keyboard in use. The language ROMs translate keyboard position codes into the required character codes necessary for further processing. The MicroVAX workstation processes 7-bit character codes as though they were 8-bit character codes with the eighth bit not set. Each character set consists of displayable or graphic characters, and nondisplayable or control characters. In 7-bit coded character sets, control characters are contained in columns 0 and 1, and in position 7/15, while graphic characters are contained in the remaining positions of columns 2 through 7. In 8-bit coded character sets, control characters are contained in columns 0, 1, 8, and 9 and in positions 7/15 and 15/15, while graphic characters are contained in the remaining positions of columns 2 through 7, and 10 through 15. In all character sets, the control characters in columns 0 and 1, and position 7/15 are designated as belonging to the control character group CO. The graphic characters in the remaining positions of columns 2 through 7 are designated as belonging to the graphics left character group GL. The control characters in columns 8 and 9, and position 15/15 are designated as belonging to the control character group Cl. The graphic characters in the remaining positions of columns 10 through 15 are designated as belonging to the graphics right character group GR. Figure B-19 illustrates how the character sets are designated and used in the MicroVAX workstation. | 00.U= | | 0 | 1 | 2 | 3 | 4 | 5 | • | 7 | • | • | 18 | 11 | 12 | 13 | 14 | 15 | |---------|-----|--------------------------|-------------|-----------|-----|----|--------|-------|----------|------|-------------------|-------|-----|-----|-----------------------------|-----|---------| | " | | | ••• | •, | •,, | ٠. | • • . | • , , | • , , | '•• | , <u>.</u> | • | • • | •• | ' <b>, ,</b> | • | , | | | *** | | | | | | | | | | | | | | . ' | | | | • • • • | 0 | NUL | DLE | <b>SP</b> | 0 | • | P | • | • | | DCS | | • | À | | 3 | | | •••• | 1 | SOH | DC1 | 1 | 1 | A | a | | • | | PU1 | ě | ±. | Ä | Ñ | 8 | • | | •••• | 2 | STX | <b>DC3</b> | ** | 2 | | R | • | • | | PU2 | • | 2 | 1 | δ | 1 | 3 | | • • • • | 3 | ETX | DC3 | | 3 | С | 8 | c | | | STS | 2 | 3 | Ā | 6 | • | . 8 | | • • • • | 4 | EOT | DC4 | \$ | 4 | D | T | đ | 1 | IND | ССН | | | Ä | 8 | ä | 8 | | • 1 • 1 | 5 | ENQ | NAK | * | 8 | E | U | • | • | NEL | MM | ¥ | μ | À | 5 | à | 5 | | • • • • | • | ACK | SYN | ٨ | • | F | ٧ | • | ٠ | SSA | SPA | | 1 | Æ | ö | • | *;<br>6 | | • , , , | 7 | BEL | ETB | • | 7 | G | w | • | • | ESA | EPA | 5 | ٠ | ç | Œ | ę | • | | | • | 28 | CAN | ( | • | # | x | h | . * | нтѕ | | × | | ş | • | 3 | • | | •••• | • | HT | EM | , | • | 1 | ٧ | • | , | HTJ | | 6 | 1 | É | ù | 8 | 3 | | •••• | 10 | LF | SUB | • | : | ٠ | Z | 1 | 2 | VTS | | • | • | Ê | ú | ٨ | : | | , • • • | 11 | VŤ | ESC | ٠ | ; | K | [ | * | { | PLD | CSI | < | > | Ë | û | ¥ | ۵ | | | 12 | FF | FS | | < | L | `\ | 1 | <u> </u> | PLU | ऽर | | * | ; | ü | ; | ï | | 11.01 | 13 | CR | Ø | • | | • | 3 | | } | RI | osc | | 1/3 | í | Ÿ | 1 | ÿ | | • • • | 14 | 80 | RS | · | > | N | ^ | n | ~ | \$52 | PM | | | î | | : | 2 | | | 15 | \$1 | US | / | ? | 0 | _ | • | DEL | 223 | APC | | ' | ï | 3 | ï | | | | | ASI<br>CONT<br>SE<br>(C) | <b>Q</b> OL | | | | | | | CON | D'L<br>TROL<br>ET | | DE | GR/ | LEMEN<br>VPHIC<br>ET<br>(R) | TAL | | | | | • | | | | DI | EC MUL | TINAT | IONAL | CHAR | ACTER | SET - | | | | | • | | | • | | | | | | | | | | | | | | | | | MR-10132 Figure B-17 DEC Multinational Character Set | | COLUMN | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-----|---------|---------|---------------------|------------------|-----------------|-------------|-------------------|---------------------------|---------------------------| | now | M BITS | | • • • • | ٠,, | ٠, , | ۰, | •, | ° , | 0, | | 0 | | NUL : | 20<br>16<br>10 | SP 20 | 0 4 | € 100<br>40 | P 80 | 1 140 | - M60<br>112<br>SCAN 3 70 | | 1 | 1 | ; | DC1 27 | 1 20 | 1 61 | A 96<br>41 | Q 81 51 | 141<br>97<br>81 | - 161<br>113<br>SCAN 5 71 | | 2 | 2100 | 2 2 2 | 22<br>16<br>12 | " #<br># | 2 50 30 | B 42 | R 60 | 1 147 | - 862<br>114<br>SCAN 7 72 | | 3 | 0 0 1 1 | ETX 3 | DC3 15<br>(XOFF) 13 | # 3<br>2 | 3 51<br>32 | C 87 | S 23 | \$ 143<br>*** | _ 163<br>115<br>SCAN 9 73 | | 4 | 0100 | EOT : | X X X | 8 2 | 4 52<br>34 | D 104 | T 324 | 1 2 | + 184<br>116<br>24 | | 5 | 0161 | ENQ | 25<br>21<br>16 | % 57<br>25 | 5 Si 35 | E 106 | U = | 145<br>201<br>85 | 1 165<br>117<br>75 | | 6 | | : | 2<br>16 | å # | 6 H | F 70 | V % | 8 146<br>102<br>86 | 1 106<br>116<br>76 | | 7 | 0 1 1 1 | BEL ; | 27 22 17 | 9 47<br>39<br>27 | 7 %<br>35 | G 71 | W 87 | ± 147<br>160<br>67 | T 167<br>119<br>77 | | • | 1 0 0 0 | BS | CAN % | ( 60 | 8 16 | H 72 | X === | 1 150<br>104<br>82 | 170<br>120<br>76 | | 9 | 1 0 0 1 | HT : | 31<br>25<br>15 | ) 60 | 9 57<br>30 | 1 73 | Y 31 | 151<br>105<br>00 | \$ 171<br>121<br>79 | | 10 | 1010 | LF 12 | SUB = | # 42<br>24 | ; 56<br>34 | J 112 | Z = 122 | J 152<br>166<br>6A | ) 172<br>122<br>3A | | 11 | 1 0 1 1 | VT : | ESC 77 | + 0 | ; 30 | K 75 | [ 91 | 7 153<br>107<br>68 | 173<br>123<br>78 | | 12 | 1100 | FF 12 C | 34<br>38<br>10 | , su | < % | L 714 | ) 134<br>82<br>80 | Γ 164<br>108<br>6C | \$ 134<br>134<br>70 | | 13 | 11 0 1 | CR 15 | 35<br>39<br>10 | - 46<br>20 | 25 St. 30 | M 77<br>40 | ] 136<br>80 | 1 185<br>100<br>60 | 175<br>125<br>70 | | 14 | 1110 | 80 4 | 36<br>30<br>16 | . # | > %<br>82<br>36 | N 76 | A 136 | † 186<br>110<br>66 | · 176<br>· 126<br>76 | | 15 | 1111 | .SI 17 | 37<br>31<br>1F | / 57<br>47<br>27 | ? 63 | 0 70 | 137<br>66<br>57 | - 157<br>111<br>SCAN 1 SF | 177<br>127<br>36 | MR-1912 Figure B-18 Special Graphics Character Set Figure B-19 Character Set Designations ### **B.8 CHARACTER SET SELECTION** A GL character set is selected by using Select Character Set (SCS) sequences. SCS sequences are used to designate two GL Character Sets as fully active and two GL character sets as partially active. The two fully active GL character sets, once designated, are selected with a Shift In or Shift Out control character. Once a fully active GL character set is selected, all subsequent characters are assumed as belonging to that GL character set until an SCS sequence is again detected. The two partially active GL character sets are selected with an escape N or escape O control character. Once a partially active GL character set is selected, only the following character is assumed as belonging to that GL character set. All subsequent characters are assumed as belonging to the previously selected, fully active GL character set. If the MicroVAX workstation firmware does not detect an SCS sequence, it assumes that all characters belong to the default GL character set. The default GL character set is assigned or determined by the value of the twelfth bit that appears on the screen in the Set-Up mode under Parameter Settings (PARAM SET). If this bit is 1, the default character set is UK; if it is 0, the default character set is USASCII. The SCS sequences and their octal equivalents for selecting the fully active GL character sets (G0 and G1) and the partially active GL character sets (G2 and G3) are listed in Figure B-20 Note that both the G2 and G3 designated GL character sets will always be the default character set determined in the Set-Up mode under Parameter Settings (PARAM SET). | | SCS SEQUENCE (NUMBERS IN SEQUENCE ARE IN OCTAL) | | | | | | | | | | | | | |---------------------|-------------------------------------------------|------------------------|--------------------------------------------------------|--------------------------------------------------------|--|--|--|--|--|--|--|--|--| | CHARACTER<br>SET | <b>c</b> 0 | G1 | G2 | <b>G</b> 3 | | | | | | | | | | | UK | ESC ( A<br>033 050 101 | ESC ) A<br>033 051 101 | ESC N<br>033 115<br>(IF UK SELECTED<br>IN SET-UP MODE) | ESC 0<br>033 117<br>(IF UK SELECTED<br>IN SET-UP MODE) | | | | | | | | | | | USASCII | ESC ( B<br>033 050 102 | ESC ) 8<br>033 051 102 | ESC N<br>033 115<br>(IF US SELECTED<br>IN SET-UP MODE) | ESC 0<br>033 117<br>(IF US SELECTED<br>IN SET-UP MODE) | | | | | | | | | | | SPECIAL<br>GRAPHICS | ESC ( 0<br>033 050 060 | ESC ) 0<br>033 051 060 | • | • | | | | | | | | | | NOTE: ALL NUMBERS ARE IN OCTAL Figure B-20 Character Set Selection ### B.9 DISPLAYING CHARACTERS All character codes are processed by the MicroVAX workstation firmware in the following order: - If no SCS sequences are detected, all character codes are assumed to belong to the default character set. - If an SCS sequence is detected, the character code is translated so that when it is input to the character generator ROM, it produces the proper character display. ### NOTE A translation between the character code received and the character code expected by the character generator ROM is necessary because, as shown in Figure B-21, the ROM mapping for graphic characters does not always agree with the character set mapping in Figures B-17 and B-18. 3. All character codes with the eighth bit set will be processed as belonging to the DEC Multinational GR Character Set. Figure B-22 illustrates the data paths in various modes. When character codes are input to the workstation application programs in the console mode, the applications software is responsible for transmitting the actual codes for each key that is pressed on the keyboard. That is, if the Escape key is pressed, the applications software must send the workstation firmware the character code for the Escape key (27 decimal, 33 octal, or 18 hexadecimal). The same thing applies to host processor software, when the workstation is in the line mode. In the local mode, keyboard outputs are transmitted directly to the translation process firmware. | | } | | | | | Γ. | | T - | | | | | | <del></del> | | | Υ | |----------|----|--------------|-------|-----|-----|----|----------|-----|-------|-----|------|-------------|-----|-------------|--------------|----|----| | COLUMN 1 | | <u> </u> | 1 | 2 | 3 | 4 | • | • | 7 | • | • | 10 | 11 | 12 | 13 | 14 | 15 | | | | ٠٠, | ••, | ١٠. | ٠., | ٠. | • | ٠, | • • • | ٠. | ٠., | <b>'•</b> , | • , | , · · · | ' • <u>,</u> | ٠, | | | **** | B | | | | | | | | | | | | | | | | | | •••• | ٥ | • | BEAN; | 87 | 0 | • | P | • | • | 0 | ٢ | | • | <b>λ</b> , | ٢ | 3 | ٢ | | •••• | • | • | EMI | ! | 1 - | A | 0 | 8 | q | ٢ | ٢ | 3 | ± | X. | 2 | \$ | T | | •••• | 2 | 1 | Em? | * | 2 | | Á | b | • | 5 | ٢. | • | 2 | * | ձ | ٨ | 3 | | •••• | 3 | ş | Em. | | 3 | С | 8 | e | • | ٢ | ٢ | £ | 3 | Ā | δ | 7 | 8 | | • • • • | 4 | í | ł | 8 | 4 | D | T | đ | ŧ | ٢ | ٢ | ٢ | ٢ | Ä | 8 | ä | 8 | | • • • • | • | 1 | 1 | 8 | 5 | £. | U | • | • | 7 | ٢ | * | μ | Ä | 10 | å | 5 | | • • • • | 8 | • | 1 | ٨ | • | F | ٧ | 1 | ٠ | 5 | ٢ | ٢ | T | R | ; | • | ë | | • • • • | 7 | ± | τ | • | 7, | G | w | • | • | 7 | ٢ | • | • | ç | Œ | • | • | | | 8 | 1 | - | ľ | • | H | x | h | 2 | ٢ | ٢ | × | 5 | È | • | 3. | • | | | • | 1 | ٤ | ) | • | 1 | Y | ı | 7 | ٢ | ٢ | € | 1 | É | Ú | 8 | 3 | | | 10 | j | > | • | : | و | Ż. | j | 2 | ٢ | ٢ | 8 | 2 | Æ | ů, | 4 | 6 | | 1 . 1 | 11 | 1 | 1 | ٠ | ŧ | ĸ | 1 | k | { | ٠ ۾ | ٢ | « | > | Ę | û | ¥ | 4 | | ,,,, | 12 | r | # | | < | L | ` | 1 | 1 | ٢ | ٢ | ٢ | * | 1 | ij | 1 | ; | | 11 • 1 | 13 | L | £ | - | | M | 1 | 3 | } | ٢ | 5 | ٢ | % | í | Ÿ | í | ÿ | | | 14 | + | ٠ | | > | N | <b>A</b> | R | 1 | 5 | 7 | ٢ | 5 | t | 5 | t | 5 | | 1111 | 15 | SCAN 1 | ٢ | 1 | 7 | 0 | _ | • | DEL | ٢ | ٢ | 5 | è | î | 3 | ï | | | | * | SPEC<br>GRAP | | | | G | L | | | NOT | USED | | | G | A | | | NOTE: REVERSE QUESTION MARKS (1) ARE POSITIONS RESERVED FOR FUTURE STANDARDIZATION ani-1813 Figure B-21 Character Generator ROM Displayable Characters Figure B-22 Keyboard Output Processing #### APPENDIX C #### MOUSE SPECIFICATION #### C.1 GENERAL DESCRIPTION This appendix provides specifications defining a hand held 3-button circular mouse shown in Figure C-1. The mouse is a high performance, ergonomically designed "pointing device" used with a MicroVAX color graphics workstation and provides X -Y coordinate output data with a resolution of .005 inches for use in controlling various functions on a host computer (i.e. the cursor on a display screen). The mouse is held in the operator's hand and moved around on a flat surface resulting in corresponding direction and magnitude movement of the cursor on a video display screen. The mouse is used by sliding it around on a surface to position the cursor and then pressing one of the mouse buttons to make a desired selection. Figure C-l Three-Button Mouse The use of an ergonomically designed pointing device, such as a mouse can make software easier to learn and use. Pointing is often faster, easier, and more accurate than keyboard typing. Some advantages of using a mouse as a pointing device are: - o Very fast positioning - o High accuracy - o Non-fatiguing - o Small, lightweight, and inexpensive The DEC serial mouse uses opto-mechanical technology to detect movement with a resolution of 200 counts per inch. A dedicated microprocessor inside the mouse converts quadrature X-Y pulses to relative X-Y coordinates which are then transmitted as serial data to the host. A rubber coated ball on the underside of the mouse provides excellent tracking on most desktop surfaces. #### C.1.1 Switches The mouse has three switches located on the top of the unit which are operated by applying light pressure at the top forward corner of the switch cap. ### C.1.2 Signal/Power Cable A five foot, 5 conductor 26 AWG, shielded, round, uncoiled high flexibility cable is supplied. One end of the cable will connect directly to the mouse with strain relief, the other end will terminate with the specified connector. #### C.1.3 Connector The mouse will be supplied with a 7 pin micro-DIN type connector (male) attached to the cable. ## C.1.4 Connector Wiring The connector wiring pin assignments and functions are listed in Table C-1. | Table C-1 | Mouse | Connector | Pin | Assignments/Functions | |-----------|-------|-----------|-----|-----------------------| |-----------|-------|-----------|-----|-----------------------| | Pin No. | Function | |---------|-----------------------------------------| | 1 | GND (signal & power return) | | . 2 | TXD (serial out from mouse) | | 3 | RXD (serial in to mouse) | | 4 | -12v | | 5 | +5v | | 6 | not used | | 7 | Device Present (mouse grounds this line | | SHELL | Protective Ground | With the connector pins facing you, the pins are numbered according to the diagram shown in Figure C-2 with the male connector attached to the mouse cable. Figure C-2 Mouse Connector Pin Numbering #### C.2 INSTALLATION ## C.2.1 System Hookup The mouse is shipped fully assembled and ready to operate. To connect the mouse, plug the mouse cable into the Mouse/Tablet input jack of the computer or terminal on which it will be used. The Mouse/Tablet input jack is normally located on the rear panel of the video monitor. # C.2.2 Installing/Removing The Mouse Ball The rubber coated ball on the underside of the mouse can be removed for cleaning or replacement without special tools. To clean the ball, use water and if necessary, a mild soap. Do not use organic solvents such as toluene, as damage to the rubber coating will occur. | | 40 RIBBON | MOUSE | D34.3 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------------|-------| | To | BF1 - 4 | 2 | 5 | | | BALL - 2' | <b>4</b> . | 17 / | | The second secon | 10RN 8 | 3 | 18 | | 1<br>C-3 | W4+ 7 | 5 | 7 · | It is recommended that the ball be cleaned when the mouse fails to smoothly track the cursor on the screen. In an average office environment, cleaning the ball every six months should be sufficient. To remove the mouse ball, turn the mouse upside down to locate the ball housing cover and remove the cover by turning it clockwise as shown in Figure C-3. Figure C-3 Mouse Ball Removal ## C.3 MOUSE USAGE The mouse is normally used on a desktop area to the right or left of the keyboard and in view of the display screen. To operate the mouse, place your hand on the mouse with your fingers resting on the buttons and the cable leading away from you. Use your thumb and smallest finger to hold the mouse and move it around in contact with desktop. As you move the mouse, verify its movement by looking at the corresponding movement of the cursor on the display screen: left when you move the mouse left; right when you move the mouse right; up when you move the mouse away from you; and down when you move the mouse toward you. You should experiment to find the method of holding and moving the mouse that is most comfortable for you. The mouse buttons may be either pressed from the front or down from the top. Most users find it easiest to make small movements using their hand and wrist. Note also that you can pick up the mouse and reposition it at any time. The buttons on the mouse are commonly referred to as left (L), middle (M), and right (R) as illustrated in Figure B-l. The function of the mouse buttons depend on the software you are using (refer to your application software documentation). #### C.4 MOUSE SPECIFICATIONS PHYSICAL Size: (TBS) Weight: (TBS) grams (TBS) ounces including cable Switches: Three tactile feel type switches (actuating force 175 grams (6 ounces) +/- 25% Cable: 1.5 m (5 ft), round .375 cm (0.15 in) diameter, six conductor #26 stranded, shielded high flexibility Connector: 7 pin micro-DIN type (male) Temperature: Operating: +10 to +40 degrees C (50 to 104 degrees F) Non-Operating: -40 to +66 degrees C (-40 to 150.8 degrees F) ELECTRICAL Power: +5 VDC +/- 5% at less than 250 mA. -12v + / -10% at less than 20 mA (RS-232 mode) Interface: RS-232 voltage level compatible. The output from the mouse shall be capable of driving a load of 3k ohms to ground (mark less than -6v, space = 4.6v min). FCC/EMI: Class B certified #### PERFORMANCE Resolution: 0.125 mm (200 dots per inch) Tracking Speed: 0.76 m/sec (30 inches/sec) Accuracy: +/- 3% 0-25 cm (0-10 inches/sec any direction) +/- 15% 25-50cm (10-20 inches/sec) +/- 30% 50-75cm (20-30 inches/sec) Acceleration: 0.5 g (5 m/sec/sec) #### OPERATING Modes: Incremental Stream Prompt Data Format: Delta Mode Sampling Rate:55 reports/second in Incremental Stream Mode Up to 95 reports/second when polling Baud Rate: 4800 baud #### C.5 ELECTRICAL INTERFACE ## C.5.1 Interface Signal Levels The mouse transmits and receives RS-232 compatible signals. transmit: mark < -6V, space > 4.6v receive: mark -15v to 0.8v, space 2.8v to +15v minimum dc load resistance is 3000 ohms to ground ## C.6 MOUSE OPERATION ## C.6.1 Serial Interface Operation The mouse communicates with its host via an asynchronous, serial interface at 4800 baud (+/-2%). Each character consists of one start bit, eight data bits, one parity bit (odd), and one stop bit. The mouse ignores incoming parity and the most significant bit of each byte (bit 7) on receive. The mouse supports only half-duplex communication. If a byte is sent to the mouse while it is transmitting, the mouse will abort the data being transmitted (force a break) and process the new command immediately (except during self-test). If a byte is received between the characters of a multibyte report, the mouse is still considered to be transmitting and will abort the current report. #### C.6.2 Data Format Data is transferred in 9 bit bytes (8 data plus odd parity). Although the mouse transmits odd parity, it will ignore parity errors on receive. The mouse will transmit a 3 byte position report as shown in Figure C-4. | | - | • | _ | - | - | | | | bit number | |---|---|----|----|----|----|------------|----|------------|------------| | + | | | | | | | | | byte l | | | 0 | х6 | х5 | x4 | х3 | <b>x</b> 2 | хı | <b>x</b> 0 | byte 2 | | | 0 | | | | | | | | byte 3 | | + | | | | | | | | + | | KEY: Bit 7 = Frame synchronization SX,SY = Sign bit, l = positive, 0 = negative L,M,R = Left, Middle, Right button position, 1 = button depressed X6-X0 = X displacement, X0 is LSB Y6-Y0 = Y displacement Figure C-4 Three Byte Position Report Format The X and Y values in the mouse position report give the movement in units of resolution since the last report. If the X or Y values overflow, the maximum movement is reported. ## C.6.3 Operating Modes The mouse has two operating modes which determine when, and how often the mouse transmits a position report. The operating modes are: - 1. Incremental Stream - 2. Prompt Mode (power-up default) In Incremental Stream Mode, the mouse will generate reports at 55 Hz intervals any time there has been movement, or a change in button position since the last report. If the mouse is motionless and no buttons have changed, no report is generated. The report rate under continuous movement or button change is 55 reports per second. In Prompt Mode, the mouse will only generate a report in response to a Request Mouse Position command. The mouse responds to over 95 position requests per second. ## C.6.4 Summary of Mouse Commands All mouse commands are printable ASCII characters and are summarized in Table C-2. The mouse will ignore invalid commands. Table C-2 Mouse Command Summary | ASCII | Hex | Function | |-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | R | 52 | Select Incremental Stream Mode | | D | 44 | Select Prompt Mode | | P | 50 | Request Mouse Position The mouse responds with a position report. The "P" command also switches the mouse to Prompt Mode. | | T | 54 | Self Test And Identify The mouse will respond with its self test report (see Power-Up Self-Test and Identification). Self test leaves the mouse in the reset or power-up state. When a self test command has been issued, it is invalid to send any data to the mouse until the last byte of the self-test report has been received. The mouse will ignore any data received during self-test. | # C.6.5 Power Up Self Test And Identification Upon command from the computer or on mouse power up, the mouse will automatically check its internal logic and circuits, and transmit a self test report consisting of a two byte identification code plus a two byte code describing the health of the electronics and firmware. The four byte self test report shown in Figure C-5 is transmitted at power up. | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | bit number | |-----|-----------|----|----|-----|----|----|----|----|----|------------| | ! | 1 | 0 | 1 | 0 | R3 | R2 | Rl | R0 | ! | byte l | | ! | 0 | M2 | Ml | M 0 | 0 | 0 | 1 | 0 | ! | byte 2 | | ! | 0 | E6 | E5 | E4 | E3 | E2 | El | E0 | ! | byte 3 | | ! | 0 | 0 | 0 | 0 | 0 | L | М | R | ! | byte 4 | | + - | <b></b> - | | | | | | | | -+ | | #### KEY: Bit 7 = frame synchronization R3-R0 = revision number M2-M0 = manufacturing location ID E6-E0 = error code (zero = OK) L,M,R = button code (zero = OK) Figure C-5 Four Byte Self-Test Report Format The bytes shown in Figure C-5 are described below: Byte 1, Firmware ID: Bit 7 through Bit 5 (101) indicates the start of a self-test report. R3-R0 is the revision number. Byte 2, Hardware ID: A single byte code for manufacturing and device identification. M2-M0 is the Digital manufacturing location ID. Bit 3 through Bit 0 is the device code, 0010 indicates mouse data. Figure C-6 shows the ID code format: | - | | | | | <br> | | | | <br> | | • • | |---|--------------|---|--|--|--------|--|---|---|------|--|-----| | • | Manufacturer | | | | Device | | | ! | | | | | - | _ | х | | | <br> | | _ | 0 | <br> | | | Figure C-6 ID Code Format Manufacturing location ID Assignments are reserved for future definition by DEC Device ID Asssignments 0010 - Indicates Mouse data 0100 - Indicates Tablet data Byte 3, Error Code or Zero: Error code ASCII ">" (3E hex) indicates RAM or ROM ckecksum error. If there is no checksum error, ASCII "=" (3D hex) indicates a button error. Codes of 20 (hex) or greater are considered to be fatal hardware problems and codes less than 20 (hex) are non-fatal status. Byte 4, Button code or Zero: The code will be the same as the low three bits of the first byte of the mouse position report indicating which buttons are down or have failed, if any. Example: 04(Hex) would mean a left button error. The switches in the mouse have two contacts and thus four possible states: - 1. Button up - 2. Button down - 3. Both contacts open (switch missing). - 4. Both contacts closed (short circuit) The left and right switches will report a button error for any state other than button up. The middle switch will report an error for button down, or both contacts closed. The mouse will ignore any data received during self test until the last byte of the self test report has been transmitted. # C.6.6 Report Synchronization Bit 7 of the first byte of a multibyte report will be one and can be used for software synchronization. Bit 7 of the succeeding bytes of a multibyte report will always be zero. The following starting bit sequences are defined (bit7, bit6, and bit5 of the first byte of a multibyte report). 100 - mouse position report 101 - mouse self test report (mouse or tablet) 110 - tablet position report (see Appendix D) 111 - reserved for future definition by DEC ## C.6.7 Response Time The mouse will complete all valid commands, except self-test and Digital reserved functions, within 50 milliseconds. The mouse will process a self-test command within 500 milliseconds. At power-up, the mouse will complete its self-test one second from stable power. ## C.7 COMPATIBILITY CONSIDERATIONS - 1. The DEC serial mouse has a resolution of 200 counts per inch which is twice the resolution of the industry standard mouse. - 2. The DEC serial mouse has only one sampling rate in incremental stream mode. The 55 Hertz sampling rate is sufficient to track the cursor smoothly and avoid missing any button action. - 3. The DEC serial mouse does not support the XON/XOFF flow control protocol because there is no data buffering inside the mouse which results in a more effective link between mouse and cursor. - 4. The DEC serial mouse uses half-duplex communication. Half-duplex does not interfere with normal mouse operation because there is no reason to send a command to the mouse while it is transmitting. When polling, the previous three byte report is always read before requesting another report. The only other commands to the mouse cause it to reset or change operating modes. - The DEC serial mouse powers up in prompt mode to avoid sending position reports to the host before it is ready to receive them. - 6. The DEC serial mouse transmits it's Self-Test report at power-up to notify the host of its presence. - 7. The DEC serial mouse does not require a special pad or calibration procedure to operate. ## C.7.1 Spurious Outputs The mouse is designed to avoid reporting movement, when it is not tracking on any surface. Picking the mouse straight up from a horizontal surface shall not report movement of more than 20 counts of resolution. Noise problems, where the output varies by one count when the mouse is not being moved shall be suppressed. ## C.8 PROGRAMMING GUIDELINES #### C.8.1 Initialization A sample initialization for the mouse is as follows: - 1. Initialize the host's serial port for the mouse to 4800 baud data format (8 data, odd parity, 1 stop bit). - 2. Request that the mouse perform a Self-Test and Identification sequence by sending ASCII "T" (54 Hex) to the mouse. - 3. The mouse will reply with the Self-Test and Identification sequence. Device Identification should be checked for device type in addition to the error report. If self-test was successful, go to step 5. - 4. If self-test report was not received within one second: - o Check that the mouse is correctly attached. - o If no response is received, the mouse is either defective or an alien mouse is connected. - 5. The system now should set the mouse to the proper operating mode. Default set up is for prompt mode. ## C.8.2 Incremental Stream Versus Prompt Mode The mouse has two operating modes, both compatible with industry standard mice protocol. In incremental stream mode, the mouse tests for movement or button action 55 times per second and only sends a report when a significant event has occurred. This mode allows the host to track the cursor smoothly with a minimum of data overhead. The mouse can also be polled to allow the host to control when the mouse position is updated. Since the buttons are not latched (only debounced), the host must poll frequently enough to detect any button action. The intended use of polling is to synchronize mouse updates with video refresh to minimize interrupt overhead. On each vertical interrupt, the host reads the previous three byte report from the mouse UART and then sends the command to poll the mouse. If the UART is buffered allowing it to hold three bytes (as many are), the host never needs to respond to mouse interrupts. To move the cursor absolutely smoothly under worst case conditions, it is necessary to update the cursor position every frame time. For normal 60 Hz refresh, the 55 Hz sampling rate is sufficient to provide good tracking. For the smoothest possible tracking or higher frame rates, polling at the frame refresh rate is recommended. Polling at irregular intervals or less than 50 times per second may fail to track smoothly. #### C.8.3 Button Use Mouse buttons are designated left, middle, and right as viewed with the mouse cable leading away from the user. The left button is frequently used for the "select" function and most closely corresponds to the single button available on some mice. If a mouse application requires only two buttons, the left and right buttons are recommended for compatibility with two button mice. ## C.8.4 Tablet Support By adding minor extensions to the mouse software, the mouse input port can accommodate the DEC serial tablet as well. For detailed information on the tablet, refer to Appendix D. The tablet uses the same connector and serial interface format. The tablet recognizes the same commands with some additions to accommodate its extended capabilities. The power-up self-test and identification sequence for the tablet uses the same format as the mouse, however, some values differ. Device code "0100" is used to indicate tablet data. By convention, tablet error codes (byte 3 of the self-test report) indicate success for values less than 32 (20 Hex) and error for values of 32 or greater. The tablet transmits a five byte absolute position report with the starting bit sequence "110" used for synchronization. #### D.1 GENERAL DESCRIPTION This appendix provides the specifications which define the characteristics of a digitizing tablet system interfacing with a MicroVAX color graphics workstation. The digitizing tablet system consists of an 27.5 cm (ll inch) square digitizing tablet, a 4-button cursor, a 2-button stylus, and a 5-foot power/signal cable as shown in The digitizing tablet is a computer input device which Figure D-l. sends X-Y coordinates to a computer to indicate the position of a stylus or cursor on the tablet's surface to a high level of accuracy. The tablet has a resolution of 0.0125 cm (0.005 inch) or 200 counts The active area of the tablet is 27.5 cm (ll inches) per inch. square. The 4-button cursor or the 2-button stylus pen use the same connector located at the rear of the tablet with only one connected at any given time. The tablet cable is supplied with a 7 pin Micro-DIN type connector (male) which is assigned signals that are listed in Table D-1. A five foot, 5 conductor, flexible signal/power cable connects the tablet to the MicroVAX workstation system. Figure D-l Digitizing Tablet Table D-1 Tablet Cable Connector Signal Assignments | Connector<br>Pin | Signal Assignment | |------------------|-------------------------------------| | 1 | GND | | 2 | TXD (serial out from tablet) | | 3 | RXD (serial in to tablet) | | 4 | not used | | 5 | not used | | 6 | +12v | | 7 | Device Present (connected to Pin 1) | | Shell | Protective Ground (ESD Shield) | A diagram of the tablet cable connector numbering scheme is shown in Figure D-2. # TABLET CABLE CONNECTOR END VIEW \* Connector Key Figure D-2 Tablet Cable Connector Numbering Diagram ## D.2 ELECTRICAL SPECIFICATIONS (POWER RATING) The electrical requirements for the tablet are +12 VDC +/-10% at less than 300mA. ## D.3 COMMUNICATION SPECIFICATIONS ## D.3.1 Serial Interface The tablet communicates with its host via an asynchronous, full-duplex, serial interface at 4800 baud (+/-2%) and 9600 baud (+/-2%). Bytes are framed by one start bit, and one stop bit. The data byte contains 8 bits of data and 1 parity bit (odd parity). Default baud rate is 4800 bits/sec. ## D.3.2 Electrical Signals The tablet will transmit and receive RS-232-C compatible signals as follows: Transmit: space = +5v to +12v, mark = -4v to -12vReceive: space = +3v to +12v, mark = -3v to -12v Output from the tablet, is capable of driving a load of 3000 ohms to ground. # D.3.3 Tablet Position Report The tablet will transmit a 5 byte position report as formatted in Figure D-3. | byte + | 0 | |---------------------------|------| | | PR: | | 2 0 0 x5 x4 x3 x2 x1 x0 | x0 | | 3 0 0 X11 X10 X9 X8 X7 X6 | х6 | | 4 0 0 Y5 Y4 Y3 Y2 Y1 Y0 | ¥0 · | | 5 0 0 Y11 Y10 Y9 Y8 Y7 Y6 | ¥6 | Figure D-3 Tablet Position Report Binary Format In explanation of the Figure D-3 diagram: Bit 7 = Start of frame synchronization ``` Cursor B1 = Button #1: 0 = up, 1 = down B2 = Button #2: 0 = up, 1 = down B3 = Button #3: 0 = up, 1 = down B4 = Button #4: 0 = up, 1 = down B4 = Button #4: 0 = up, 1 = down ``` Stylus B1 = Barrel Button: 0 = up, 1 = downB2 = Tip Button: 0 = up, 1 = down PR = Proximity: 0 = in proximity, 1 = out of proximity. X0-X11 = X coordinate bits, X0 is LSB, binary format. Y0-Y11 = Y coordinate bits, Y0 is LSB, binary format. #### TABLET SPECIFICATION Each report contains the absolute X and Y position of the cursor or stylus from the origin of the tablet. Origin of the tablet is bottom left hand corner of the active area. The first byte of the report indicates which button is pressed. # D.4 TABLET OPERATION AND COMMANDS # D.4.1 Report Rate The tablet report rate is software selectable by host command. Report rates are 55, 72 and 120 reports per second. In order to transmit 120 reports/second, the baud rate must be increased to 9600 bits/sec. The default or power up report rate is 55 reports per second. Report rate is selected by sending the following ASCII characters: - "K" (4B Hex) Sampling rate of 55 reports per second "L" (4C Hex) Sampling rate of 72 reports per second "M" (4D Hex) Sampling rate of 120 reports per second - D.4.2 Baud Rate Command Default baud rate of the tablet is 4800 bits/second. The baud rate is changed to 9600 bits/second by sending the ASCII character "B" (42 Hex) to the tablet. Upon receiving this command, the tablet will complete any report in progress, change baud rate, and switch to Request Point Mode. The tablet is switched back to the default baud rate by sending a "BREAK" (minimum of two character times) or by requesting a self-test of the tablet. Both of these commands will invoke self-test and return all functions to the default conditions. ## D.4.3 Request Point Mode Request Point Mode allows the host to select when a coordinate pair will be sent. This mode is selected by by sending the ASCII character "D" (44 Hex). A coordinate pair is requested by sending the ASCII character "P" (50 Hex) to the tablet. The "P" command will also switch the tablet to Request Point Mode. If the request is made while the stylus or cursor is not in proximity with the tablet, the last valid coordinate pair will be transmitted without the off-proximity flag being set. Upon completion of power-up or self-test, the tablet will be placed in this mode. At 4800 baud, the tablet will respond to 72 point requests a second. When at 9600 bits per second baud rate, the tablet will respond to a maximum of 120 requests a second. #### D.4.4 Incremental Stream In Incremental Stream, the tablet will generate a report when the cursor or stylus has moved more than 0.0125 cm (0.005 inch). Reports will continue while the cursor is in motion. A report will also be generated upon button depression or release. Incremental Stream is selected by sending the ASCII character "R" (52 Hex) to the tablet. #### D.4.5 Self-Test Upon command from the host computer or upon tablet power-up, the tablet will automatically check its internal logic circuits and transmit a two byte identification code plus a two byte code describing the health of the electronics and firmware. The four bytes transmitted at power-up are: - 1. Firmware ID AO(Hex) for initial release. - 2. Hardware ID A single byte code for manufacturing and device identification as formatted in Figure D-4. | | | | | <br> | | | | | | |----|-----|-----|------|------|---|-----|------|---|--| | Ma | nuf | act | urer | | | Dev | rice | | | | | | | | <br> | | | | | | | 0 | X | X. | X | | 0 | 1 | 0 | 0 | | Figure D-4 ID Code Format Manufacturing location ID Code Assignments are reserved for future definition by DEC Device ID Code Assignments 0010 - Indicates Mouse data 0100 - Indicates Tablet data Hardware Status - This byte states the health of the tablet's circuitry. Codes of 20(Hex) or greater are considered to be fatal hardware problems and codes less than 20(Hex) are successful. This byte will be one of the following codes: 3E(Hex) - RAM or ROM ckecksum error 3A(Hex) - Analog or Digital error 3D(Hex) - Button down error 13(Hex) - No cursor or stylus connected 11(Hex) - Stylus is connected 00(Hex) - Self-test passed #### TABLET SPECIFICATION 4. Button Code - The code is the same as the first byte of the five byte or Zero code of the tablet position report indicating which buttons are down, if any. Bits 6 and 7 of this byte are zero. The self-test command will leave the tablet in the reset or power-up state. When a self-test command has been issued, it is invalid to send any data to the tablet until the last byte of the self-test report has been received. The tablet will ignore any data received during self-test. The host commands for self-test are the ASCII character "T" (54 Hex) or a "BREAK" (minimum of two character times). ## D.4.6 Default Conditions Upon completion of power-up or after a Self-Test Command, the tablet will be placed in the following state: Request Point Mode Baud rate of 4800 bits/sec Report Rate of 55 reports/sec ## D.4.7 Report Synchronization Multibyte reports are atomic-(the bytes of the report will be sent in sequence without interruption). Bit 7 of the first byte of a multibyte report will be "one"; and can be used for software synchronization. Bit 7 of the succeeding bytes of a multibyte report will always be zero. When a command is received, the tablet will complete the current report transmission before executing the new command. ## D.4.8 Recovery From Invalid Commands The tablet will completely ignore invalid commands. ## D.4.9 Summary of Digitizing Tablet Commands Table D-2 lists the commands that can be executed using the digitizing tablet. All tablet commands are single byte printable ASCII characters. Table D-2 Summary Of Tablet Commands | ASCII | HEX | FUNCTION | |-------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | "BREAK" "B" "C" "K" "L" "M" "P" "R" | 42<br>44<br>4B<br>4C<br>4D<br>50<br>52 | Invoke Self-Test Change Baud Rate to 9600 Request Point Mode Command Set sampling rate to 55 Set sampling rate to 72 Set sampling rate to 120 Position Request Command Incremental Stream Invoke Self-Test | #### D.5 PERFORMANCE SPECIFICATIONS #### D.5.1 Resolution The resolution of the tablet is $0.0125~\rm cm$ ( $0.005~\rm inch)$ or $200~\rm counts$ per inch in any direction. ### D.5.2 Accuracy The tablet will not produce outputs in error by more than +/-5 counts of the position report's LSB. # D.5.3 Spurious Outputs The tablet shall avoid reporting movements of 1 LSB or when reporting has been disabled. Picking the cursor or stylus straight up from the tablet surface shall not report movement of more than 10 counts of resolution. When the cursor or the stylus is not in proximity of the tablet, positional reports to the host shall be suppressed. #### D.5.4 Response Time The tablet will process all valid commands except self-test and vendor reserved commands within 100 milliseconds. Within 500 milliseconds, the tablet must respond to a self-test command. The tablet shall complete its power-up self-test within one second after stable power. #### TABLET SPECIFICATION # D.5.5 Initialization A sample initialization for the tablet is as follows: - 1. Initialize the host's serial port for the mouse/tablet to 4800 baud data format (8 data, odd parity, 1 stop bit). - 2. Request that the tablet do a Self-Test and Identification sequence by sending ASCII "T" (54 Hex) to the tablet. If the tablet driver switches the baud rate to 9600 baud, the Break Character should also be used (Break followed by an ASCII "T"). This will prevent the tablet staying at the higher baud rate if the system is reset. Care must be taken when switching to the higher baud rate. - 3. The tablet will reply with the Self-Test and Identification sequence. Device identification should be checked for device type along with any error report. If self-test was successful, go to Step 5. - 4. If self-test report was not received within one second: - o Check that the tablet is correctly attached. - o If no response is received, the tablet is either defective or an alien tablet is connected. - 5. The system now should set the tablet to the proper operating mode. Default set up is for prompt mode. ## D.6 ENVIRONMENTAL SPECIFICATIONS ## D.6.1 Temperature Range - +10 to +40 degrees C (+50 to 104 degrees F) Operating Non-Operating - -40 to +66 degrees C (-40 to +118.8 degrees F) #### D.6.2 Humidity - 10% to 90% relative humidity, non-condensing, Operating with a maximum wet bulb temperature of 28 degrees C (82.4 degrees F) and a minimum dew point of 2 degrees C (3.6 degrees F). Non-Operating - 5% to 95% with a maximum wet bulb temperature of 46 degrees C (82.8 degrees F). ## TABLET SPECIFICATION # D.6.3 Altitude Operating - Tablet shall be operated at maximum altitude of 2.4 kilometers (8,000 feet) for 4 hours minimum. Non-Operating - Packaged tablet can be exposed to maximum altitude of 9.1 kilometers (30,000 feet) for 1 hour minimum. chip Address Processor A custom LSI chip (microsequencer) that generates the CRT timing signals and bitmap memory addresses required for screen refresh, scrolling, and raster operations. The Address Processor chip also supplies microinstructions and data used by the Video Processor chip (datapath). Applications Program A program designed to meet specific user needs, such as a program that monitors a manufacturing process. ASCII American Standard Code for Information Interchange Asynchronous Multiplexer A device which controls and alternates the transmission of signals, so that more than one signal can be transmitted over a single communications line. The data being transmitted contains the necessary synchronizing information in the form of start and stop signals. Backplane The backplane is the connector block into which all MicroVAX workstation printed circuit boards, including the QBus, are inserted. Backup The continuing process of making a copy of the disk drive(s) stored data for the purpose of recovery in the event a loss of the main record occurs. Backup is accomplished on RX50 floppy disks or TK50 magnetic tape cartridges and then safely stored. Baud rate The speed at which signals are serially transmitted along a communications path. One baud equals one bit per second. Binary A number system which uses only 2 digits: 0 and 1. These digits are usually represented in MicroVAX workstation circuitry by two voltage levels. Bit A binary digit; the smallest unit of information in a binary system of notation, designated as a 0 or a 1. Bitmap Memory used to store an image as an array of bits, one bit for each pixel. Bitmaps can be physically overlayed to form multi-valued pixels. Bootable medium A fixed disk, floppy disk, or magnetic tape cartridge containing software, such as an operating system, which the bootstrap program can load into the MicroVAX workstation system memory and begin memory execution. Bootstrap A program which is started upon powerup of the MicroVAX workstation. The bootstrap loads software contained on fixed disk, floppy disk, or magnetic tape cartridge into memory; the workstation halts executing the bootstrap and starts executing the software in memory. The software usually loads an operating system or software into memory to enable operation of the MicroVAX workstation. Bug An error in the design or implementation of hardware or software system components. Bus The bus is a printed circuit board that is part of the backplane. The bus permits the sharing of signals among the MicroVAX workstation printed circuit boards. Byte A group of eight binary digits (bits). A byte is one-quarter of the size of a MicroVAX workstation word (32 bits or 4 bytes or 2 words or 1 longword). Unit (CPU) Central Processing The part of a MicroVAX workstation system that controls the interpretation and execution of instructions. Clipping rectangle A rectangular mask applied to the destination raster during a rasterop. Pixels outside the boundary of the clipping rectangle are unmodified. CMR Color Map Register Color Map A RAM that translates a pixel value into a color or intensity. Command An order entered on the MicroVAX workstation keyboard by a user. Communications line A cable path along which electrical signals are transmitted. Computer system A combination of MicroVAX workstation hardware, software, and external devices which perform specific operations or tasks. Console terminal The MicroVAX workstation terminal used when installing software and running diagnostic programs. Controller A MicroVAX workstation component, usually a printed circuit board, that regulates the operation of one or more peripheral devices. Controllers are often called interface units. Control Panel The desktop, floorstand, or rack mounted BA23 or BA123 box unit which contain the control switches and indicators for monitoring the operation of the MicroVAX workstation. CPU See Central Processing Unit. Cursor An arbitrary two-color shape with an arbitrary point. A blink or no-blink, block or underline displayed to indicate screen or data entry position. A 4-button input device used with an optional digitizing tablet. D DAC Digital to Analog Converter Data A representation of facts, concepts, or instructions, in a formalized manner suitable for communciation, interpretation, or processing by humans or by automatic means. Data transmission The movement of data, in the form of electrical signals, along a communications line. Debug To detect, locate, and correct errors (bugs) in system hardware or software. Device The general name for any entity connected to the MicroVAX workstation that is capable of receiving, storing, transmitting data. Diagnostic program A program or several programs that detect and identify abnormal MicroVAX workstation hardware operation. Directed-Beam Refresh See graphics CRT display Direct-View Storage Tubes See graphics CRT display Disk A flat circular plate with a coating on which data is magnetically stored in concentric circles (tracks). MicroVAX workstation disks include the RD53 fixed disk and the RX50 floppy disk. Disk drive A device which contains a fixed disk or one or more floppy disks. The drive contains mechanical components that spin the disk, or floppy disks and move the pickup heads for reading and writing data. Diskette A flexible floppy disk packaged in a square paper envelope. Display The address of a pixel in cartesian coordinates Coordinates referenced to the upper left corner of the display referenced to the upper left corner of the display. X increases to the right and Y increases downwards. DMA . Direct Memory Access DUART Dual Universal Asynchronous Receiver and Transmitter Ľ EIA Electronic Industries Association Error message A message displayed by the MicroVAX workstation to indicate detection of hardware or software or data fault(s). **:** Fast mode . The writing mode in which data is written into the destination raster in 16 bit increments. Fast mode can be used when one edge of the raster is aligned with the X axis. FCN Registers Logic function registers. Registers within the Viper chip that can be coded to perform logical operations on displayable data. FIFO First In First Out (Buffer Control) File A collection of related information treated by MicroVAX workstation as a single item. Floppy disk A flexible disk contained in a square paper envelope package. Floppy disk drive The device that holds one or more RX50 floppy disks. Formatted data Data arranged in a particular pattern to conform to a pre-determined structure or architectural protocol. Its organization is dictated by the system software. FRU Field Replaceable Unit. An individual component or assembly of a larger system which can be detached and replaced while the on-site system is operational. The FRUs for the VCB02 are: VCB02 Base Module, the first VCB02 4-plane Memory Upgrade Module, the second VCB02 4-plane Memory Upgrade Module, the Keyboard, and the Mouse or optional Tablet. Graphics CRT Display There are three basic forms of graphics CRT displays: raster scan, directed-beam refresh, and direct-view storage tubes. The raster-scan version is used in commercial television and operates by varying the intensity of a beam that periodically scans left to right along a fixed number of scan lines from the top to the bottom of the screen. In the directed-beam refresh displays, the beam moves from point to point on the screen to produce the desired image, rather than scanning periodically. The image is maintained by being completely redrawn at the periodic refresh rate. Direct-view storage tube devices use the same method as directed-beam displays to draw an image. Since the image is stored in the phosphor of the screen, periodic refresh is not necessary. This type features a "write through" capability, which writes a beam-refreshed image of lesser intensity over the permanent image on the screen. Full color is only available on the raster and scan display devices. Hard-copy terminal A terminal that displays information on paper, rather than on a video terminal's display screen. Hardware The physical mechanical and electrical components assembled in a MicroVAX workstation. The part of a fixed disk drive, floppy disk drive, Head or tape drive that reads, records, and erases data. Pixel within the boundaries of a destination Hole raster that is not mapped by the normal raster operation algorithm. Hole-Fill A modification of the raster operation algorithm that is used to fill in holes in the destination raster. Ι I/D Interconnect Instruction/Data that interconnects the Address > Processor chip to one or more Video Processor chips and associated display hardware. Used to transfer instructions and data. A system assembly which is used to transfer data Input device into the MicroVAX workstation (e.g. a keyboard is an input device). Device Input/Output (I/O) A system assembly that accepts data for transmission to (input) or from (output) a MicroVAX workstation (e.g. a terminal is an I/O device). Interactive The method of communicating with a MicroVAX > workstation system in which a command is entered at the keyboard, the system executes the command, and indicates its accomplishment of the command with a displayed screen prompt. A hardware device or software instruction that Interface allows the different components of a MicroVAX workstation to communicate with one another. I/0 See Input/Output device. K KByte Abbreviation for kilobyte. Kilobyte 1,024 bytes L LED Light Emitting Diode. LEDs are used as indicators on the control panel and vital elements of a printed circuit board. Linear Pattern A repeating, two dimensional rectangular pattern whose origin and alignment correspond to some arbitrary vector within the bitmap. LK201 One of a series of LK200 Keyboards Load To move software from a peripheral device into system memory or to physically place a disk on a disk drive or tape on a tape drive. Local Processor Processor that controls the VCB02 video subsystem. Locator An absolute point on the display represented as X, Y with the x-coordinate in the high 16 bits and the Y-coordinate in the low 16 bits. LSB Least Significant Bit Μ Magnetic tape A long plastic strip coated with magnetic oxide which is used for storing data (e.g. the tape contained in a TK50 magnetic tape cartridge). MByte Abbreviation for megabyte. Megabyte 1,048,576 bytes. Memory The area where a MicroVAX workstation finds the instructions to perform commanded tasks and stores data. Memory The address of a pixel in cartesian coordinates Coordinates referenced to the start of bitmap memory. X increases to the right and Y increases downwards. Menu A displayed list of options, typically commands which can be entered by the user. O OCR Operand Control Registers in the Video Processor chip which can be coded to control the transfer of displayable data between functional registers within the Video Processor chip and the bitmap or I/D interconnect. On-line Pertaining to equipment, devices, and events that are in direct communication with the MicroVAX workstation system. Operating system A collection programs that control the operation of the MicroVAX workstation and performs such tasks - o Data and program memory assignments - o Processing requestso Scheduling tasks - o Controlling input/output operations Output device A device which extracts data from the MicroVAX workstation (e.g. a printer is an output device). ₽ Peripheral device Any device that provides the CPU with added memory storage or communication capability (e.g. disk drive, floppy disk drive, video terminal, and printer are peripheral devices). Pixel Picture element that is the smallest addressable component of a displayable image. Associated with each pixel is a bitmap address in a two-dimensional cartesian coordinate system and a value. Pixel Field The bits in the X direction that represent a pixel. At the highest resolution, the field is one bit wide. The width is two or four bits at half and quarter resolutions respectively. Pixmap An N-plane (pixel) rectangle, where N is number of planes provided by a display. Power-up sequence A series of ordered events which occurs to properly energize a system. Printer A peripheral device that provides paper copies of information stored on a MicroVAX workstation. The complete sequence of instructions necessary for Program for a MicroVAX workstation to perform a task. Programmable Read Only Memory PROM A symbol or word(s) which a MicroVAX workstation Prompt displays to indicate a command should be entered to perform a task or a task has just been completed. R The set of pixels within the area of a parallelogram. Raster Raster operation refers to the operation on the Rasterop contents of bitmap memory that transforms a rectangular source of pixels into a destination raster of any size or orientation. See graphics CRT display Raster Scan A memory that does not allow modification of its Read Only Memory contents. (ROM) To restart a MicroVAX workstation system. Pressing Reboot the RESTART button on the control panel reboots the workstation system, if the HALT ENABLE/DISABLE switch on the rear of the workstation cabinet is in the up (ENABLE) position. A set of related data that a program can treat as Record a unit. A file consists of a number of records. See Read Only Memory. ROM A single continuous execution of a program. Run The writing mode in which data is written into Slow mode the bitmap one pixel at a time. Slow mode is used for Z-axis operations and when the destination raster does not have one edge aligned with the X axis. Program executed by a MicroVAX workstation system Software to perform a chosen or required function. A set of related programs which together perform Software package a specific task. Storage medium Any device capable of recording information (e.g. a floppy disk is a storage medium). Store To enter data into a storage device, such as a disk, or into memory. Sub-plane The bitplane that is created by reducing the X resolution of a bitmap by a factor of 1/4 or 1/2. In this case X resolution is sacrificed to obtain added color or intensity levels. System A combination of MicroVAX workstation hardware, software, and external devices that perform specific processing operations. System management Tasks performed by the operating system which control the overall operation of the MicroVAX workstation. T Terminal An input/output device generally used for communication between the user of a MicroVAX workstation system and the system itself. Terminals are categorized into two basic types: video and hard-copy. Tile A linear pattern whose origin coincides with the screen origin and whose edges are parallel to the X and Y axes. Conceptually, a tile pattern covers the entire bitmap address space. V VCB02 video subsystem A 4- or 8-plane video subsystem contained on respective two or three quad-height modules which provide 1024H by 864V pixel resolution on a 19 inch monochrome or color monitor when installed in a MicroVAX workstation using a BA23 or BA123 system box. The 4-plane subsystem displays 16 simultaneous colors or shades of gray, whereas the 8-plane subsystem displays 256 simultaneous colors or shades of gray. Video terminal A terminal which displays information on the screen of a cathode ray tube (CRT). Video Processor chip Component (datapath) of the VCB02 video subsystem that operates on displayable data as instructed by the Address Processor chip. GLOSSARY-10- ΙAΙ Winchester disk A hard disk permanently sealed in a drive unit to prevent contaminants from affecting the read/write head. Word The largest number of bits (32) that a MicroVAX workstation can accommodate in any one operation. The MicroVAX workstation can also process longwords (two words or 64 bits). Workstation A single-user system that offers high performance, high resolution graphics and can function in a network environment. Write-protect To protect a disk, floppy disk, or other storage medium against the addition, revision, or deletion of information. Write-protect notch The small notch in the side of an RX50 floppy disk which is covered with an adhesive-backed label or tab to write-protect the floppy disk. # INDEX | additional memory, 2-10 | BTPs, 3-39 | |--------------------------------|------------------------------| | ADDRESS COUNTER, 3-58 | Bus width | | Address disable pin, 3-94 | effect of | | address indexing, 4-12 | address output, 3-102 | | address mapping algorithm, | performance, 3-17 | | 4-11 | register, 3-70, 3-82 | | address processor | restrictions | | commands, 4-55 | tiles, 3-34 | | description, 4-54 | BUS WIDTH (Video Processor), | | Address Processor chip, 3-26 | 3-82 | | commands, 3-74 | | | functions, 3-26, 3-39, 3-48 | | | pins, 3-92 | cables, 2-10 | | registers, 3-57 | Cancel command, 3-40, 3-56, | | address processor chip, 4-17 | 3-63, 3-78, 3-80 | | data flow, 4-19 | status bit, 3-81 | | QBus interface, 4-19 | status bit.lt, 3-58 | | address translation, 4-13 | chip architecture | | alignment error, 4-52 | video processor, 4-20 | | arbitrator, 4-19 | video processor/address | | | processor, 4-17 | | BA123 system box, 1-1, 2-2, | chip select registers | | 2 - 6 | external register numbers, | | configuration, 2-6 | 3-100 | | BA23 system box, 1-1 | CLIP X MAX, 3-66 | | components, 2-5 | CLIP X MIN, 3-66 | | configuration, 2-5 | CLIP Y MAX, 3-66 | | BA23/BA123 system box | CLIP Y MIN, 3-66 | | configurations, 2-3 | Clipping, 3-50, 3-56 | | BACKGROUND COLOR, 3-85 | region, 3-18, 3-22, 3-104 | | effect of, 3-37, 3-84, 3-85 | registers, 3-66 | | loading of, 3-26, 3-76, 3-89 | with scrolling, 3-23 | | with PTBs, 3-80 | clipping rectangle, 4-8 | | bitmap data operations, 4-16 | clipping region, 4-11 | | bitmap memory organization, | color map loading, 3-5 | | 4 - 4 | COMMAND, 3-27, 3-62, 3-63, | | bitmap/processor mapping, 4-48 | 3 - 7 4 | | bitmap/processor transfers, | use of, 3-52 | | 4 - 46 | communication devices, 2-11 | | Bresenham's algorithm, 4-29 | connections | | Brush, 3-48 | common intermodule, 2-17 | | BTP, 3-26, 3-39 | intermodule, 2-17 | | command, 3-63, 3-75, 3-78 | unique intermodule, 2-19 | | with scrolling, 3-78 | console emulation, 3-11 | | X mode, 3-78 | control store RAM, 4-22 | | Z mode, 3-80 | coordinate systems, 4-55 | | | | | Coordinate systems/mapping, 4-9 Coordinates device, 3-57 memory, 3-57 world, 3-57 | doubling, 4-44<br>drag<br>region, 4-9<br>DZQ11, 2-11 | |-----------------------------------------------------------------------------------|------------------------------------------------------------| | CSR, 3-10, 3-38, 3-87 | odgo wogtors 4 40 | | selecting, 3-77, 3-79 | edge vectors, 4-40<br>before fill, 4-43<br>diverging, 4-45 | | DEQNA, 2-9 | ERROR 1, 3-32, 3-69 | | destination operand, 4-13, | ERROR 2, 3-32, 3-69 | | 4 - 31 | Ethernet controller (DEQNA), | | DESTINATION X ORIGIN, 3-28, | 2-9 | | 3-52, 3-67 | | | DESTINATION Y ORIGIN, 3-28, 3-52, 3-67 | FAST DESTINATION DX, 3-28, 3-33, 3-67 | | diagnostic support, 3-12 | FAST DESTINATION DY, 3-28, | | diagnostics, 5-1 | 3-33, 3-67 | | address processor, 5-9 | FAST SCALE, 3-32, 3-33, 3-49, | | bitmap memory, 5-9 | 3-67 | | console bus reset, 5-18 | FAST SOURCE 1 DX, 3-67 | | console I/O support, 5-16 | effect of, 3-32, 3-33, 3-49 | | console page, 5-6 | use of, 3-52, 3-55 | | console reset, 5-18 | FILL, 3-85 | | DUART, 5-14 | loading of, 3-26, 3-76, 3-77 | | error processing, 5-3 | 3-89 | | FIFO/DMA, 5-12 | FOREGROUND COLOR, 3-85 | | functional description, 5-4 | effect of, 3-37, 3-84, 3-85 | | get character, 5-17 | loading of, 3-26, 3-76, 3-89 | | manual input devices, 5-15 | with PTBs, 3-80 | | operation, 5-1 | | | put character, 5-16 | Graphics, 3-46 | | register access/data, 5-7 | curves, 3-26, 3-48 | | requirements, 5-3 | flood, 3-40, 3-55 | | restrictions, 5-3 | objects, 3-56 | | template RAM, 5-8 | points, 3-46 | | update video processor | polygons, 3-50 | | enable, 5-9 | vectors | | update video processor scroll, 5-11 | shaded, 3-48 | | VCB02 lights, 5-7 | H9278-a backplane slot | | video signal level, 5-12 | assignments, 2-4 | | video synchronization, 5-12 | Hardware | | display list data and commands, | buses, 3-15 | | 3-116 | address, 3-15, 3-16, 3-101 | | DMA controller | data, 3-15, 3-16, 3-103 | | interface, 3-15, 3-18, 3-57, | I/D, 3-15, 3-17 | | 3-58 | private data, 3-15 | | restriction, 3-24 | video, 3-15, 3-105 | | use of, 3-26, 3-39, 3-78 | chip select | ``` I/O interconnect, 2-20 logic, 3-15, 3-22, 3-74, 3-75, 3-81, 3-100 I/O page CSR, 3-10 use of, 3-76, 3-78, 3-79, index/offset registers, 4-15 3-80, 3-89 Interconnect I/D, 3-15 color map, 3-105 Interrupt, 3-22, 3-25 interconnect I/D, 3-25, 3-81, 3-99 pin, 3-18, 3-75 INTERRUPT ENABLE, 3-58 timing, 3-16 address bus, 3-16, 3-72 KA630-AA CPU, 2-7 clocks, 3-98, 3-101 keyboard, 2-10 computation cycle, 3-17 data bus, 3-16 I/D bus, 3-17, 3-99 LEFT SCROLL BOUNDARY, 3-77, 3-85 major cycle, 3-16, 3-72, linear pattern, 4-36 3-73, 3-101, 3-104 LK201 keyboard, 2-10, 3-6 minor cycle, 3-16, 3-101, local memory space computation, 3-104 4 - 49 synchronization, 3-70, logic unit, 4-24 3-73, 3-98 LOGIC UNIT FUNCTION, 3-38, video bus, 3-16, 3-73, 3-84 3-82 selecting, 3-77, 3-79, 3-80 write enable logic, 3-104 hardware cursor, 3-5 hardware support, 4-1 manual organization, xx MASK 1, 3-84, 3-85 hole-fill, 4-30 control of, 3-84 loading of, 3-37, 3-87 I/D bus, 3-15 command, 3-64, 3-74, 3-75 MASK 2, 3-84 control of, 3-84 data registers, 3-62, 3-64, loading of, 3-37, 3-87 masking/clipping logic, 4-25 FIFO, 3-39, 3-75, 3-78, mass storage devices, 2-9 3-80 Memory, 3-16 status, 3-58 configuration, 3-16, 3-17, with address counter, 3-18, 3-70, 3-102, 3-103 3 - 58 planes, 3-25, 3-41, 3-56, data source, 3-37, 3-79, 3-104 3-87, 3-88 RAM, 3-71, 3-103 external device, 3-75, 3-76, refresh, 3-16, 3-70, 3-71, 3-100 3-102, 3-103 NOP cycle, 3-76, 3-89 row/column addresses, 3-70, I/D DATA, 3-58, 3-62, 3-76, 3-80, 3-88 3-101, 3-102 timing, 3-16, 3-72, 3-101 I/D interconnect, 3-2, 4-17 chip select decoding, 3-2 word boundaries, 3-34, 3-39, 3-41, 3-79, 3-85 protocol, 4-17, 4-27 memory base register, 3-10 I/D SCROLL COMMAND, 3-64, 3-74, memory CSR, 3-11 3-76, 3-80 I/D SCROLL DATA, 3-58, 3-64, MicroVAX CPU 3-76, 3-88 index management, 3-24 MicroVAX workstation, 1-1 I/O devices, 3-6 ``` ``` system configuration, 2-2 with scrolling, 3-39 MODE, 3-45, 3-62 X mode, 3-39 Z mode, 3-39 use of, 3-49, 3-50, 3-51 modulo arithmetic, 4-11 I/D instructions, 3-37 monitors, 2-9, 3-7 PENDING X INDEX, 3-24, 3-65, VR260/VR290, 2-9 3 - 77 mouse, 2-10, 3-6 PENDING Y INDEX, 3-24, 3-65, commands, C-8 3-77 operating modes, C-8 Performance, 3-17 operation, C-7 rasterop, 3-17, 3-40 text, 3-17, 3-42, 3-43, 3-44 programming guidelines, C-12 RS-232 mode, C-6 font storage, 3-41 while scrolling, 3-20, 3-40 self-test and ID, C-9 usage, C-4 physical configuration, 3-92 MS630 Memory Expansion Module, Pixels non-square, 3-27, 3-28, 3-30 PLANE ADDRESS, 3-84 NEW X INDEX, 3-24, 3-65, 3-77 polygon fill, 4-40 NEW Y INDEX, 3-24, 3-65, 3-77 polygon fill algorithm effects, 4-42 object (raster), 4-12 polygon fill model, 4-41 Off screen printers, 2-11 definition, 3-71 processor/bitmap mapping, 4-51 shared use, 3-19 processor/bitmap transfers, 4-46, 4-50, 4-58 use of PTB, 3-26, 3-39 complement mode, 3-30, command, 3-63, 3-75, 3-78 fonts, 3-41 with scrolling, 3-78 PBTs, 3-40 X mode, 3-78 PTBs, 3-79 Z mode, 3-80, 3-85 source two, 3-34, 3-50, I/D instructions, 3-90 3-56 PTBs, 3-39 zoom, 3-27 PTP offscreen memory, 4-9 Z mode, 3-84 offscreen/visible memory, 4-5 OLD X INDEX, 3-24, 3-65, 3-77 OLD Y INDEX, 3-24, 3-65, 3-77 system configurations, A-33 On screen, 3-56, 3-57 Q22 Bus, A-1 definition, 3-17, 3-71 bus cycle protocol, A-6 operand indexing algorithm, bus pin identifers, A-37 4-12 control functions, A-27 operand routing functions, data transfer operations, 4 - 23 A-5 DMA, A-15 optional tape storage, 2-10 DMA protocol, A-15 ordering documentation, xxiii orthogonal functions, 4-17 interrupts, A-21 signal assignments, A-3 PAUSE, 3-23, 3-58, 3-64, 3-76 specifications, A-29 PBT, 3-25 Q22 bus flood, 3-55 block mode DMA, A-17 ``` | BDCOK H, A-28 BPOK H, A-28 BPOK H, A-28 halt, A-27 initialization, A-27 memory refresh, A-27 power status, A-28 power-up/down protocol, A-28 DATEO bus cycle, A-20 DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-29 power supply loading, A-36 major axis, 3-29 minor axis, 3-29 range, 3-27, 3-33 scaling, 3-32 scaling, 3-32 command, 3-27, 3-63, 3-77 loading of, 3-52 complement mode, 3-27, 3-29, 3-30, 3-32 data path, 3-33, 3-35 barrel shifter, 3-37, 3-79, 3-81, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-45 control of, 3-81, 3-84 3-81 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 loading of, 3-25 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-75, 3-78 use of, 3-56 CSRs, 3-30, 3-37, 3-84 control of, 3-26 command, 3-27, 3-63, 3-77 loading of, 3-50 command, 3-27, 3-63, 3-77 loading of, 3-26 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84 use of, 3-56 CSRs, 3-30, 3-37, 3-84 control of, 3-81, 3-26 definition, 3-29 use of, 3-52 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | minor axis, 3-29 initialization, A-27 memory refresh, A-27 power status, A-28 power-up/down protocol, A-28 DATEO bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus receivers, A-30 bus traination, A-29 protocol, A-29 multiple backplane interion, A-31 load definition, A-29 load definition, A-29 minor axis, 3-29 range, 3-27, 3-33 scaling, 3-32 shift constants, 3-37 command, 3-27, 3-63, 3-77 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-30, 3-32 data path, 3-33, 3-35 barrel shifter, 3-37, 3-84, 3-85 loading of, 3-26, 3-27, 3-38, 3-37, 3-84, 3-85 loading of, 3-3-63, 3-77 loading of, 3-75, 3-78 use of, 3-55 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-35 loading of, 3-3-63, 3-77 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-3-64 cuse of, 3-56 CSRs, 3-30, 3-37, 3-84 colors, 3-37, 3-84 colors, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 constants, 3-29 and the constants, 3-27 command, 3-27, 3-63, 3-77 loading of, 3-69 loading of, 3-69 and path a-13 | | initialization, A-27 memory refresh, A-27 power status, A-28 power-up/down protocol, A-28 DATBO bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-26 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 lace in termination, A-29 lace in termination, A-29 lace in termination, A-29 lace in termination, A-29 lace in termination, A-29 shift constants, 3-37 command, 3-27, 3-63, 3-77 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 barrel shifter, 3-37, 3-79, 3-81, 3-84, 3-85 loading of, 3-27, 3-29, 3-80, 3-32 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-72, 3-30, 3-81, 3-84, 3-85 loading of, 3-72, 3-79, 3-81, 3-84, 3-85 loading, 3-26 destination, 3-26 destination, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | memory refresh, A-27 power status, A-28 power-up/down protocol, A-28 DATBO bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 lack ling, 3-32 shift constants, 3-37 command, 3-27, 3-63, 3-77 loading of, 3-75, 3-78 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84 use of, 3-56 CSRs, 3-30, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-85 barrel shifter, 3-37, 3-85 complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84 use of, 3-56 CSRs, 3-30, 3-37 selecting, 3-77 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 complement mode, 3-27, 3-29, 3-80, 3-32 data path, 3-33, 3-35 barrel shifter, 3-37, 3-84 use of, 3-56 CSRs, 3-30, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, | | power status, A-28 power-up/down protocol, A-28 DATBO bus cycle, A-20 DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-29 120 ohm bus, A-29 Shift constants, 3-37 command, 3-27, 3-63, 3-77 loading of, 3-25, 3-29, 3-80 use of, 3-52 complement mode, 3-27, 3-29, 3-80 use of, 3-33, 3-37 barrel shifter, 3-37, 3-89 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 barrel shifter, 3-37, 3-84 colors, 3-37, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-36 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 control of, 3-69 definition, 3-26 destination, 3-26 destination, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | power-up/down protocol, A-28 DATBO bus cycle, A-20 DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 A-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-29 120 ohm bus, A-29 Command, 3-27, 3-63, 3-77 loading of, 3-52 complement mode, 3-27, 3-29, 3-30, 3-32 data path, 3-33, 3-37 3-81, 3-84, 3-85 loading of, 3-27, 3-79, 3-81, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-36 CSRs, 3-30, 3-37, 3-84 colors, 3-36 CSRs, 3-30, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79, 3-80 use of, 3-45 configuration of, 3-81 use of, 3-52 complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-27, 3-79, 3-26, 3-45 use of, 3-45 use of, 3-68 CSRs, 3-30, 3-37 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-69 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-28 | | A-28 DATBO bus cycle, A-20 DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 DATIO bus cycle, A-8 use of, 3-52 complement mode, 3-27, 3-29, 3-80 use of, 3-32 data path, 3-32 complement mode, 3-27, 3-29, 3-80 salous of, 3-45, 3-56 complement mode, 3-27, 3-29, 3-80, 3-37, 3-84, 3-85 barrel shifter, 3-37, 3-84, 3-85 loading of, 3-52 complement mode, 3-27, 3-29, 3-30, 3-32 data path, 3-33, 3-35 barrel shifter, 3-37, 3-84 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-29, 3-80 use of, 3-52 Complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 barrel shifter, 3-37, 3-84 colors, 3-37, 3-84, 3-85 loading of, 3-52 complement mode, 3-27, 3-29, 3-30, 3-32 data path, 3-33, 3-65 barrel shifter, 3-37, 3-84 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-29, 3-80 use of, 3-52 Complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-27, 3-29, 3-80 use of, 3-52 Complement mode, 3-27, 3-29, 3-81, 3-84, 3-85 loading of, 3-27, 3-29, 3-80 use of, 3-52 Complement mode, 3-27, 3-29, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-27, 3-79, 3-80 use of, 3-56 complement mode, 3-27, 3-29, 3-80 use of, 3-56 complement mode, 3-27, 3-79, 3-81, 3-84, 3-85 loading of, 3-27, 3-79, 3-80 use of, 3-56 complement mode, 3-27, 3-79, 3-81, 3-84, 3-85 loading of, 3-27, 3-79, 3-80 use of, 3-45 use of, 3-56 complement mode, 3-27, 3-37, 3-84 use of, 3-56 complement mode, 3-27, 3-79, 3-80 use of, 3-45 loading of, | | DATBO bus cycle, A-20 DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-29 120 ohm bus, A-29 DATIO or DATOB bus cycle, A-32 data path, 3-35 barrel shifter, 3-37, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-26, 3-26, 3-27, 3-80 CSRS, 3-30, 3-37, 3-38, 1 colors, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-52 data path, 3-33, 3-59 barrel shifter, 3-37, 3-79, 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-26, 3-27 selecting, 3-77, 3-79 logic unit, 3-37, 3-79 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-56 source register, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | DATI bus cycle, A-8 DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 complement mode, 3-27, 3-29, data path, 3-32 colors, 3-37, 3-87, barrel shifter, 3-37, 3-79, a-80, 3-81, 3-84, 3-85 loading of, 3-26, 3-27, 3-88, selecting, 3-77, 3-79 logic unit, 3-37, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-84 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-28 | | DATIO or DATIOB bus cycle, A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 data path, 3-32, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-56 CSRs, 3-30, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 3-84 control of, 3-81 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-81 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-60 selecting, 3-77, 3-79 logic unit, 3-3 | | A-13 DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 data path, 3-33, 3-35 barrel shifter, 3-37, 3-79, 3-81, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-36 CSRs, 3-30, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 destination, 3-26 definition, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | DATO or DATOB bus cycle, A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 barrel shifter, 3-37, 3-79, 3-81, 3-84, 3-85 loading, 3-26, 3-45 use of, 3-45 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 buse of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 source register, 3-37, 3-84 use of, 3-45 source register, 3-37, 3-84 estination, 3-26 definition, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 13-69 definition, 3-28 | | A-11 device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 3-81, 3-88, 3-91 colors, 3-37, 3-84, 3-85 loading of, 3-26, 3-45 use of, 3-56 CSRs, 3-30, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 control of, 3-45 mask register, 3-37, 3-84 use of, 3-45 source register, 3-37, 3-84 use of, 3-45 source register, 3-37, 3-84 use of, 3-45 definition, 3-26 definition, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | device addressing, A-7 DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 1 colors, 3-37, 3-84, 3-85 1 coading of, 3-26, 3-45 use of, 3-36 CSRs, 3-30, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79, 3-80 use of, 3-45 selecting, 3-77, 3-79, a-80 3-79 logic unit, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45 selecting, 3-77, 3-79, a-80 use of, 3-45 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79, a-80 use of, 3-45 selecting, 3-77, 3-79, a-80 use of, 3-45 selecting, 3-77, 3-79, a-80 use of, 3-45 selecting, 3-77, 3-79, a-80 use of, 3-45 selecting, 3-77, 3-79, a-80 use of, 3-60 definition, 3-26 definition, 3-26 definition, 3-26 enable, 3-77 fast vector, 3-33, 3-67, a-69 definition, 3-28 | | DMA guidelines, A-21 interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 loading of, 3-26, 3-45 use of, 3-56 CSRs, 3-30, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-65 source register, 3-37, 3-84 use of, 3-45 selecting, 3-77, 3-79 logic unit, 3-37, 3-79 logic unit, 3-37, 3-65 selecting, 3-77, 3-79 logic unit, 3-37, 3-65 selecting, 3-77, 3-79 logic unit, 3-37, 3-65 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-65 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 3-86 selecting, 3-77, 3-79 logic unit, 3-37, 3-86 selecting, 3-77, 3-79 logic unit, 3-37, 3-86 selecting, 3-77, 3-79 logic unit, 3-37, 3-86 selecting, 3-77, 3-79 logic unit, 3-37, 3-86 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-84 selecting, 3 | | interrupts device priority, A-22 4-level configurations, A-26 protocol, A-22 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 logic unit, 3-37, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 logic unit, 3-37 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 3-84 control of, 3-81 selecting, 3-77, 3-79 logic unit, 3-27, uni | | device priority, A-22 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 CSRs, 3-30, 3-37, 3-38, 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 to selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 to selecting, 3-77, 3-79 logic unit, 3-37, 3-85 desting, 3-80 use of, 3-45 source register, 3-37, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-84 use of, 3-45 source register, 3-37, 3-84 use of, 3-45 source register, 3-37, 3-84 source register, 3-37, 3-84 source register, 3-37, 3-84 use of, 3-45 3-64 use of, 3-45 source register, 3-37, 3-64 use of, 3-45 source register, 3-37, 3-64 use of, 3-45 s | | 4-level configurations, A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 3-87 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79, mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | A-26 protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 selecting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 use of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 selecting, 3-77, 3-79 logic unit, 3-37, 3-79 selecting, 3-77, 3-79 logic unit, 3-37, 3-69 desting, 3-77, 3-79 logic unit, 3-37, 3-85 selecting, 3-77, 3-79 bus of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 source register, 3-37, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | protocol, A-22 master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 logic unit, 3-37, 3-85 selecting, 3-77, 3-79, use of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45, 3-56 source register, 3-37, a-81, 3-84, 3-85 loading, 3-26 definition, 3-26 definition, 3-26 destination, 3-26, 3-27, a-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, a-69 definition, 3-28 | | master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 multiple backplane system use of, 3-45 mask register, 3-37, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | master/slave relationship, A-2 multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 multiple backplane system use of, 3-45 mask register, 3-37, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 destination, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | multiple backplane system configuration rules, A-34 single backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 3-80 use of, 3-45 mask register, 3-37, 3-84 control of, 3-81, 3-84 sequence register, 3-37, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | configuration rules, A-34 single backplane system configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 mask register, 3-37, 3-84 control of, 3-81, 3-84 specificater, 3-37, 3-56 source register, 3-37, 3-84 control of, 3-81, 3-84 specification of, 3-26 source register, 3-37, 3-66 source register, 3-37, 3-66 source register, 3-37, 3-66 source register, 3-37, 3-84 control of, 3-81, 3-84 specifications source register, 3-37, 3-66 3-67 source register, 3-37, 3-67 source register, 3-37, 3-67 source register, 3-37, 3-67 source regist | | configuration rules, A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 mask register, 3-37, 3-84 control of, 3-81, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-84 use of, 3-45, 3-36 definition, 3-26 definition, 3-26 definition, 3-26 loading, 3-26 definition, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | A-34 single backplane system configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 control of, 3-81, 3-84 use of, 3-45, 3-56 source register, 3-37, 3-81, 3-84 specifications loading, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 specification rules, 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | configuration rules, A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 specification rules, 3-80 source register, 3-37, 3-84, 3-85 loading, 3-26 definition, 3-26 definition, 3-26 definition, 3-28 source register, 3-37, 3-84 specifications loading, 3-26 definition, 3-28 | | A-34 specifications bus drivers, A-30 bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 l20 ohm bus, A-29 3-81, 3-84, 3-85 loading, 3-26 definition, 3-26 definition, 3-26 definition, 3-26 definition, 3-27 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | bus drivers, A-30 definition, 3-26 bus interconnecting wiring, A-32 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 bus termination, A-31 fast vector, 3-33, 3-67, load definition, A-29 120 ohm bus, A-29 definition, 3-28 | | bus drivers, A-30 definition, 3-26 bus interconnecting wiring, A-32 destination, 3-26, 3-27, Bus receivers, A-30 enable, 3-77 bus termination, A-31 fast vector, 3-33, 3-67, load definition, A-29 definition, 3-28 | | bus interconnecting wiring, A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 destination, 3-26, 3-27, 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | A-32 bus receivers, A-30 bus termination, A-31 load definition, A-29 120 ohm bus, A-29 3-28, 3-37, 3-64 enable, 3-77 fast vector, 3-33, 3-67, 3-69 definition, 3-28 | | bus termination, A-31 fast vector, 3-33, 3-67, load definition, A-29 3-69 definition, 3-28 | | bus termination, A-31 fast vector, 3-33, 3-67, load definition, A-29 3-69 definition, 3-28 | | load definition, A-29 3-69 120 ohm bus, A-29 definition, 3-28 | | 120 ohm bus, A-29 definition, 3-28 | | nower supply loading, A-36 use of, 3-47, 3-49 | | ponor supper everency, and an | | OBus memory space, 3-8 holes and duplications, | | 3-29, 3-47, 3-63 | | raster (object), 4-12 origin, 3-52, 3-67 | | raster operational model, 4-38 registers, 3-67 | | raster scanning algorithm, rotation, 3-39 | | 4-29 effect of, 3-33 | | Rasterop, 3-17, 3-26, 3-48 use of, 3-26, 3-43, 3-45 | | address FIFO, 3-27, 3-40 slow vector, 3-67, 3-69 | | arithmetic definition, 3-28 | | Bresenham's algorithm, use of, 3-47, 3-50, 3-52 | | Dieseman s argerrem, | | fast mode, 3-33, 3-37, 3-40, 3-47 | rasterop command, 4-56 rasterop data flow, 4-20 | |-----------------------------------|-------------------------------------------------| | fill mode, 3-50, 3-62 | rasterop dataflow, 4-21 | | A and B sides, 3-51, 3-69 | rasterop operand flow, 4-7 | | baseline, 3-55, 3-63 | rasterop operands, 4-30 | | complement mode, 3-53, | rasterop process, 4-29 | | 3-55 | rasterop protocol, 4-57 | | crossing vectors, 3-51, | rasterop rotation, 4-33 | | 3-54 | rasterops, 4-5 | | error registers, 3-32 | rasterops/scrolling | | origin, 3-51, 3-52 | collisions, 4-15 | | polygon subdivision, 3-51 | interactions, 4-14 | | X or Y fill axis, 3-33, | Region, 3-18 | | 3-50, 3-52, 3-55, 3-63 | boundaries, 3-18, 3-20 | | mode, 3-26, 3-27, 3-50, 3-62 | register | | pen up/down, 3-45, 3-50, | updating, 4-15 | | 3-63 | register mapping, 3-9 | | use of, 3-49 | related documentation, xxi | | register values, 3-26, 3-57 | REQUEST ENABLE, 3-58 | | registers, 3-65 | RESOLUTION MODE, 3-81 | | source one, 3-26, 3-27, 3-32, | Resolution mode | | 3-37, 3-50 | logic, 3-37, 3-81, 3-84, | | enable, 3-64, 3-77 | 3-85, 3-89 | | fast vector, 3-32, 3-49, | subplane, 3-82 | | 3 - 67 | with scrolling, 3-82 | | use of, 3-49 | RIGHT SCROLL BOUNDARY, 3-77, | | linear pattern, 3-48, 3-62 | 3 - 85 | | effect of, 3-33 | | | use of, 3-35, 3-45, 3-48, | scaling process, 4-33 | | 3 - 50 | scrambling effect, 4-15 | | origin, 3-49, 3-50, 3-52, | Screen | | 3-55, 3-67 | format, 3-16 | | registers, 3-67 | registers, 3-69 | | scaling, 3-32, 3-39, 3-78 | requirements, 3-17, 3-70 | | effect of, 3-30, 3-33 | refresh, 3-17, 3-21, 3-40, | | registers, 3-67 | 3 - 71 | | use of, 3-26, 3-43, 3-45, | synchronization signals, | | 3-49, 3-50 | 3-17, 3-69, 3-71, 3-105 | | slow vector, 3-32, 3-49, | screen coordinate system, 4-11 | | 3-67 | screen refresh area, 4-9 | | use of, 3-50 | screen to memory mapping, 4-10 | | use of, 3-52 | SCROLL CONSTANT (Video | | source two, 3-26, 3-33, 3-37, | Processor), 3-82 | | 3-39 | SCROLL CONSTANT (Video | | enable, 3-64, 3-77 | Processor)., 3-105 | | registers, 3-68 | SCROLL CONSTANT (Viper), 3-77 | | tiles, 3-34, 3-68 | SCROLL X MAX, 3-64, 3-76 | | use of, 3-48, 3-50 | SCROLL X MIN, 3-64, 3-76 | | use of, 3-34, 3-50, 3-56 | SCROLL Y MAX, 3-64, 3-76 | | use of, 3-23, 3-41 | SCROLL Y MIN, 3-64, 3-76 | | (Scrolling | SOURCE, 3-85 | |----------------------------------------------------|-------------------------------------------------| | registers, 3-85 | control of, 3-84 | | Scrolling, 3-19, 3-20 | effect of, 3-37, 3-84 | | buffered registers, 3-21, | loading of, 3-26, 3-76, 3-87, | | 3-22, 3-24, 3-25, 3-64, | 3 - 89 | | 3-65, 3-66, 3-82, 3-85 | with PTBs, 3-80 | | command, 3-65, 3-82 | source 1 operand, 4-13, 4-31 | | plane enable, 3-74, 3-82, | mapping/scaling, 4-32 | | 3-105 | SOURCE 1 X ORIGIN, 3-32, 3-49, | | down, 3-21, 3-65, 3-82 | 3-50, 3-52, 3-55, 3-67 | | effect of, 3-29, 3-33, | SOURCE 1 Y ORIGIN, 3-32, 3-49, | | 3-39, 3-40, 3-105 | 3-50, 3-52, 3-55, 3-67 | | reserved memory, 3-21, | source 2 address computation, | | 3-71 | 4-14 | | dragging, 3-22 | SOURCE 2 HEIGHT AND WIDTH, | | erasing a region, 3-23, 3-65 | 3-34, 3-68 | | fill color, 3-20, 3-22, 3-23, | source 2 operand, 4-36 | | 3-26, 3-85 | SOURCE 2 X ORIGIN, 3-33, 3-68 | | I/D commands, 3-22, 3-58, | SOURCE 2 Y ORIGIN, 3-33, 3-68 | | 3-64, 3-74, 3-100 | source edge vector, 4-36 | | indexing, 3-23 | source/destination alignment, | | effect of, 3-28, 3-33, | 4 - 47 | | 3-34, 3-40, 3-41, 3-66, | STATUS, 3-58 | | 3-68 | Status bits, 3-18, 3-58, 3-80 | | enable, 3-63 | address complete, 3-58, 3-61, | | registers, 3-65 | 3-62, 3-78 | | use of, 3-23, 3-27, 3-29, | clipping, 3-19, 3-58 | | 3-33, 3-56 | I/D receive ready, 3-58 | | region, 3-19, 3-22, 3-64 | I/D scroll ready, 3-58, 3-76 | | boundaries, 3-85, 3-104 | I/D transmit ready, 3-58, | | registers, 3-64, 3-82 | 3-76, 3-81 | | speed, 3-20 | initialization complete, | | with update, 3-22, 3-23, | 3-58, 3-75, 3-78 | | 3-34, 3-66, 3-76 | pause, 3-23, 3-58, 3-65 | | | rasterop complete, 3-52, | | scrolling, 4-8 scrolling region, 4-11 | 3-58, 3-78 | | | scroll service, 3-22, 3-25, | | <pre>scrolling/region mapping effect, 4-14</pre> | 3-58 | | scrolling/screen refresh | use of, 3-58, 3-63, 3-75, | | dataflow, 4-20 | 3-78 | | serial device protocols, 3-7 | vertical blank, 3-61 | | SLOW DESTINATION DX, 3-28, | subsystem timing generation, | | | 3-4 | | 3-52, 3-67 | switchpack settings, 2-16 | | SLOW DESTINATION DY, 3-28, | SYNC PHASE, 3-74 | | 3-52, 3-67 | synchronization and blank, 3-5 | | SLOW SCALE, 3-32, 3-49, 3-50, | system specifications, 2-11 | | 3-67 | system specifications, 2 11 system support, 3-7 | | SLOW SOURCE 1 DY, 3-67 | alacem adhorel a | | effect of, 3-32, 3-49 | tablet, 2-11, 3-6, D-1 | | use of. 3-52, 3-55 | COULTEL, A LL, J U, D L | | commands, D-6 | operational elements, 1-6 | |----------------------------------------|--------------------------------------| | connector pins, D-2 | performance, 1-9 | | default state, D-6 | 4-plane, l-l | | modes, D-4 | 8-plane, 1-1 | | operation, D-4 | 4-plane module, 1-1, 1-3 | | power rating, D-2 | principal features, 1-5 | | resolution, D-7 | private memory, 1-10 | | response time, D-7 | programmable modes, 1-8 | | self-test, D-5 | rasterops, 1-8 | | specifications, D-8 | text/graphics applications, | | support, C-14 | 1-13 | | Test functions, 3-57, 3-62 | video processor registers, | | Text, 3-41 | 1-12 | | attributes, 3-39, 3-45 | | | fonts, 3-41, 3-43 | viewport support, 1-8 | | normal, 3-41 | VCB02-B cable interconnections, 2-14 | | rotated and scaled, 3-43 | • | | variable pitch, 3-43 | VCB02-B module set, 2-8 | | tiling, 4-37 | VCB02-C cable interconnections, | | | 2-15 | | tiling disabled, 4-13 timing generator | VCB02-C module set, 2-8 | | | video memory structure, 3-12 | | inputs/outputs, 3-4 TK50, 2-10 | video output logic, 3-4 | | TR30, 2-10 | video processor | | 17CD () 2 | control registers, 4-26 | | VCB02 | description, 4-51 | | chips | external operand, 4-22 | | registers and commands, | FIFO, 4-20 | | 3-57 | operand fetch, 4-22 | | VCB02 4-plane configuration, | operand processing, 4-22 | | 2-1 | Video Processor chip, 3-26, | | VCB02 8-plane configuration, | 3-81 | | 2-2 | commands, 3-88 | | VCB02 address map, 3-7 | active cycle, 3-75, 3-77, | | VCB02 DMA gate array, 3-105 | . 3-90 | | VCB02 installation, 2-13 | register access, 3-88, | | VCB02 modules, 3-2 | 3-90 | | base module, 3-2 | functions, 3-35 | | 4-plane module, 3-12 | pins, 3-96 | | VCB02 power requirements, 2-13 | registers, 3-81 | | VCB02 programming, 4-1 | loading, 3-75, 3-76, 3-84, | | VCB02 video interfaces, 2-8 | 3 - 85 | | VCB02 video subsystem, 1-1, | video processor chip, 4-17 | | 2 - 8 | video upgrade path, 3-5 | | address processor registers, | Viewport, 3-18 | | 1-11 | viewports, 4-8, 4-12 | | base module, 1-1 | VR260, 2-9 | | block diagram, 4-3 | VR290, 2-9 | | chipset interface, 1-10 | • | | data manipulation, 1-9 | | | multiplane support, 1-6 | windows. 4-12 | ``` X LIMIT, 3-71 use of, 3-17, 3-57 X SCAN CONFIGURATION, 3-70, 3-71, 3-73, 3-102 X SCAN COUNT, 3-71 Y LIMIT, 3-71 use of, 3-17, 3-57, 3-65 Y OFFSET, 3-65 effect of, 3-29, 3-33, 3-34, 3-41, 3-56 loading of, 3-21, 3-76 use of, 3-21, 3-57, 3-71 Y SCAN COUNT, 3-69 Y SCROLL CONSTANT, 3-65, 3-76 Z axis, 3-25, 3-33 definition, 3-25 ``` ``` I/D command, 3-26, 3-75 plane address, 3-25, 3-80, 3-89 register, 3-84 restrictions, 3-81, 3-84 register load, 3-75, 3-88 use of, 3-37, 3-45, 3-84, 3-85 Z block, 3-76, 3-80, 3-84, 3-89 definition, 3-25 Z-axis addressing mode, 4-61 Z-axis processor/bitmap command, 4-60 Z-axis processor/bitmap transfers, 4-54 Z-axis register loads, 4-63 Zoom, 3-27 ```