# VERSAdos to VME Hardware and Software Configuration User's Manual ## MICROSYSTEMS QUALITY • PEOPLE • PERFORMANCE | | | | • | |---|--|--|---------------| | | | | | | | | | 3 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | a | | | | | | | | | | | | | | | * | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | $\overline{}$ | | | | | | | | | | | | | | | | | | | | | MVMEVDOS/D2 MAY 1985 VERSAdos TO VME HARDWARE AND SOFTWARE CONFIGURATION USER'S MANUAL The information in this document has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, Motorola reserves the right to make changes to any products herein to improve reliability, function, or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights or the rights of others. EXORmacs, EXORterm, I/Omodule, RMS68K, SYMbug, TENbug, VERSAdos, VMEbug, VMEmodule, VMEsystem and VME/10 are trademarks of Motorola Inc. SASI is a trademark of Shugart Associates. Second Edition Copyright 1985 by Motorola Inc. ### SAFETY SUMMARY SAFETY DEPENDS ON YOU The following general safety precautions must be observed during all phases of operation, service, and repair of this equipment. Failure to comply with these precautions or with specific warnings elsewhere in this manual violates safety standards of design, manufacture, and intended use of the equipment. Motorola Inc. assumes no liability for the customer's failure to comply with these requirements. The safety precautions listed below represent warnings of certain dangers of which we are aware. You, as the user of the product, should follow these warnings and all other safety precautions necessary for the safe operation of the equipment in your operating environment. #### GROUND THE INSTRUMENT. To minimize shock hazard, the equipment chassis and enclosure must be connected to an electrical ground. The equipment is supplied with a three-conductor ac power cable. The power cable must either be plugged into an approved three-contact electrical outlet or used with a three-contact to two-contact adapter, with the grounding wire (green) firmly connected to an electrical ground (safety ground) at the power outlet. The power jack and mating plug of the power cable meet International Electrotechnical Commission (IEC) safety standards. #### DO NOT OPERATE IN AN EXPLOSIVE ATMOSPHERE. Do not operate the equipment in the presence of flammable gases or fumes. Operation of any electrical equipment in such an environment constitutes a definite safety hazard. #### KEEP AWAY FROM LIVE CIRCUITS. Operating personnel must not remove equipment covers. Only Factory Authorized Service Personnel or other qualified maintenance personnel may remove equipment covers for internal subassembly or component replacement or any internal adjustment. Do not replace components with power cable connected. Under certain conditions, dangerous voltages may exist even with the power cable removed. To avoid injuries, always disconnect power and discharge circuits before touching them. #### DO NOT SERVICE OR ADJUST ALONE. Do not attempt internal service or adjustment unless another person, capable of rendering first aid and resuscitation, is present. #### USE CAUTION WHEN EXPOSING OR HANDLING THE CRT. Breakage of the Cathode-Ray Tube (CRT) causes a high-velocity scattering of glass fragments (implosion). To prevent CRT implosion, avoid rough handling or jarring of the equipment. Handling of the CRT should be done only by qualified maintenance personnel using approved safety mask and gloves. #### DO NOT SUBSTITUTE PARTS OR MODIFY EQUIPMENT. Because of the danger of introducing additional hazards, do not install substitute parts or perform any unauthorized modification of the equipment. Contact Motorola Microsystems Warranty and Repair for service and repair to ensure that safety features are maintained. #### DANGEROUS PROCEDURE WARNINGS. Warnings, such as the example below, precede potentially dangerous procedures throughout this manual. Instructions contained in the warnings must be followed. You should also employ all other safety precautions which you deem necessary for the operation of the equipment in your operating environment. #### WARNING Dangerous voltages, capable of causing death, are present in this equipment. Use extreme caution when handling, testing, and adjusting. #### TABLE OF CONTENTS | | | <u>Page</u> | |-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | CHAPTER 1 | INTRODUCTION | | | 1.1<br>1.2<br>1.3 | OVERVIEW NON-VME COMPONENTS RELATED DOCUMENTATION | 1<br>2<br>2 | | CHAPTER 2 | MONOBOARD MICROCOMPUTERS | | | 2.1<br>2.1.1<br>2.1.2<br>2.2<br>2.2.1<br>2.2.2<br>2.3<br>2.3.1<br>2.3.2<br>2.4<br>2.4.1<br>2.4.2<br>2.5<br>2.5.1<br>2.6 | MVME101 MONOBOARD MICROCOMPUTER Standard VERSAdos Configuration MVME110-1 MONOBOARD MICROCOMPUTER Standard VERSAdos Configuration MVME110-1 Debug Monitor MVME115M MONOBOARD MICROCOMPUTER Standard VERSAdos Configuration MVME115 Debug Monitor MVME120 SERIES MONOBOARD MICROCOMPUTER MVME120 Series Standard VERSAdos Configurations MVME120 Debug Monitor MVME025 SYSTEM CONTROLLER MODULE MVME025 SYSTEM CONTROLLER MODULE MVME050 SYSTEM CONTROLLER AND MVME701 I/O TRANSITION MODULES MVME050/701 Standard VERSAdos Configuration | 3<br>3<br>7<br>7<br>7<br>12<br>12<br>12<br>18<br>18<br>18<br>33<br>33<br>35 | | CHAPTER 3 | DYNAMIC MEMORY MODULES | | | 3.1<br>3.1.1<br>3.1.2<br>3.2<br>3.2.1<br>3.2.2<br>3.3<br>3.3.1<br>3.4<br>3.4.1 | MVME200/201 64K/256K BYTE DYNAMIC MEMORY MODULES Standard VERSAdos Configuration MVME201 Memory Address Settings MVME202/222-1/222-2 512K/1M/2M BYTE DYNAMIC RAM MODULES Standard VERSAdos Configuration MVME202/222 Memory Address Settings MVME210 RAM/ROM/EPROM MEMORY MODULE Standard VERSAdos Configuration MVME211 RAM/ROM/EPROM MEMORY MODULE Standard VERSAdos Configuration | 41<br>41<br>43<br>43<br>43<br>49<br>52<br>52 | | CHAPTER 4 | MASS STORAGE CONTROLLERS | | | 4.1<br>4.1.1<br>4.2<br>4.2.1<br>4.2.2 | MVME315 INTELLIGENT DISK CONTROLLER MODULE MVME315 Standard VERSAdos Configuration | 55<br>55<br>55<br>57<br>59 | #### TABLE OF CONTENTS (cont'd) | | | Page | |----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | 4.2.2.1<br>4.3<br>4.3.1<br>4.4<br>4.4.1 | MVME702 Standard VERSAdos Configuration | 59<br>61<br>63<br>63 | | CHAPTER 5 | I/O CHANNEL MODULES | | | 5.1<br>5.1.1<br>5.2<br>5.2.1<br>5.3<br>5.3.1<br>5.4<br>5.4.1<br>5.5<br>5.5.1 | MVME316 VMEBUS TO I/O CHANNEL INTERFACE MVME316 Standard VERSAdos Configuration MVME400 DUAL RS-232C SERIAL PORT MODULE Standard VERSAdos Configuration MVME410 DUAL PARALLEL PORT MODULE MVME410 Standard VERSAdos Configuration M68RAD1 REMOTE INTELLIGENT ANALOG-TO-DIGITAL CONVERSION MODULE M68RAD1 Standard VERSAdos Configuration M68RI01 REMOTE INPUT/OUTPUT MODULE M68RI01 Standard VERSAdos Configuration I/O CHANNEL ADDRESS SPACE | 67<br>67<br>67<br>72<br>72<br>72<br>72<br>76<br>76 | | CHAPTER 6 | MISCELLANEOUS VMEmodules | | | 6.1<br>6.1.1<br>6.1.2<br>6.2<br>6.2.1 | MVME300 GPIB CONTROLLER WITH DMA | 83<br>83<br>86<br>89<br>89 | | CHAPTER 7 | VME CHASSIS/CARD CAGES AND BACKPLANES | | | 7.1<br>7.2<br>7.2.1<br>7.2.2<br>7.2.3<br>7.2.4<br>7.2.5<br>7.3<br>7.3.1<br>7.3.2<br>7.3.3<br>7.3.4 | INTRODUCTION VME CHASSIS/CARD CAGES MVME940-1 Chassis/Card Cage MVME941 Chassis/Card Cage MVME942 Chassis/Card Cage MVME943 Chassis MVME944 Chassis VME BACKPLANES MVME920 20-Slot VMEbus Backplane MVME921 9-Slot VMEbus Backplane MVME922 5-Slot I/O Channel Backplane MVME924 3-Slot I/O Channel Backplane | 93<br>93<br>93<br>93<br>96<br>96<br>96<br>97<br>97 | #### TABLE OF CONTENTS (cont'd) | | | <u>Page</u> | |-------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | CHAPTER 8 | STANDARD SYSTEM CONFIGURATIONS | | | 8.1<br>8.2<br>8.3<br>8.4<br>8.5<br>8.6<br>8.7 | INTRODUCTION MVME101 SYSTEM MVME110-1 SYSTEM MVME115M SYSTEM MVME120 FAMILY SYSTEMS VME/10 SYSTEM STANDARD CONFIGURATION PROCEDURE | 103<br>105<br>108 | | CHAPTER 9 | SYSTEM MODIFICATIONS | | | 9.1<br>9.2<br>9.2.1<br>9.2.2<br>9.2.3<br>9.3<br>9.4<br>9.5<br>9.6<br>9.7<br>9.8<br>9.9.1<br>9.9.2<br>9.9.3<br>9.9.4<br>9.9.4.3<br>9.9.4.3 | Pagesize Chunks for Task Memory | 113<br>114<br>115<br>116<br>118<br>118<br>122<br>128<br>134<br>150<br>152<br>152<br>152<br>154<br>155<br>155 | | CHAPTER 10 | BOOTING A SYSTEM | | | 10.1<br>10.2<br>10.3<br>10.4<br>10.4.1<br>10.4.2<br>10.4.3<br>10.4.4<br>10.4.5<br>10.5<br>10.6<br>10.7 | INTRODUCTION FIRMWARE BOOT SEQUENCE IOT INITIALIZATION SEQUENCE FMS BOOT SEQUENCE FUNCTIONS Size of FMS Main Data Segment FMS Dynamic Segments I/O Common Data Segments Operating System Task Sizes RAM/ROM Sizes for Operating System Tasks FHS BOOT SEQUENCE FUNCTIONS IOS BOOT SEQUENCE FUNCTIONS SESSION MANAGER EXECUTION SEQUENCE | 157<br>158<br>167<br>169<br>170<br>171<br>172<br>173<br>174<br>175 | #### TABLE OF CONTENTS (cont'd) | | | <u>Page</u> | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | APPENDIX A APPENDIX B APPENDIX C APPENDIX D | VERSAdos CONFIGURATION VALUES | 183<br>199<br>203<br>205 | | | LIST OF ILLUSTRATIONS | | | FIGURE 2-1. 2-2. 2-3. 2-4. 2-5. 2-6. 2-7. 2-8. 2-9. 2-10. 3-1. 3-2. 3-3. 3-4. 4-1. 4-2. 4-3. 4-4. 5-5. 5-1. 5-2. 5-3. 5-4. 5-5. 6-1. 6-2. 7-1. 7-2. 8-1. 8-2. 8-3. 8-4. 8-5. 9-1. 10-1. 10-2. 10-3. 10-4. 10-5. | MVME10-1 Jumper Header Locations MVME115M Jumper Header Locations MVME120 Jumper Header Locations MVME121 Jumper Header Locations MVME122 Jumper Header Locations MVME123 Jumper Header Locations MVME123 Jumper Header Locations MVME025 Jumper Header Locations MVME050 Jumper Header Locations MVME006201 Jumper Header Locations MVME200/201 Jumper Header Locations MVME200/201 Jumper Header Locations MVME210 Jumper Header Locations MVME210 Jumper Header Locations MVME210 Jumper Header Locations MVME210 Jumper Header Locations MVME210 Jumper Header Locations MVME315 Jumper Header Locations MVME320 Jumper Header Locations MVME400 Jumper Header Locations MVME400 Jumper Header Locations MVME410 Jumper Header Locations MVME410 Jumper Header Locations MVME410 Jumper Header Locations MVME410 Jumper Header Locations MVME410 Jumper Header Locations MVME310 Jumper Header Locations MVME410 Jumper Header Locations MVME435A Jumper Header Locations MVME400 Jumper Header Locations MVME300 Jumper Header Locations MVME300 Jumper Header Locations MVME101 Jumper Header Locations MVME101 Jumper Header Locations MVME101 Jumper Header Locations MVME101 Jumper Header Locations MVME100 H | 48<br>13<br>19<br>22<br>25<br>34<br>36<br>39<br>46<br>48<br>53<br>56<br>62<br>64<br>67<br>77<br>77<br>84<br>90<br>102<br>104<br>107<br>107<br>107<br>107<br>107<br>107<br>107<br>107<br>107<br>107 | | 10-6.<br>10-7. | Session Manager Execution Sequence | 177<br>179 | #### LIST OF TABLES | TABLE | 2-1. | MVME101 VERSAdos-Supported Jumper Settings | 5 | |-------|-------|----------------------------------------------------|-----| | | 2-2. | MVME101bug 3.n Commands | 6 | | | 2-3. | MVME110-1 VERSAdos-Supported Jumper Settings | 9 | | | 2-4. | MVME110bug Command and Option Summary | l 1 | | | 2-5. | MVME115M VERSAdos-Supported Jumper Settings | l 4 | | | 2-6. | MVME115 Debug Monitor Command and Option Summary 1 | l 6 | | | 2-7. | MVME120 VERSAdos-Supported Jumper Settings | 20 | | | 2-8. | MVME121 VERSAdos-Supported Jumper Settings | 23 | | | 2-9. | MVME122 VERSAdos-Supported Jumper Settings | 26 | | | 2-10. | MVME123 VERSAdos-Supported Jumper Settings | 9 | | | 2-11. | MVME120 Debug Montior Command and Option Summary 3 | 31 | | | 2-12. | MVMEO25 VERSAdos-Supported Jumper Settings | 35 | | | 2-13. | MVMEO50 VERSAdos-Supported Jumper Settings | 37 | | | 2-14. | MVME701 VERSAdos-Supported Jumper Settings 4 | 10 | | | 3-1. | MVME200/201 VERSAdos-Supported Jumper Settings 4 | 7 | | | 3-2. | MVME202/222 VERSAdos-Supported Jumper Settings 4 | 9 | | | 3-3. | MVME210 VERSAdos Jumper and Backplane Settings 5 | 1 | | | 3-4. | MVME211 VERSAdos Jumper and Backplane Settings 5 | 4 | | | 4-1. | MVME315 VERSAdos-Supported Jumper Settings 5 | 7 | | | 4-2. | MVME320 VERSAdos-Supported Jumper Settings | 9 | | | 4-3. | | 1 | | | 4-4. | MVME420 VERSAdos-Supported Jumper Settings 6 | 3 | | | 4-5. | M68RWIN1 VERSAdos-Supported Jumper Settings 6 | 55 | | | 5-1. | MVME316 VERSAdos-Supported Jumper Settings 6 | 9 | | | 5-2. | MVME400 VERSAdos-Supported Jumper Settings | 1 | | | 5-3. | MVME410 VERSAdos-Supported Jumper Settings | 4 | | | 5-4. | M68RAD1 VERSAdos-Supported Jumper Settings | 6 | | | 5-5. | M68RIO1 VERSAdos-Supported Jumper Settings | 8 | | | 5-6. | | 9 | | | 5-7. | Map of I/O Channel Addresses 000 - OFF | 9 | | | 5-8. | Map of I/O Channel Addresses 100 - 1FF | 30 | | | 5-9. | Map of I/O Channel Addresses 000 - 07F | 30 | | | 5-10. | Map of I/O Channel Addresses 000 - 01F 8 | 31 | | | 5-11. | Map of I/O Channel Addresses 000 - 00F | 31 | | | 6-1. | MVME300 VERSAdos-Supported Jumper Settings 8 | 35 | | | 6-2. | MVME435A VERSAdos-Supported Jumper Settings | 1 | | | 8-1. | MVME101 Standard System SYSGEN Map 9 | 9 | | | 8-2. | MVME110-1 Standard SYSGEN Map 10 | | | | 8-3. | MVME115M Standard SYSGEN Map | | | | 8-4. | MVME120 Family Standard SYSGEN Map 10 | | | | 8-5. | MVME122 Standard SYSGEN Map 10 | 16 | | | 8-6 | VME/10 Standard System SYSGEN Man 10 | 18 | THIS PAGE INTENTIONALLY LEFT BLANK. #### CHAPTER 1 #### INTRODUCTION #### 1.1 OVERVIEW VMEmodules and the VME Family Support Products are modular system building blocks that reflect the latest in microcomputer architecture. VMEmodules make use of the performance and flexibility of the M68000 Family of microprocessors packaged on the internationally accepted Eurocard format. The VMEbus Specification assures mechanical integrity and compatibility for all VMEsystem products. This specification dictates the use of industrial quality 96-pin DIN connectors and sockets. These sealed, virtually gas-tight connectors give VMEsystem products exceptionally high immunity to vibration, shock, and corrosion. Motorola's VERSAdos 4.4 Real-Time Operating System complements the advantages offered by the VMEsystem. VERSAdos provides software development capability on target VMEsystems and high-level language support. Other features include system file handling, I/O services and program loading capability, device drivers for most Motorola board-level products, and most importantly, the RMS68K real-time multitasking kernel. The powerful and universal characteristics of RMS68K can support a wide variety of application systems without large expenditures for design and programming efforts on complex real-time and multitasking functions. The user's task is to configure a VME-based system for a defined environment using VERSAdos. In order to create a system that meets the needs of the application, the systems designer must be educated as to the alternatives available to him. The goal of this manual is to guide the systems designer through the following procedures: - . Define the VME hardware supported by VERSAdos - . Properly configure the hardware with respect to other elements in the system as well as VERSAdos - Provide quick reference information for the user who must adjust jumper settings and utilize Motorola's debug monitors - . Install and run VERSAdos - . Provide support information on SYSGEN requirements, bus addresses, memory requirements, etc. The user should view this document as a reference tool where pertinent component information can be found along with step-by-step procedures for configuring a system. The manual is organized in a modular format that enables the user to easily locate information pertaining to specific topics. This format enables a user to design a variety of systems including the standard VERSAdos-supported systems employing Motorola microprocessor modules. This manual is organized by first presenting hardware-oriented information (through Chapter 7) followed by software-oriented material. For ease of reference, Chapters 2 through 7 describe the standard VERSAdos-supported configurations of various VMEmodules. Chapter 8 describes the standard systems supported by VERSAdos. Chapters 9 and 10 detail the procedures needed to configure various components to meet specific system requirements using VERSAdos. A set of appendices provide handy reference material for the user. #### 1.2 NON-VME COMPONENTS While this manual is specifically geared to the VME/VERSAdos user, non-VME components are occasionally referred to in various tables and examples. This information is included due to the fact that while these modules are VERSAdos-supported, the information is not readily available in another document. It is hoped that the system designer in possession of one of the non-VMEmodules mentioned in this manual will be aided by the inclusion of this information. #### 1.3 RELATED DOCUMENTATION It is assumed that the user designing a system with the help of this manual has already read the user's manual for each of the components in the target system. While some information (such as debug monitor commands) is provided as a reference, this manual does not attempt to duplicate the intended efforts of the user manuals. In addition to the component user manuals, the following documents are helpful references when configuring a VMEsystem using VERSAdos. They may be obtained from Motorola's Literature Distribution Center, 616 West 24th Street, Tempe, AZ 85282; telephone (602) 994-6561. | DOCUMENT TITLE | MOTOROLA PUBLICATION NUMBER | |------------------------------------------------------|-----------------------------| | VMEsystem Architecture Manual | MVMESYSAM | | VMEbus Specification Manual | MVMEBS | | Guide to Writing Device Drivers for VERSAdos | M68KDRVGD | | M68000 Real-Time Multitasking Software User's Manual | M68KRMS68K | | System Generation Facility User's Manual | M68KSYSGEN | | VERSAdos Messages Reference Manual | M68KVMSG | #### CHAPTER 2 #### MONOBOARD MICROCOMPUTERS #### 2.1 MVME101 MONOBOARD MICROCOMPUTER The MVME101 Monoboard Microcomputer is a double Eurocard VMEmodule designed to operate as a monoboard system, as a single CPU controller in a VMEbus system, or as a CPU controller in a multiprocessor system. The MVME101 Monoboard Microcomputer utilizes an 8 MHz MC68000 microprocessor incorporating a 16-bit data bus and a 16Mb addressing range. The module is equipped with eight 28-pin industry-standard JEDEC sockets capable of handling RAM or ROM devices ranging from 2Kb to 32Kb each. The MVME101 features 20 programmable I/O lines, two RS-232C serial I/O ports, seven jumper-selectable interrupt priority levels, and a triple-programmable 16-bit MC6840 Programmable Timer Module. #### 2.1.1 Standard VERSAdos Configuration Figure 2-1 illustrates the MVME101 jumper configuration necessary to boot VERSAdos. Table 2-1 lists the jumpers and their locations. A detailed description of this information is provided in the VME101 System VERSAdos Hardware and Software Configuration Manual (MVMECNFG1). Refer to the MVME101 MC68000 Monoboard Microcomputer User's Manual (MVME101) to compare these settings with the factory-set jumper configuration. #### 2.1.2 MVME101bug Debug Monitor The MVME101 module is configured for use with the MVME101bug Debug Monitor. The MVME101bug Debug Monitor commands are listed in Table 2-2. FIGURE 2-1. MVME101 Jumper Header Locations TABLE 2-1. MVME101 VERSAdos-Supported Jumper Settings | JUMPER NUMBI | ER DESCRIPTION | SETTING | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | | MVME101 VERSAdos JUMPER SETT | <u>INGS</u> | | K1<br>K2 | VMEBUS REQUESTER PRIORITY LEVEL SELECT | 13-14, 15-16<br>7-8 | | К3 | VMEBUS SYSTEM CONTROLLER FUNCTION SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10 | | K4 | LOCAL ROM ACCESS TIME SELECT | 1-2 | | K5 | VMEBUS INTERRUPT REQUEST SELECT | 9-10 | | К6 | LOCAL INTERRUPT REQUEST SELECT | 3-4, 5-6, 7-8, 9-10,<br>11-12 | | K7 | PORT 1 CONFIGURATION SELECT | 1-2, 5-7, 6-8, 9-11,<br>10-12, 13-15, 14-16 | | К9 | PORT 1 INTERFACE CONTROL SELECT | 1-2, 2-3, 5-6 | | K15 | PORT 2 CONFIGURATION SELECT | 1-2, 5-6, 7-8, 9-10,<br>11-12, 13-14, 15-16 | | K10 | PORT 2 INTERFACE CONTROL SELECT | 1-2, 2-3, 5-6 | | K16 | PTM CONFIGURATION SELECT | NO JUMPERS | | K11 | MEM1 MEMORY CONFIGURATION SELECT | 1-2, 4-5, 7-10, 9-12,<br>13-16 | | K12 | MEM2 MEMORY CONFIGURATION SELECT | 1-2, 4-5, 7-10, 9-12,<br>13-16 | | K13 | MEM3 MEMORY CONFIGURATION SELECT | 1-2, 4-5, 7-10, 9-12,<br>13-16 | | K14 | MEM4 MEMORY CONFIGURATION SELECT | 1-4, 3-6, 7-10, 8-9,<br>12-15, 13-16, 14-17,<br>18-21, 19-20 | | | MVME101 BACKPLANE JUMPER SETTI | INGS | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | TABLE 2-2. MVME101bug 3.n Commands DESCRIPTION | BD | Bootstrap dump | |--------------------------------------------------------------------|------------------------------------| | /o + o + / / / / / / / / / / / / / / / / | Block of memory fill | | BF <000011> <00012> <0010> | | | BH | Bootstap natt | | BI <addr1> <addr2></addr2></addr1> | Block of memory initialize | | BM <addr1> <addr2> <addr3></addr3></addr2></addr1> | Block of memory move | | 08 | Bootstrap program | | [NO]BR [ <addr1>[&lt;;count1&gt;]]</addr1> | Set and remove breakpoints | | BS | Block of memory search | | BT <addr1> <addr2></addr2></addr1> | Block of memory test | | DC <expr></expr> | Data conversion | | DF | Display formatted MPU registers | | DU[ <port>] <addr1> <addr2> [<text>]</text></addr2></addr1></port> | Dump memory (S-records) | | GD [ <addr>]</addr> | Go direct execute program | | 60 [ <addr>]</addr> | Go execute program | | GT <addr></addr> | Go execute program to breakpoint | | HE HE | Help | | 10P | Disk I/O physical | | 101 | Disk 1/0 teach | | LO[; <opts>][=<text>]</text></opts> | Load memory (S-records) | | MD[ <port>] <addr> [<count>][;<opt>]</opt></count></addr></port> | Memory display/disassembly | | MM <addr> [opts&gt;]</addr> | Memory modify/disassembly/assembly | | MS <addr> <data> [<data>]</data></data></addr> | Memory set | | 0F | Display all relative offsets | | [NO]PA | Printer attach/detach | | PF[ <port>]</port> | Port format | | TM [ <char>]</char> | Transparent mode | | TR [ <count>]</count> | Trace one instruction | | TT <addr></addr> | Trace to temporary breakpoint | | VE[;= <text>]</text> | Verify memory (S-records) | | . <register> commands</register> | | | ⋖. | Display all address registers | | .A0A7 [ <expr>]</expr> | Display/set address register | | O. | Display all data registers | | .DOD7 [ <expr>]</expr> | Display/set data register | | .PC [ <expr>]</expr> | | | .R0-R6 [ <expr>]</expr> | Display/set relative offset | | . SR [ <expr>]</expr> | Display/set status register | | .SS [ <expr>]</expr> | Display/set superv. stack pointer | | .US [ <expr>]</expr> | Display/set user stack pointer | #### 2.2 MVME110-1 MONOBOARD MICROCOMPUTER The MVMEllo-1 Monoboard Microcomputer is a double Eurocard VMEmodule designed to function as a stand-alone microcomputer, a single CPU/controller in a VMEbus system, or as a single CPU element in a multiprocessor VMEbus configuration. The MVMEllo-1 is equipped with an MC68000 16-bit microprocessor running at 8 MHz. Eight 28-pin sockets enable the module to possess a maximum of 128Kb of RAM, or 64Kb of ROM, or a mixture of these memories. Full support is provided for the Motorola I/O Channel which provides access to a large variety of peripheral and industrial I/O functions. Three independent 16-bit counter/timers are available to implement various forms of interrupts and watchdog timers. An RS-232C serial port is provided to allow use of a terminal or a down-loading function to the MVMEllo-1. #### 2.2.1 Standard VERSAdos Configuration Figure 2-2 illustrates the VERSAdos-supported jumper configuration of the MVME110-1. Table 2-3 lists the jumper locations and settings. Refer to the MVME110-1 VMEmodule Monoboard Microcomputer User's Manual (MVME110) to compare these settings with the factory-set jumper configuration. #### 2.2.2 MVME110-1 Debug Monitor The MVMEl10-1 Debug Monitor, MVMEl10bug, is a powerful debugging and evaluation tool for use in an MVMEl10-1 Monoboard Microcomputer environment. Table 2-4 describes the MVMEl10bug command set. FIGURE 2-2. MVME110-1 Jumper Header Locations TABLE 2-3. MVME110-1 VERSAdos-Supported Jumper Settings | ======================================= | 2-3. MVME110-1 VEKSAGOS-Supported Sumper | | |-----------------------------------------|-------------------------------------------|----------------------------------------| | JUMPER NUMBER | DESCRIPTION<br> | SETTING | | | MVME110-1 VERSAdos JUMPER SETTINGS | | | J1 | MPU CLOCK SPEED SELECT | 1-2 | | J2<br>J3 | BUS ARBITRATION REQUEST LEVEL SELECT | 1-3, 4-6, 5-7, 9-11<br>3-5,4-6 | | J4 | ADDRESS MODIFIER 3 SELECT | 1-2 | | J5 | SOFTWARE STATUS BITS SELECT | 2-4, 3-5 | | J6 | LOCAL BUS TIME-OUT SELECT | 2-3 | | J7 | RESET & ABORT SWITCH ENABLE SELECT | 1-2, 3-4 | | J8 | SYSTEM CONTROLLER FUNCTIONS SELECT | 1-2, 3-4, 5-6, 7-8 | | J9 | ROM ACCESS TIME SELECT | 7-8 | | J10 | RAM ACCESS TIME SELECT | 5-6, 7-8 | | J11 | LOCAL INTERRUPT ENABLE SELECT | 1-2, 3-4, 5-6, 7-8, 9-10, 11-12, 13-14 | | J12 | VMEBUS INTERRUPT ENABLE SELECT | 1-2, 3-4, 5-6, 7-8, 9-10, 11-12, 13-14 | | J13 | I/O CHANNEL BUFFER OPTION | 2-3 | | J14 | BAUD RATE SELECT | 7-8 | | J16<br>J17<br>J18 | SOCKET PAIR 1 MEMORY CONFIGURATION SELECT | 3-5, 4-6<br>1-2, 3-4<br>5-7 | | J19<br>J20<br>J21 | SOCKET PAIR 2 MEMORY CONFIGURATION SELECT | 3-5, 4-6<br>1-2, 3-4<br>5-7 | | J22<br>J23<br>J24 | SOCKET PAIR 3 MEMORY CONFIGURATION SELECT | 5-7, 6-8<br>3-5, 4-6<br>5-7 | | J25<br>J26<br>J27 | SOCKET PAIR 4 MEMORY CONFIGURATION SELECT | 5-7, 6-8<br>3-5, 4-6<br>5-7 | | TABLE 2-3. MVME110 | 0-1 | <b>VERSAdos-Supported</b> | Jumper | Settings | (cont'd | ) | |--------------------|-----|---------------------------|--------|----------|---------|---| |--------------------|-----|---------------------------|--------|----------|---------|---| | TABLE 2-3. | MVME110-1 VERSAdos-Suppor | ted Jumper Settings | (cont'a) | |------------------------------------|-------------------------------------------------------------------------|---------------------|------------------------------------------| | JUMPER NUMBER | DESCRIPTION | S | ETTING | | A21-A22 | MVME110-1 BACKPLANE JU IACKIN* TO IACKOUT* | NO . | JUMPERS<br>JUMPERS | | B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO A | JUMPERS<br>JUMPERS<br>JUMPERS<br>JUMPERS | TABLE 2-4. MVME110bug Command and Option Summary | CUMMAND | DESCRIPTION | |--------------------------------------------------------------------------------------------------------|------------------------------------------| | BD [ <device>][,<controller>]</controller></device> | Boot dump | | | | | 0000 | BLOCK OF MEMORY TILL | | [ <qevi< td=""><td>Bootstrap halt</td></qevi<> | Bootstrap halt | | BI <address1> <address2></address2></address1> | Block of memory initialize | | BM <address1> <address2> <address3></address3></address2></address1> | Block of memory move | | BO [ <device>][,<controller>][,<string>]</string></controller></device> | Bootstrap operating system | | [NO]BR [ <address>[;<count>]] [<address>[;<count>]]</count></address></count></address> | Breakpoint set (and remove) | | <addre< td=""><td>Block of memory search; options B, W, L</td></addre<> | Block of memory search; options B, W, L | | BT <address1> <address2></address2></address1> | test | | DC <expression></expression> | Data conversion | | DF . | Display formatted registers | | DU[ <port number="">] <address1> <address2> [<text>]</text></address2></address1></port> | Dump memory (S-records) | | GD [ <address>]</address> | Go direct execute program | | G[0] [ <address>]</address> | Go execute program | | GT <temporary address="" breakpoint=""></temporary> | Go until breakpoint | | · ± | Herp | | 301 | 1/0 direct command | | dol | 1/0 physical to disk | | IOT [ <device>][,<controller>]</controller></device> | 1/0 "teach" to disk | | LO[ <port number="">] [;[<ptions>]=<text>]</text></ptions></port> | Load (S-records); options X, -C | | MD[ <port number="">] <address> [<count>][;D1]</count></address></port> | Memory display/disassembly | | M[M] <address>[;<options>]</options></address> | Memory modify; options W. L. O. V. N. DI | | MS <address> <data></data></address> | Memory set | | 06 | Display offsets | | [NO]PA[ <port number="">]</port> | Printer attach (and detach) | | PF[ <port number="">]</port> | Port format | | <pre>TM[<port number="">][<exit character="">[<trailing character="">]]</trailing></exit></port></pre> | Transparent mode | | I[R] [ <count>]</count> | Trace | | TT<br>breakpoint address> | Temporary breakboint trace | | VE[ <port number="">][;[<ptions>]=<text>]</text></ptions></port> | Verify (S-records): options X = C | | In | Vector initialize | | .A0A7 [ <expression>] .</expression> | Display/set address register | | .D0D7 [ <expression>]</expression> | Display/set data register | | .R0R6 [ <expression>]</expression> | Display/set relative offset register | | .PC [ <expression>]</expression> | program counter | | .SR [ <expression>]</expression> | Display/set status register | | .SSP [ <expression>]</expression> | | | .USP [ <expression>]</expression> | | #### 2.3 MVME115M MONOBOARD MICROCOMPUTER The MVME115M Monoboard Microcomputer is designed to function as a single CPU in a VMEbus system, or as an element in a multiprocessor VMEbus configuration. The module is shipped with an 8 MHz MC68010 16-bit microprocessor and an MC68451 Memory Management Unit (MMU). The MVME115M accepts up to 64Kb of onboard ROM/PROM and up to 48Kb of RAM devices with a combined maximum of 96Kb of onboard memory. It is recommended that the MVME025 or MVME050 System Controller modules be added to systems employing the MVME115M. The MVME115M can be configured to use Large-Scale Integrated (LSI) parts of a different maximum clock frequency than those supplied. Any frequency between 2.0 MHz and 10 MHz is supported. The actual frequency used must not exceed the rated maximum clock frequency of the MC68010 microprocessor, the MC68451 MMU, or the MC68320 Parallel Interface/Timer. The MVME115M can be used with or without an MC68451 MMU. To run software which does not use the MMU, it is not required to remove the MMU. On system reset, the MMU automatically configures itself to a transparent state, in which all logical addresses generated by the MC68010 microprocessor are mapped to identical physical addresses. Until the MMU registers are configured by software to implement a different mapping, no segment fault can be generated. The MVME115M contains two asynchronous serial ports, implemented primarily by a single SCN2681 Dual Asynchronous Receiver/Transmitter (DUART). This device provides two independent, full duplex, asynchronous transmitter/receiver channels which are independently programmable for operating mode, data format, and a baud rate ranging from 50.0 baud to 38.4 kilobaud. #### 2.3.1 Standard VERSAdos Configuration Figure 2-3 illustrates the standard jumper locations and settings of the MVME115M necessary to boot VERSAdos. Table 2-5 lists the jumpers and the required settings. Refer to the MVME115M User's Manual (MVME115M) to compare these settings with the factory-set configuration. #### 2.3.2 MVME115 Debug Monitor The MVME115M module utilizes the MVME115M Debug Monitor for debugging and diagnostic purposes. As a reference during debugging operations, the MVME115M Debug Monitor commands are listed in Table 2-6. FIGURE 2-3. MVME115M Jumper Header Locations TABLE 2-5. MVME115M VERSAdos-Supported Jumper Settings | JUMPER NUMBER | 2-5. MVME115M VERSAdos-Supported Jumper<br> | SETTING | |----------------------------------------------------------------------|----------------------------------------------|-----------------------------------------------------------------------------------------------------| | | DESCRIPTION | ======================================= | | | MVME115M VERSAdos JUMPER SETTINGS | | | J107 | ONBOARD MEMORY ROM/RAM SELECT | 1-2, 5-6, 8-9 | | J106 | ONBOARD MEMORY CHIP TYPE SELECT | 3-4, 5-6, 9-15,<br>11-17, 13-19,<br>21-22, 23-24,<br>25-26, 40-46,<br>42-48, 43-49,<br>51-52, 53-54 | | J125 | ONBOARD MEMORY ACCESS TIME SELECT | 1-9, 6-11-10, 7-12 | | J127 | BATTERY BACKUP SELECT | NO JUMPER | | J151 | PORT A DIRECTION SELECT | 1-2, 3-4 | | J152 | PORT B DIRECTION SELECT | 1-3, 2-4 | | J121<br>J128 | SERIAL PORT STATUS LINE CONFIGURATION SELECT | 1-2, 3-4<br>1-3 | | J113<br>J114<br>J115<br>J116<br>J117<br>J118<br>J119<br>J120<br>J126 | PARALLEL PORT CONFIGURATION SELECT | 1-2<br>NO JUMPERS<br>1-2<br>1-2, 3-4<br>1-4, 2-5<br>1-2<br>2-3, 5-6<br>2-20, 4-9, 7-8<br>1-2, 3-4 | | J150 | ONBOARD INTERRUPT LEVEL SELECT | 5-12, 19-26 | | J109<br>J110<br>J111 | VMEBUS REQUEST LEVEL SELECT | 2-3<br>2-4, 6-8<br>2-4, 5-6, 7-8 | | J129 | VMEBUS ARBITRATION OPTION SELECT | 1-2 | | J103 | RESET SELECT | 2-3 | | J104<br>J105 | BUS ERROR HANDLING SELECT | 1-2<br>1-2 | | J108 | VMEBUS INTERRUPT LEVEL SELECT | 1-8, 2-9, 3-10,<br>4-11, 5-12, 6-13,<br>7-14 | TABLE 2-5. MVME115M VERSAdos-Supported Jumper Settings (cont'd) | TADLE 2-5. | MANIETTON AEKSAGOS-20Phorted onlines Set | tings (cont d) | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | J101<br>J102 | STROBE TIMING SELECT | 2-3<br>5-10 | | J100 | CLOCK SPEED SELECT | 1-2 | | | MVME115M BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BGIIN* TO BGIOUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | TABLE 2-6. MVME115 Debug Monitor Command and Option Summary COMMAND DESCRIPTION | BF <address1> <address1> <address2> </address2></address1></address1> | |-----------------------------------------------------------------------| |-----------------------------------------------------------------------| TABLE 2-6. MVME115 Debug Monitor Command and Option Summary (cont'd) | | COMMAND | DESCRIPTION | |---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | (See description of | on of . <register> commands)</register> | | | | .A7 [ <expression>]</expression> | Display/set address register | | )>] /0 00. | .D7 [ <expression>]</expression> | Display/set data register | | | [ <expression>]</expression> | Display/set destination function code | | | <expression>]</expression> | Display/set program counter | | R7 [ | [ <expression>]</expression> | Display/set relative offset register | | | <expression>]</expression> | Display/set source function code | | | <pre></pre> <pre><pre></pre> <pre></pre> &lt;</pre> | Display/set status register | | | <pre><cexpression>]</cexpression></pre> | Display/set supervisor stack pointer | | >] [4]sn. | <expression>}</expression> | Display/set user stack pointer | | | <expression>]</expression> | Display/set vector base register | | Key Functions: | | | | (BREAK) | | Abort command or process | | (DEL) | | Delete character | | (CTRL-D) | | Redisplay line | | (CTRL-H) | | Delete character | | (CTRL-S) | | Suspend output; any character continues | | (CTRL-X) | | Cancel command line | | (RETURN) | | Process current/previous command line | #### 2.4 MVME120 SERIES MICROPROCESSOR MODULES The MVME120 series of microprocessor modules consists of the MVME120, MVME121, MVME122, and MVME123 modules. These modules are based on the MVME120 and are offered with several combinations of important features. The MVME120 VMEmodule is a high-performance microprocessor module that offers a solution for high-speed data processing, management, and control applications. The module contains an MC68010 MPU, MC68451 MMU, logical instruction cache, a serial debug terminal port, programmable tick timer, private ROM, and a large dynamic dual port RAM that may be loaded externally via the VMEbus. The MPU module, when used with a system controller module (such as the MVME025 or MVME050 system controllers or the MVME110-1 CPU module), satisfies system requirements ranging from simple, high-speed single processor applications to complex multiprocessor system architectures. Four configurations are available for the MVME120 family of microprocessor modules. The configurations are listed below: MVME120 10 MHz MC68010, 128Kb dynamic RAM, cache, MMU MVME121 10 MHz MC68010, 512Kb dynamic RAM, cache, MMU MVME122 12.5 MHz MC68010, 128Kb dynamic RAM, no cache, no MMU MVME123 12.5 MHz MC68010, 512Kb dynamic RAM, cache, no MMU #### 2.4.1 MVME120 Series Standard VERSAdos Configurations Figures 2-4 through 2-7 illustrate the jumper locations and settings required to allow VERSAdos to operate using the MVME120 series of microprocessor modules. Tables 2-7 through 2-10 list the jumpers and their required settings. Refer to the MVME120/MVME121/MVME122/MVME123 VMEbus Microprocessor Module User's Manual (MVME120) to compare these settings with the factory-set configurations. #### 2.4.2 MVME120 Debug Monitor The MVME120 family of microprocessor modules make use of the MVME120 Debug Monitor for debugging and diagnostic purposes. The MVME120 Debug Monitor commands are listed in Table 2-11. FIGURE 2-4. MVME120 Jumper Header Locations TABLE 2-7. MVME120 VERSAdos-Supported Jumper Settings | | ====================================== | | |---------------------------------|---------------------------------------------------------|------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME120 VERSAdos JUMPER SETTINGS | | | J2 | ACFAIL/SYSFAIL SELECT | 2-3 | | J3<br>J4 | VMEBUS REQUEST LEVEL SELECT VMEBUS REQUEST LEVEL SELECT | 1-3, 4-6, 5-7, 9-11<br>3-5, 4-6 | | J5 | ABORT SWITCH DISABLE SELECT | 1-2 | | J6 | RESET SWITCH DISABLE SELECT | 1-2 | | J7 | VMEBUS INTERRUPT CONNECTION SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14 | | J8 | ROM/EPROM DEVICE CONFIGURATION SELECT | 1-2, 5-7, 9-10,<br>11-12, 13-14 | | J9<br>J17 | CACHE CONFIGURATION SELECT CACHE CONFIGURATION SELECT | 2-3<br>NO JUMPERS | | J10 | MMU STROBE SELECT | 2-3 | | J11 | MMU ADDRESS STROBE SELECT | NO JUMPERS | | J12 | MAP DECODE TIME SELECT | 2-3 | | J13<br>J14<br>J16<br>J18<br>J19 | RAM CYCLE TIMING SELECT | 1-2<br>1-2<br>2-3<br>2-3<br>2-3 | | J15 | REFRESH PERIOD SELECT | NO JUMPER | | J20 | MSR BIT 1 SELECT | NO JUMPER | | J21 | MSR BIT 2 SELECT | 2-3 | | J22 | ROM ACCESS TIME SELECT | 7-8 | | J23 | RAM SIZE SELECT | 2-3 | | J24 | RESET VECTOR FETCH MODE SELECT | 1-2 | | J25 | LOCAL TIME-OUT SELECT | 1-2 | | TABLE 2-7. | MVME120 VERSAdos-Supported Jumper Sett | ings (cont'd) | |-----------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | ======================================= | MVME120 VERSAdos SWITCH SETTINGS | | | SWITCH NUMBER | | | | \$3-1<br>\$3-2<br>\$3-3<br>\$3-4 | AUTOBOOT SELECT BAUD RATE SELECT (12.5-10 MHz) RESET VECTOR FETCH SELECT RESET VECTOR FETCH SELECT | OPEN<br>CLOSED<br>CLOSED<br>OPEN | | | MVME120 BACKPLANE JUMPER SETTINGS | • | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | FIGURE 2-5. MVME121 Jumper Header Locations TABLE 2-8. MVME121 VERSAdos-Supported Jumper Settings | JUMPER NUMBER | DESCRIPTION | SETTING | |---------------------------------|---------------------------------------------------------|------------------------------------------| | | MVME121 VERSAdos JUMPER SETTINGS | ======================================= | | J2 | ACFAIL/SYSFAIL SELECT | 2-3 | | J3<br>J4 | VMEBUS REQUEST LEVEL SELECT VMEBUS REQUEST LEVEL SELECT | 1-3, 4-6, 5-7, 9-11<br>3-5, 4-6 | | J5 | ABORT SWITCH DISABLE SELECT | 1-2 | | J6 | RESET SWITCH DISABLE SELECT | 1-2 | | J7 | VMEBUS INTERRUPT CONNECTION SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14 | | J8 | ROM/EPROM DEVICE CONFIGURATION SELECT | 1-2, 5-7, 9-10,<br>11-12, 13-14 | | J9<br>J17 | CACHE CONFIGURATION SELECT CACHE CONFIGURATION SELECT | 2-3<br>NO JUMPERS | | J10 | MMU STROBE SELECT | 2-3 | | J11 | MMU ADDRESS STROBE SELECT | NO JUMPERS | | J12 | MAP DECODE TIME SELECT | 2-3 | | J13<br>J14<br>J16<br>J18<br>J19 | RAM CYCLE TIMING SELECT | 1-2<br>1-2<br>2-3<br>2-3<br>2-3 | | J15 | REFRESH PERIOD SELECT | NO JUMPER | | J20 | MSR BIT 1 SELECT | NO JUMPER | | J21 | MSR BIT 2 SELECT | 2-3 | | J22 | ROM ACCESS TIME SELECT | 7-8 | | J23 | RAM SIZE SELECT | 1-2 | | J24 | RESET VECTOR FETCH MODE SELECT | 1-2 | | J25 | LOCAL TIME-OUT SELECT | 1-2 | | TABLE 2-8. | MVME121 VERSAdos-Supported Jumper Setti | ings (cont'd) | | |-----------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME121 VERSAdos SWITCH SETTINGS | | | | | SWITCH NUMBER | | | | | S3-1<br>S3-2<br>S3-3<br>S3-4 | AUTOBOOT SELECT BAUD RATE SELECT (12.5-10 MHz) RESET VECTOR FETCH SELECT RESET VECTOR FETCH SELECT | OPEN<br>CLOSED<br>CLOSED<br>OPEN | | | MVME121 BACKPLANE JUMPER SETTINGS | | | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BGIIN* TO BGIOUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | | \_\_\_\_\_\_ FIGURE 2-6. MVME122 Jumper Header Locations TABLE 2-9. MVME122 VERSAdos-Supported Jumper Settings | IADLE | 2-9. MVME122 VERSAGOS-Supported Sumper | | |---------------------------------|---------------------------------------------------------|------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME122 VERSAdos JUMPER SETTINGS | | | J2 | ACFAIL/SYSFAIL SELECT | 2-3 | | J3<br>J4 | VMEBUS REQUEST LEVEL SELECT VMEBUS REQUEST LEVEL SELECT | 1-3, 4-6, 5-7, 9-11<br>3-5, 4-6 | | J5 | ABORT SWITCH DISABLE SELECT | 1-2 | | J6 | RESET SWITCH DISABLE SELECT | 1-2 | | J7 | VMEBUS INTERRUPT CONNECTION SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14 | | J8 | ROM/EPROM DEVICE CONFIGURATION SELECT | 1-2, 5-7, 9-10,<br>11-12, 13-14 | | J9<br>J17 | CACHE CONFIGURATION SELECT CACHE CONFIGURATION SELECT | NO JUMPER<br>NO JUMPER | | J10 | MMU STROBE SELECT | 2-3 | | J11 | MMU ADDRESS STROBE SELECT | 1-2 | | J12 | MAP DECODE TIME SELECT | 1-2 | | J13<br>J14<br>J16<br>J18<br>J19 | RAM CYCLE TIMING SELECT | NO JUMPER<br>2-3<br>1-2<br>1-2 | | J15 | REFRESH PERIOD SELECT | 1-2 | | J20 | MSR BIT 1 SELECT | 1-2 | | J21 | MSR BIT 2 SELECT | 2-3 | | J22 | ROM ACCESS TIME SELECT | 7-8 | | J23 | RAM SIZE SELECT | 1-2 | | J24 | RESET VECTOR FETCH MODE SELECT | 1-2 | | J25 | LOCAL TIME-OUT SELECT | 1-2 | | TABLE 2-9. | MVME122 VERSAdos-Supported Jumper Sett | ings (cont'd) | | | | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--|--|--| | JUMPER NUMBER | DESCRIPTION | SETTING | | | | | ======================================= | MVME122 VERSAdos SWITCH SETTINGS | | | | | | SWITCH NUMBER | | | | | | | S3-1<br>S3-2<br>S3-3<br>S3-4 | S3-2 BAUD RATE SELECT (12.5-10 MHz) S3-3 RESET VECTOR FETCH SELECT | | | | | | | MVME122 BACKPLANE JUMPER SETTINGS | | | | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | | | | FIGURE 2-7. MVME123 Jumper Header Locations TABLE 2-10. MVME123 VERSAdos-Supported Jumper Settings | JUMPER NUMBER | DESCRIPTION | SETTING | | | | | |---------------------------------|---------------------------------------------------------|------------------------------------------|--|--|--|--| | | MVME123 VERSAdos JUMPER SETTINGS | ======================================= | | | | | | J2 | ACFAIL/SYSFAIL SELECT | 2-3 | | | | | | J3<br>J4 | VMEBUS REQUEST LEVEL SELECT VMEBUS REQUEST LEVEL SELECT | 1-3, 4-6, 5-7, 9-11<br>3-5, 4-6 | | | | | | J5 | ABORT SWITCH DISABLE SELECT | 1-2 | | | | | | J6 | RESET SWITCH DISABLE SELECT | 1-2 | | | | | | J7 | VMEBUS INTERRUPT CONNECTION SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14 | | | | | | J8 | ROM/EPROM DEVICE CONFIGURATION SELECT | 1-2, 5-7 ,9-10,<br>11-12, 13-14 | | | | | | J9<br>J17 | CACHE CONFIGURATION SELECT CACHE CONFIGURATION SELECT | 2-3<br>NO JUMPERS | | | | | | J10 | MMU STROBE SELECT | 2-3 | | | | | | J11 | MMU ADDRESS STROBE SELECT | 1-2 | | | | | | J12 | MAP DECODE TIME SELECT | 1-2 | | | | | | J13<br>J14<br>J16<br>J18<br>J19 | RAM CYCLE TIMING SELECT | NO JUMPERS<br>2-3<br>1-2<br>1-2 | | | | | | J15 | REFRESH PERIOD SELECT | 1-2 | | | | | | J20 | MSR BIT 1 SELECT | NO JUMPER | | | | | | J21 | MSR BIT 2 SELECT | 2-3 | | | | | | J22 | ROM ACCESS TIME SELECT | 7-8 | | | | | | J23 | RAM SIZE SELECT | 1-2 | | | | | | J24 | RESET VECTOR FETCH MODE SELECT | 1-2 | | | | | | J25 | LOCAL TIME-OUT SELECT | 1-2 | | | | | | TABLE 2-10. | MVME123 VERSAdos-Supported Jumper Set | tings (cont'd) | |-----------------------------------------------|----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME123 VERSAdos SWITCH SETTINGS | | | SWITCH NUMBER | | | | S3-1<br>S3-2<br>S3-3<br>S3-4 | AUTOBOOT SELECT BAUD RATE SELECT (12.5-10 MHz) RESET VECTOR FETCH SELECT RESET VECTOR FETCH SELECT | OPEN<br>OPEN<br>CLOSED<br>OPEN | | | MVME123 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BG0IN* TO BG00UT* BG1IN* TO BG10UT* BG2IN* TO BG20UT* BG3IN* TO BG30UT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | \_\_\_\_\_\_ TABLE 2-11. MVME120 Debug Monitor Command and Option Summary | | COMMAND | DESCRIPTION | |----------|---------------------------------------------------------------------------------------------------------|-------------------------------------------| | 80 | [ <device>][,<controller>]</controller></device> | Bootstrap dump | | BF | <pre><address1> <address2> <pattern></pattern></address2></address1></pre> | Block fill . | | 番 | [ <device>][,<controller>]</controller></device> | Boot and halt | | BI | <address1> <address2></address2></address1> | Block initialize | | <b>B</b> | <address1> <address2> <address3></address3></address2></address1> | Block move | | 8 | [ <device>][,<controller>][,<string>]</string></controller></device> | Boot operating system | | [NO]BR | [ <address>[;<count>]]</count></address> | Set and remove breakpoints | | BS | <address1> <address2> '<literal string="">'</literal></address2></address1> | Block search; options;B;W;L | | | <pre><address1> <address2> <data>[<mask>][;<option>]</option></mask></data></address2></address1></pre> | | | 18 | <address1> <address2></address2></address1> | Block test | | CAC | CACHE | Manipulate MVME120 cache | | 2 | DC <expression></expression> | Data conversion/evaluation | | DF | | Display formatted registers | | | DU[ <port number="">] <address1> <address2> [<text>]</text></address2></address1></port> | Dump memory (S-records) | | 8 | GD [ <address>]</address> | Go direct | | 5]5 | G[0] [ <address>]</address> | Install breakpoints and go | | GT | <pre><temporary address="" breakpoint=""></temporary></pre> | Go until address | | 빞 | | Display commands/registers | | 100 | | Issue disk command | | IOP | | Issue physical read/write | | 10. | <pre>IOT [<device>][,<controller>]</controller></device></pre> | Teach disk controller a configuration | | Š | LO <port number=""> [;<options>] =<text></text></options></port> | Load (S-records) | | QW | ^ | Memory display; options ;DI ;S | | Ī | v | Memory modify; options ;W ;L ;O ;V ;N ;DI | | Ā | MP <address></address> | Map memory for disk | | WS | MS <address> <data></data></address> | Memory set (also ASCII) | | O. | | Offset register display | | [NO]PA | [NO]PA <port number=""></port> | Printer attach/detach | | PF. | PF <port number=""></port> | Port format | | ST | | Self-test | | TA | TA[ <port number="">]</port> | Terminal attach | | ₹ | TM <port number=""> [<exit character=""> [<trailing character="">]]</trailing></exit></port> | Transparent mode | | = | T[R] [ <count>]</count> | Trace | | TT | TT<br>breakpoint address> | Trace until address | | VE | VE <port number=""> [;<options>] =<text></text></options></port> | Verify (S-records) | | Ι / | | Vector initialize | | | | | TABLE 2-11. MVME120 Debug Monitor Command and Option Summary (cont'd) COMMAND DESCRIPTION | Process current/previous command line | | (RETURN) | |-----------------------------------------|----------------------------------|------------------| | Cancel command line | | (CTRL-X | | Suspend output; any character continues | | (CTRL-S) | | Delete character | | (CTRL-H) | | Redisplay line | | (CTRL-D) | | Delete character | | (DEL) | | Abort command or process | | (BREAK) | | | tions: | Key Functions: | | Display/set vector base register | [ <expression>]</expression> | . VBR | | Display/set user stack pointer | [ <expression>]</expression> | .USP | | Display/set supervisor stack pointer | [ <expression>]</expression> | .SSP | | Display/set status register | [ <expression>]</expression> | S. | | Display/set source function code | [ <expression>]</expression> | .SFC | | Display/set relative offset register | .R7 [ <expression>]</expression> | | | Display/set program counter | [ <expression>]</expression> | ج<br>5 | | Display/set destination function code | [ <expression>]</expression> | .DFC | | Display/set data register | .D7 [ <expression>]</expression> | 0. – <b>0</b> 0. | | Display/set address register | | | ## 2.5 MVMEO25 SYSTEM CONTROLLER MODULE The MVMEO25 System Controller module offers the bus arbitration, monitor, and utility functions usually required in a VMEbus system. This module combines clock generation, AC fail and system reset control, bus time-out and error control, and bus arbitration capabilities thus eliminating the need for these functions on other modules. The MVMEO25 is especially useful in multiprocessor and intelligent Direct Memory Access (DMA) applications, and is recommended in applications requiring the MVME115M Monoboard Microcomputer. # 2.5.1 MVMEO25 Standard VERSAdos Configuration Figure 2-8 illustrates the jumper locations and settings required for VERSAdos operation using the MVME025. Table 2-12 lists the jumpers and the required settings. Refer to the MVME025 VMEbus System Controller User's Manual (MVME025) to compare these settings with the factory-set configuration. FIGURE 2-8. MVME025 Jumper Header Locations | TABLE 2-12. MV | /ME025 | <b>VERSAdos-Supported</b> | Jumper | Settings | |----------------|--------|---------------------------|--------|----------| |----------------|--------|---------------------------|--------|----------| | IADLE Z- | 12. MVMEOZS VENSAUS-Supported C | | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME025 VERSAdos JUMPER SETTI | <u>INGS</u> | | | AC - FAIL POLARITY | NONE | | | BUS TIME-OUT | B,2 | | | BUS ARBITRATION | PRI | | | | | | | MVME025 BACKPLANE JUMPER SETTI | NGS | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | # 2.6 MVMEO50 SYSTEM CONTROLLER AND MVME701 I/O TRANSITION MODULES The MVMEO50 System Controller module is a combination system controller, system utility, and debug/diagnostic module. The MVMEO50 is designed to implement functions that are only required once in a multiprocessor system such as bus arbitration, bus time-out, system clock generation, and time-of-day clock. This capability eliminates the need to duplicate these functions on every processor in the system (although only one can be enabled). The MVMEO50 is typically used in an MVME120-based system. The MVME701 I/O Transition module is an optional, Euro-format, double-high companion board to the MVME050. The MVME701 may be attached via a ribbon cable to the MVME050 P2 connector, providing the connectors for the system controller's serial and parallel ports, and optionally, batteries for back-up of the MVME050 time-of-day clock. There are no active components on the MVME701. # 2.6.1 MVME050/701 Standard VERSAdos Configuration Figures 2-9 and 2-10 illustrate the jumper locations and settings for the MVME050 and MVME701 respectively. Tables 2-13 and 2-14 list the jumpers and their settings for these modules. Refer to the MVME050 System Controller/MVME701 I/O Transition Module User's Manual (MVME050) to compare these settings with the factory-set configurations. FIGURE 2-9. MVME050 Jumper Header Locations TABLE 2-13. MVME050 VERSAdos-Supported Jumper Settings | IADLE | 2-13. MVMC030 VERSAGOS-SUPPORTEG Gumper | | |-------------------|----------------------------------------------------------------------------|-------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME050 VERSAdos JUMPER SETTINGS | | | J1<br>J2 | EPROM BASE ADDRESS SELECT (A14-A23)<br>EPROM BASE ADDRESS SELECT (A24-A31) | USER-CONFIGURED<br>USER-CONFIGURED | | J8<br>J13<br>J27 | EPROM SIZE SELECT EPROM QUAD ENABLE SELECT EPROM ACCESS TIME SELECT | USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED | | J9<br>J10 | RAM BASE ADDRESS SELECT (A14-A23)<br>RAM BASE ADDRESS SELECT (A24-A31) | USER-CONFIGURED<br>USER-CONFIGURED | | J26<br>J14<br>J15 | RAM ACCESS TIME SELECT<br>RAM QUAD ENABLE SELECT<br>RAM SIZE SELECT | USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED | | J12 | AM1E ENABLE SELECT (EPROM QUAD 1) AM16 ENABLE SELECT (EPROM QUAD 2) | USER-CONFIGURED | | J3,J16,J17 | EPROM/RAM CONFIGURATION SELECT (EPROM/RAM QUAD 1) | USER-CONFIGURED | | J11,J18,J19 | EPROM/RAM CONFIGURATION SELECT (EPROM/RAM QUAD 2) | USER-CONFIGURED | | J4 | BUS TIME-OUT SELECT | 9-10 | | J5 | SERIAL CLOCK DAMPING/SHORTING SELECT | 1-2 | | J6 | SYSTEM CLOCK DAMPING/SHORTING SELECT | 1-2 | | J7 | SYSTEM CONTROLLER SELECT | 1-2, 3-4, 5-6, 7-8 | | J20 | I/O BASE ADDRESS SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14 | | J21 | TIME-OF-DAY CLOCK POWER AND BATTERY CHARGE SELECT | 1-2, 2-4, 7-8 | | J22 | SYSTEM FAIL OR GROUND FOR INTERRUPT SOURCE SELECT | 2-3 | | J23 | INTERNAL/EXTERNAL TRANSMIT CLOCK<br>SERIAL PORT 1 SELECT | NO JUMPER | | J24 | INTERNAL/EXTERNAL TRANSMIT CLOCK<br>SERIAL PORT 2 SELECT | NO JUMPER | | TABLE 2-13. MVME050 VERSAdos-Supported Jumper Settings (cont'd | TABLE 2-13. | MVME050 | VERSAdos-Supported | Jumper | Settings | (cont'd | |----------------------------------------------------------------|-------------|---------|--------------------|--------|----------|---------| |----------------------------------------------------------------|-------------|---------|--------------------|--------|----------|---------| | TABLE 2-13. | MANIEO20 AEKSMO2-20bboured admiter 2er | criigs (cont d) | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | J25 | DISPLAY BLANKING ENABLE SELECT | 1-2 | | J28 | RESET SWITCH DISABLE SELECT | 1-2 | | J29 | PRINTER ACKNOWLEDGE EDGE SELECT | 1-2 | | | MVME050 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | FIGURE 2-10. MVME701 Jumper Header Locations TABLE 2-14. MVME701 VERSAdos-Supported Jumper Settings | JUMPER NUMBER | DESCRIPTION | SETTING | |---------------|----------------------------------------|-----------------------------------------------------------------| | | DESCRIPTION | 3L111Md | | | MVME701 VERSAdos JUMPER SETTINGS | | | J5 | PORT 1 TO TERMINAL SELECT | NO JUMPERS | | J6 | PORT 1 TO MODEM SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10,11-12, 13-14<br>15-16, 17-18, 19-20 | | J11<br>J7 | PORT 1 CTS SELECT<br>PORT 1 DSR SELECT | 2-3<br>2-3 | | J9 | PORT 2 TO TERMINAL SELECT | 1-2, 3-4, 5-6, 7-8<br>9-10, 11-12, 13-14<br>15-16, 17-18, 19-20 | | J10 | PORT 2 TO MODEM SELECT | NO JUMPERS | | J8 | PORT 2 DSR SELECT | 2-3 | | J12 | PORT 2 CTS SELECT | 2-3 | #### CHAPTER 3 #### DYNAMIC MEMORY MODULES # 3.1 MVME200/201 64K/256K BYTE DYNAMIC MEMORY MODULES The MVME200 and MVME201 Dynamic RAM VMEmodules are designed to provide additional global RAM capacity in a VMEbus-based microcomputer system. Memory is addressable in byte or 16-bit word format. The modules feature odd parity error detection and asynchronous refresh circuitry. In addition, both modules allow memory block base addresses to be jumper-selectable and unused memory blocks to be jumper disabled. The MVME200 utilizes 16Kb dynamic RAM devices organized into four 16Kb blocks to create a total memory capacity of 64Kb. The MVME201 employs 64Kb devices in four 64Kb blocks to achieve 256Kb of memory. ## 3.1.1 Standard VERSAdos Configuration Figure 3-1 depicts the jumper locations for the MVME200 and MVME201 memory modules. Table 3-1 lists the jumper settings required to operate VERSAdos using the modules. Refer to the MVME200/201 64K/256K Byte Dynamic Memory Module User's Manual (MVME200) to compare these settings with the factory-set jumper configurations. #### 3.1.2 MVME201 Memory Address Settings The MVME201 module is organized into four 64Kb blocks of memory. Each block is addressable on any 64Kb boundary within the 16Mb address space. The following diagrams illustrate these blocks for various VMEmodules. | | A14* | A15* | A16* | A17* | A18* | A19* | A20* | | A22* | A23* | | |-------|------|------|-------|-------|-------|-------|-------|-------|------|------|------------------| | PIN # | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | L | | ROW C | 0 | 0 | o<br> | o<br> | o<br> | o<br> | o<br> | 0 | 0 | 0 | <br> 11<br> | | ROW B | Ò | Ó | Ó | Ó | Ò | Ó | Ó | 0<br> | 0 | 0 | 0 | | ROW A | o | 0 | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | <br><del> </del> | | | • | | | | | | | A21 | | | | Block Addressed at \$10000 (MVME101) | | A14* | A15* | A16* | A17* | A18* | | A20* | A21* | A22* | A23* | | |-------|----------|--------|-------|------|-------|-------|-------|-------|------|------|----| | PIN # | 1 | 2 | 3 | 4 | 5 | 6 | 7. | 8 | 9 | 10 | L | | ROW C | 0 | 0<br>1 | 0<br> | 0 | 0<br> | 0 | 0<br> | 0<br> | 0 | 0 | 11 | | ROW B | Ó | Ó | Ó | Ó | 0 | 0<br> | 0 | Ó | 0 | 0 | 0 | | ROW A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | I | | | <b>T</b> | | | | | A19 | | | | | | Block Addressed at \$40000 (MVME110-1) | | A14* | A15* | A16* | A17* | A18* | A19* | | A21* | A22* | A23* | | |-------|------|-------|-------|-------|-------|-------|-------|-------|------|------|---------| | PIN # | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | L | | ROW C | 0 | 0<br> | 0<br> | 0<br> | 0<br> | 0<br> | 0 | 0<br> | 0 | 0 | 11 | | ROW B | į o | Ó | Ó | Ó | Ó | Ó | 0<br> | ò | 0 | 0 | 0 | | ROW A | o | 0 | 0 | 0 | 0 | 0 | ó | 0 | 0 | 0 | '<br> - | | | • | | | | | | A20 | | | ' | l | Block Addressed at \$20000 (MVME120, MVME122) | | A14* | A15* | A16* | A17* | | A19* | A20* | A21* | A22* | A23* | | |-------|------|-------|-------|-------|-------|-------|--------|------|------|------|----------------| | PIN # | . 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | | | ROW C | 0 | 0<br> | 0<br> | 0<br> | 0 | 0<br> | 0<br>1 | 0 | 0 | 0 | 11<br> 11<br> | | ROW B | 0 | Ó | Ó | ó | 0<br> | Ó | ó | Ó | 0 | 0 | ' o | | ROW A | 0 | 0 | 0 | 0 | ó | 0 | 0 | 0 | 0 | 0 | <br> <br>+ | | | , | | | | A18 | | | | | | • | Block Addressed at \$80000 (MVME121, MVME123) | | A14* | A15* | A16* | | | A19* | A20* | A21* | A22* | A23* | | |-------|------|------|--------|--------|-----|------|--------|--------|------|------|---------------| | PIN # | . 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | | | ROW C | 0 | 0 | 0<br>I | 0 | 0 | 0 | 0<br>I | 0<br>I | 0 | 0 | +<br> 11<br> | | ROW B | 0 | 0 | 0 | 0<br>1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ROW A | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | '<br> ' | | | Ψ | | | A17 | A18 | | | | | | ī | Block Addressed at \$180000 (VME/10) # 3.2 MVME202/222-1/222-2 512K/1M/2M BYTE DYNAMIC RAM MODULES The MVME202, MVME222-1, and MVME222-2 are dynamic RAM VMEmodules used in VMEbus-based microcomputer systems to increase global memory. The modules use an 18-bit row organization to implement both byte and word accessing and upper or lower byte parity generation and checking. The four 18-device rows on the MVME202 hold 64K-bit memories providing a capacity of 512Kb. On the MVME222-1, two 18-device rows are filled with 256K-bit memories providing 1Mb of memory. The four 18-device rows on the MVME222-2 are filled with 256K-bit memories to achieve 2Mb of memory. ### 3.2.1 Standard VERSAdos Configuration The standard VERSAdos-supported jumper configuration is shown in Figure 3-2. The jumper settings are listed in Table 3-2. Refer to the MVME202/222-1/222-2 512K/1M/2M Byte Dynamic RAM User's Manual (MVME202) to compare these settings with the factory-set configurations. #### 3.2.2 MVME202/222 Memory Address Settings The 512Kb MVME202 memory module is organized as one 512Kb block of memory addressable on any 512Kb boundary within the 16Mb address space. The 1Mb MVME222-1 memory module is organized as one 1Mb block of memory addressable on any 1Mb boundary within the 16Mb address space. Similarly, the 2Mb MVME222-2 memory module is organized as one 2Mb block of memory addressable on any 2Mb boundary within the 16Mb address space. The following diagrams illustrate these blocks for various VMEmodules. | Ċ | JUMPER | R K | 2 | JL | IMPEF | R K | 1 | | |----------|--------|-----|----------|---------------|-------|-----|--------|-------------| | PIN 1 + | | 0 | PIN 1 | +<br> o | 0 | · | 0 | +<br> (A01) | | | 0 | 0 | A19 | <br> 0 | -0 | 0 | 0 | | | | 0 | 0 | | 0 | 0 | 0 | - O | A20* | | | 0 | 0 | | <br> 0<br> | 0 | 0 | -0 | A21* | | | 0 | 0 | | 0 | 0 | 0 | -0 | A22* | | PIN 11 - | 0 | 0 | PIN 21 | l<br> 0<br>+ | 0 | 0 | -0<br> | A23* | | 11 | • | | 7 111 21 | HI | | LO | W | • | MVME202 Block Addressed at \$80000 (MVME121, MVME123) MVME202 Block Addressed at \$180000 (VME/10) MVME222-1 Block Addressed at \$100000 (MVME121, MVME123) MVME222-2 Block Addressed at \$200000 FIGURE 3-1. MVME200/201 Jumper Header Locations | TABLE 3-1. | MVME200/201 VERSAdos Jumper and Ba | ackplane Settings | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | ======================================= | MVME201 VERSAdos JUMPER SETTING | <u>ss</u> | | J2 | BLOCK 1 BASE ADDRESS SELECT | USER-CONFIGURED | | J3 | BLOCK 2 BASE ADDRESS SELECT | USER-CONFIGURED | | J4 | BLOCK 3 BASE ADDRESS SELECT | USER-CONFIGURED | | J5 | BLOCK 4 BASE ADDRESS SELECT | USER-CONFIGURED | | J6 | LONGWORD DISABLE SELECT | NO JUMPER | | J7 | BUS ERROR DISABLE SELECT | 1-2 | | J8 | REFRESH DISABLE SELECT | 1-2 | | | | | | | MVME201 BACKPLANE JUMPER SETTING | <u>as</u> | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | FIGURE 3-2. MVME202/222 Jumper Header Locations | TARLE 3-2 | MVME202/222 | VERSAdos | Jumper | and | Racknlane | Settings | |------------|------------------|-------------|--------|-----|-----------|----------| | INDLE 3-2. | ויועויובעטע/ עעע | A E L'OHUU2 | oumper | anu | Dackprane | Sectings | | TABLE 3-2. | MVME2U2/222 VERSAUGS Jumper and Back | Talle Sectings | |---------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME202 VERSAdos JUMPER SETTINGS | | | K1 | BASE ADDRESS SELECT | USER-CONFIGURED | | К2 | MEMORY CAPACITY AND ADDRESSING MODE SELECT | USER-CONFIGURED | | К3 | TEST CONNECTOR | NO JUMPERS | | K4 | ACCESS TIME SELECT | 1-2, 7-8, 15-16 | | A21-A22<br>B4-B5<br>B6-B7 | MVME202 BACKPLANE JUMPER SETTINGS IACKIN* TO IACKOUT* BG0IN* TO BG00UT* BG1IN* TO BG10UT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | | B8-B9<br>B10-B11 | BG2IN* TO BG2OUT*<br>BG3IN* TO BG3OUT* | NO JUMPERS | ## 3.3 MVME210 RAM/ROM/EPROM MEMORY MODULE The MVME210 RAM/ROM/EPROM Memory Module provides users with a VMEbus-compatible board containing sixteen 28-pin sockets for installation of up to 128Kb of various types of byte-wide memory devices. Module sockets are organized into four word-oriented memory blocks and are capable of being populated with 1Kb, 2Kb, 4Kb or 8Kb RAM, ROM, or EPROM devices. The MVME210 is jumper-selectable for device type and device access time. In addition, the module is capable of jumper disabling for unused memory blocks. ### 3.3.1 Standard VERSAdos Configuration Figure 3-3 illustrates the jumper header locations for the MVME210 RAM/ROM/EPROM Memory Module. Table 3-3 lists the jumpers and their settings required to operate VERSAdos. Refer to the MVME210 RAM/ROM/EPROM Memory Module User's Manual (MVME210) to compare these settings with the factory-set configuration. FIGURE 3-3. MVME210 Jumper Header Locations TABLE 3-3. MVME210 VERSAdos Jumper and Backplane Settings | TABLE 3 | o. Hittelio tenonado damper ana backpri | | |-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------| | JUMPER NUMBER | <br>DESCRIPTION | SETTING | | | MVME210 VERSAdos JUMPER SETTINGS | | | J1<br>J9<br>J11<br>J10 | BLOCK 4 BASE ADDRESS SELECT<br>BLOCK 4 SIDE SELECT<br>BLOCK 4 LOW WORD DEVICE SELECT<br>BLOCK 4 HIGH WORD DEVICE SELECT | | | J3<br>J8<br>J13<br>J12 | BLOCK 3 BASE ADDRESS SELECT<br>BLOCK 3 SIDE SELECT<br>BLOCK 3 LOW WORD DEVICE SELECT<br>BLOCK 3 HIGH WORD DEVICE SELECT | USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED | | J2<br>J6<br>J15<br>J14 | BLOCK 2 BASE ADDRESS SELECT<br>BLOCK 2 SIDE SELECT<br>BLOCK 2 LOW WORD DEVICE SELECT<br>BLOCK 2 HIGH WORD DEVICE SELECT | USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED | | J4<br>J7<br>J17<br>J16 | BLOCK 1 BASE ADDRESS SELECT<br>BLOCK 1 SIDE SELECT<br>BLOCK 1 LOW WORD DEVICE SELECT<br>BLOCK 1 HIGH WORD DEVICE SELECT | USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED<br>USER-CONFIGURED | | J5 | ACCESS TIME SELECT | USER-CONFIGURED | | J18-J33 | RAM OR ROM SELECT | USER-CONFIGURED | | | MVME210 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS NO JUMPERS NO JUMPERS NO JUMPERS NO JUMPERS | # 3.4 MVME211 RAM/ROM/EPROM MEMORY MODULE The MVME211 RAM/ROM/EPROM Memory Module provides users with a VMEbus-compatible board containing sixteen 28-pin sockets for installation of up to 1Mb of various types of byte-wide memory devices. Module sockets are organized into two word-oriented memory blocks and are capable of being populated with 2Kb, 4Kb, 8Kb, 16Kb, 32Kb, or 64Kb JEDEC-standard RAM, ROM, or EPROM devices. The MVME211 is jumper-selectable for device type, device access time, and battery back-up standby power. The module also features jumper disabling for unused memory blocks. # 3.4.1 Standard VERSAdos Configuration Figure 3-4 illustrates the jumper header locations of the MVME210 RAM/ROM/EPROM Memory Module. Table 3-4 lists the jumpers and the settings required to boot VERSAdos on a system incorporating the module. FIGURE 3-4. MVME211 Jumper Header Locations | TABLE 3-4. | MVME211 | <b>VERSAdos</b> | Jumper | and | Backplane | Settings | |------------|---------|-----------------|--------|-----|-----------|----------| |------------|---------|-----------------|--------|-----|-----------|----------| | ======================================= | ======================================= | | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | | | | | MVME211 VERSAdos JUMPER SETTINGS | | | J1,J2,J6<br>J12,J14 | BLOCK 1 SIGNAL SELECT | USER-CONFIGURED | | J3,J4,J7<br>J13,J15 | BLOCK 2 SIGNAL SELECT | USER-CONFIGURED | | J5 | STANDBY POWER BATTERY BACKUP SELECT | USER-CONFIGURED | | J8-J11 | BLOCK 1 BASE ADDRESS SELECT | USER-CONFIGURED | | J16-J19 | BLOCK 2 BASE ADDRESS SELECT | USER-CONFIGURED | | J22 | BLOCK 1 CHIP SIZE SELECT | USER-CONFIGURED | | J20 | BLOCK 2 CHIP SIZE SELECT | USER-CONFIGURED | | J21,J23 | ACCESS TIME SELECT | USER-CONFIGURED | | | | | | | MVME211 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | #### CHAPTER 4 #### MASS STORAGE CONTROLLERS ## 4.1 MVME315 INTELLIGENT DISK CONTROLLER MODULE The MVME315 Intelligent Disk Controller Module combines in one double-high Eurocard VMEmodule a multiple floppy disk controller, a SASI bus interface. The module is designed for use in applications having intensive I/O or multiprocessor structures to reduce VMEbus traffic and to increase system throughput and mass storage capability. The MVME315 controls up to four 8-inch or 5-1/4 inch floppy disk drives in any mixed configuration and serves as an intelligent interface to the SASI bus. The Universal Intelligent Peripheral Controller (UIPC) is equipped with an MC68121 Intelligent Peripheral Controller, a Direct Memory Access (DMA) controller, 32Kb of dual-ported RAM for program data and storage of up to 12Kb of floppy and hard disk I/O data, and a full VMEbus interface featuring a VMEbus request and interrupt controller. ## 4.1.1 MVME315 Standard VERSAdos Configuration Figure 4.1 illustrates the jumper header locations of the MVME315 module. The jumper settings required to support VERSAdos are listed in Table 4.1. Refer to the MVME315 Intelligent Disk Controller Module User's Manual (MVME315) to compare these jumper settings with the factory-set configuration. #### 4.2 MVME320 DISK CONTROLLER MODULE The MVME320 Disk Controller Module is a double-high Eurocard VMEmodule for adding mass storage capability to a VMEbus-based system. The module provides high-performance DMA channels between system memory and Winchester hard disk drives and/or floppy disk drives. The MVME320 is intended for applications having intensive real-time disk I/O or multiprocessing structures designed to reduce VMEbus traffic and increase system throughput. The MVME320 controls mixed 5-1/4 inch and 8-inch disk drives. The module can simultaneously control up to two Winchester hard disks and two floppy disks or up to four floppy disk drives. The MVME320 supports single- and double-sided (single- and double-density) disks. All drives connected to the MVME320 must be soft-sectored. VERSAdos is released on double-sided, single-density, Motorola formatted 8-inch diskettes which are incompatible with the IBM format supported by the MVME320. Software purchased on 8-inch diskettes must be converted to a single-sided, single-density format before it can be read by a MVME320 Disk Controller. FIGURE 4-1. MVME315 Jumper Header Locations TABLE 4-1. MVME315 VERSAdos-Supported Jumper Settings | | ====================================== | | |-------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------| | JUMPER NUMBER | | SETTING | | | MVME315 VERSAdos JUMPER SETTINGS | | | K1<br>K2<br>K3 | VMEBUS GRANT IN SELECT<br>VMEBUS GRANT OUT SELECT<br>VMEBUS REQUEST LEVEL SELECT | 1-2<br>1-2<br>1-2 | | K6<br>K8 | VMEBUS INTERRUPT REQUEST LEVEL SELECT VMEBUS INTERRUPT REQUEST LEVEL SELECT | 3-8<br>1-6 | | K15 | . COMMAND CHANNEL BASE ADDRESS SELECT | 1-14, 2-13, 3-12,<br>4-11, 5-10, 6-9,<br>7-8 | | К7 | SYSTEM FAIL ENABLE SELECT | 1-2 | | K16 | DRIVE 3 SELECT ENABLE SELECT | 1-2 | | K10 | INTERRUPT CONTROLLER CONFIGURATION | 1-4 | | K9<br>K11 | LOCAL RAM CONFIGURATION LOCAL RAM CONFIGURATION | 1-2<br>2-4 | | K12<br>K13<br>K14 | LOCAL ROM CONFIGURATION LOCAL ROM CONFIGURATION LOCAL ROM CONFIGURATION | 1-7, 2-6, 3-4<br>1-4, 2-3<br>1-2 | | | MVME315 BACKPLANE JUMPER SETTINGS | | | B4-B5<br>B6-B7<br>B8-B9 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>JUMPER<br>JUMPER<br>JUMPER<br>NO JUMPERS | # 4.2.1 MVME320 Standard VERSAdos Configuration Figure 4-2 details the jumper header locations of the MVME320 Disk Controller module. Table 4-2 lists the jumper settings required to operate VERSAdos in a system employing the MVME320. Refer to the MVME320 Disk Controller User's Manual (MVME320) to compare these settings with the factory-set configuration. FIGURE 4-2. MVME320 Jumper Header Locations TABLE 4-2. MVME320 VERSAdos-Supported Jumper Settings | JUMPER NUMBER | DESCRIPTION | SETTING | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------| | | | ======================================= | | | MVME320 VERSAdos JUMPER SETTINGS | | | JWO | PROM SIZE SELECT | 5-6 | | JW1<br>JW2 | INTERRUPT REQUEST LEVEL SELECT INTERRUPT ACKNOWLEDGE LEVEL SELECT | 3-8<br>2-5, 3-6 | | JW3<br>JW4 | BUS REQUEST LEVEL SELECT<br>BUS GRANT LEVEL SELECT | 1-2<br>1-9, 2-10, 3-4<br>5-6, 7-8 | | JW5 | ADDRESS MODIFIER SELECT | 2-3 | | JW6 | MEMORY ADDRESS SELECT | 1-2, 3-4, 9-10 | | | | | | | MVME320 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>JUMPER<br>JUMPER<br>JUMPER<br>NO JUMPERS | #### 4.2.2 MVME702 Disk Interface Module The MVME702 Disk Interface Module is a double-high VMEmodule that is designed to function as an extension of the MVME320 Disk Controller Module. The MVME702 performs signal switching and provides standard disk cable connections for different drives. **4.2.2.1** MVME702 Standard VERSAdos Configuration. Figure 4-3 illustrates the jumper header locations of the MVME702 Disk Interface Module. Table 4-3 lists the MVME702 jumper settings required to operate VERSAdos with the MVME702. Refer to the MVME702 Disk Interface Module User's Manual (MVME702) to compare these settings with the factory-set configuration. FIGURE 4-3. MVME702 Jumper Header Locations | TABLE 4-3. MVM | 1E702 VERSAdo | s-Supported | Jumper | Settings | |----------------|---------------|-------------|--------|----------| |----------------|---------------|-------------|--------|----------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | |---------------|--------------------------------------------------------|-----------------------------------------------|--|--| | | MVME702 VERSAdos JUMPER SETTINGS | | | | | J4<br>J5 | SIGNAL TERMINATION SELECT<br>SIGNAL TERMINATION SELECT | 13-14<br>1-2, 3-4, 7-8,<br>9-10, 11-12, 13-14 | | | | J6 | SIGNAL TERMINATION SELECT | 3-4, 5-6, 7-8,<br>9-10, 11-12, 13-14 | | | #### 4.3 MVME420 SASI PERIPHERAL ADAPTER The MVME420 SASI Peripheral Adapter provides an interface between a microcomputer I/O Channel and a Shugart Associates SASI bus. The SASI bus supports the single-host, non-arbitrating, SA1400 disk controller implementation. The MVME420 is a single Eurocard VMEmodule that appears as eight 1-byte read/write registers on the I/O Channel address map. The base address is jumper-selectable. In addition, a maskable interrupt is jumper-selectable to any of three I/O Channel interrupt priority levels. Diagnostic read/write capability is provided to verify I/O Channel data paths. The MVME420 supports both 5-1/4 inch and 8-inch diskette media. However, VERSAdos is released on double-sided, single-density, Motorola-formatted 8-inch diskettes which are incompatible with the IBM format supported by the MVME420. Software purchased on 8-inch diskettes must be converted to a single-sided, single-density format before it can be used with an MVME420 module. #### 4.3.1 MVME420 Standard VERSAdos Configuration Figure 4-4 illustrates the jumper header locations of the MVME420 SASI Adapter Module. Table 4-4 lists the jumper settings required to operate VERSAdos using the MVME420. Refer to the MVME420 SASI Peripheral Adapter User's Manual (MVME420) to compare these settings with the factory-set configuration. FIGURE 4-4. MVME420 Jumper Header Locations | TABLE | 4-4. MVME420 VERSAdos-Supported Jur | mper Settings | |-----------------------------------------|-------------------------------------|-----------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | ======================================= | | ======================================= | | | MVME420 VERSAdos JUMPER SETTING | <u>GS</u> | | J2 | INTERRUPT LEVEL SELECT | 1-2 | | J3 | BASE ADDRESS SELECT | 7-8 | ### 4.4 M68RWIN1 WINCHESTER DISK CONTROLLER The M68RWIN1 Winchester Disk Controller is an intelligent interface between the Motorola I/O Channel and up to two Winchester disk drives and two floppy disk drives. The module is designed to operate with any host which uses an I/O Channel bus. The M68RWIN1 is available in two configurations -- one for 8-inch (SA1000-compatible) drives and one for 5-1/4 inch (ST500-compatible) drives. The M68RWIN1 performs high-level commands such as read/write data, format track, verify data, etc., and includes implied seeks, automatic track/head switching, alternate sectoring, and error checking. Data is sent between the host and the M68RWIN1 through interrupt-initiated block transfers, interrupt-initiated byte transfers, or by processor polling. ## 4.4.1 M68RWIN1 Standard VERSAdos Configuration Figure 4-5 illustrates the jumper header locations of the M68RWIN1 Winchester Disk Controller module. Table 4-5 lists the jumper settings of the M68RWIN1 required to operate VERSAdos. Refer to the M68RWIN1 Winchester Disk Controller User's Manual (M68RWIN1) to compare these settings with the factory-set configuration. FIGURE 4-5. M68RWIN1 Jumper Header Locations TABLE 4-5. M68RWIN1 VERSAdos-Supported Jumper Settings | JUMPER NUMBER | DESCRIPTION | SETTING | |-----------------------------------------|-----------------------------------------------------|-----------------------------------------| | ======================================= | ======================================= | ======================================= | | • | RWIN VERSAdos JUMPER SETTINGS | | | J7<br>J8 | WINCHESTER DATA TERMINATION SELECT | NO JUMPER<br>NO JUMPER | | J9 | POWER CONNECTION SELECT | 2-3 | | J10 | I/O CHANNEL INTERRUPT SELECT | 5-6, 7-8 | | J11 | I/O CHANNEL ADDRESS SELECT | 5-6 | | J16 | WINCHESTER & FLOPPY DISK DRIVE<br>PARAMETERS SELECT | 3-4, 7-8, 9-10,<br>11-12, 13-14, 15-16 | | J12 | | 1-2 | | J13 | | NO JUMPER | | J14 | | NO JUMPER | | J15 | | 1-2 | | J17 | | 1-2 | | J18 | | 1-2 | | J19 | | NO JUMPER | #### CHAPTER 5 ## I/O CHANNEL MODULES ## 5.1 MVME316 VMEBUS TO I/O CHANNEL INTERFACE The MVME316 VMEbus to I/O Channel Interface processes address, data, interrupt, and control signals to expand the resources of the VMEbus and provide a complete interface from the VMEbus to the I/O Channel. The MVME316 is designed to operate with any I/O Channel module available from Motorola Microsystems. The module features programmable interrupt vectors and VMEbus time-ou-capability. Base addresses for the interrupter and the I/O Channel are jumper-selectable. In addition, the MVME316 supports daisy-chained interrupt acknowledgements and a software-controlled I/O Channel reset mechanism. Two types of operations are possible through the MVME316 to the I/O Channel --normal polling and interrupt handling routines. Data transfer may be done using a normal polling operation to an I/O Channel access. Read or write instructions access odd bytes of the VMEbus memory map dedicated to the I/O Channel. ## 5.1.1 MVME316 Standard VERSAdos Configuration Figure 5-1 depicts the jumper header locations of the MVME316 module. Table 5-1 lists the jumper settings required to operate VERSAdos in a system employing the MVME316. Refer to the VMEbus to I/O Channel Interface User's Manual (MVME316) to compare these settings with the factory-set configuration. #### 5.2 MVME400 DUAL RS-232C SERIAL PORT MODULE The MVME400 Dual RS-232C Serial Port Module is an I/O Channel-compatible dual RS-232C serial interface module designed to expand the resources of an I/O Channel master to include one or two additional RS-232C serial data ports. The module conforms to a single 64-pin DIN 41612 standard connector; however, because of the wide front panel, the MVME400 occupies two module card slots. ### 5.2.1 Standard VERSAdos Configuration Figure 5-2 illustrates the jumper header locations of the MVME400. The jumper settings required to operate VERSAdos in a standard configuration are listed in Table 5-2. Refer to the Dual RS-232C Serial Port Module User's Manual (MVME400) to compare these settings with the factory-set configuration. FIGURE 5-1. MVME316 Jumper Header Locations | TARLE 5-1 | MVMF316 | VERSAdos-Supported | Jumper | Settings | |------------|-----------|---------------------|--------|------------| | IVDEF 3-T. | LIALITOIO | *LN3Au03-3uppor ceu | oumper | occurings. | | | 5-1. MVMES16 VERSAGOS-Supported Jumper S | | |-----------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION<br>==================================== | SETTING | | | MVME316 VERSAdos JUMPER SETTINGS | | | J1 | VMEBUS TIME-OUT ENABLE SELECT | 2-3 | | J2 | +5VDC EXTENSION TO I/O CHANNEL SELECT | 1-2, 3-4, 5-6 | | J3 | +12VDC EXTENSION TO I/O CHANNEL SELECT | 1-2 | | J4 | -12VDC EXTENSION TO I/O CHANNEL SELECT | 1-2 | | J5 | I/O CHANNEL BASE ADDRESS SELECT | NO JUMPERS | | J6 | SOFTWARE RESET ENABLE SELECT | 2-3 | | J7 | BIM AND SOFTWARE RESET ADDRESS SELECT (MSB) | 3-4 | | J8 | BIM AND SOFTWARE RESET ADDRESS SELECT (LSB) | 1-2, 3-4, 5-6 | | | MVME316 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BGOIN* TO BGOOUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS<br>NO JUMPERS | FIGURE 5-2. MVME400 Jumper Header Locations | TABLE 5-2. MVME400 VERSAdos-Supported Jumper Setting | TABLE 5-2. | MVME400 | VERSAdos-Supported | Jumper | Setting: | |------------------------------------------------------|------------|---------|--------------------|--------|----------| |------------------------------------------------------|------------|---------|--------------------|--------|----------| | | ====================================== | = | |---------------|--------------------------------------------------------------|----------------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME400 VERSAdos JUMPER SETTINGS | | | J2 | PORT 2 TXC SELECT | 1-2 | | J3<br>J4 | PORT 2 EXTERNAL CLOCK SELECT<br>PORT 2 INTERNAL CLOCK SELECT | NO JUMPERS<br>1-2, 3-4, 9-10,<br>11-12 | | J5 | INTERRUPT LEVEL SELECT | 3-5, 9-11, 15-17 | | J6 | BASE ADDRESS SELECT | .7-8 | | J7 | PORT 2 CTS FLOW CONTROL | 5-7, 6-8 | | J8 | PORT 2 TO MODEM SELECT | NO JUMPERS | | J9 | PORT 2 TO TERMINAL SELECT | 1-2, 3-4, 5-6, 7-8,<br>9-10, 11-12, 13-14,<br>15-16, 17-18, 19-20 | | J10 | BAUD RATE PORT 1 & 2 SELECT | 3-4, 5-6, 9-10,<br>11-12 | | J11 | PORT 1 TXC SELECT | 1-2 | | J12<br>J13 | PORT 1 EXTERNAL CLOCK SELECT<br>PORT 1 INTERNAL CLOCK SELECT | NO JUMPERS<br>1-2, 3-4, 9-10,<br>11-12 | | J14 | PORT 1 TO MODEM SELECT | NO JUMPERS | | J15 | PORT 1 TO TERMINAL SELECT | 1-2, 3-4, 5-6,<br>7-8, 9-10, 11-12,<br>13-14, 15-16,<br>17-18, 19-20 | | | PORT 1 CTS FLOW CONTROL | 5-7, 6-8 | ### 5.3 MVME410 DUAL PARALLEL PORT MODULE The MVME410 Dual Parallel Port Module is an I/O Channel-compatible dual printer interface module. The module is used to allow an I/O Channel master to include two printer interfaces. These interfaces may consist of one printer interface and a general-purpose 16-bit parallel data port, or two general-purpose 16-bit parallel data I/O ports. The MVME410 conforms to the single-wide VMEmodule form factor and connects to the I/O Channel via a 64-pin DIN standard connector. The MVME410 utilizes two MC6821 Peripheral Interface Adapter buffered ports. Each port is capable of driving two of four I/O Channel interrupt lines. ## 5.3.1 MVME410 Standard VERSAdos Configuration Figure 5-3 depicts the jumper locations of the MVME410 module. Table 5-3 lists the proper jumper settings required to operate the module in a standard configuration using VERSAdos. Refer to the Dual Parallel Port Module User's Manual (MVME410) to compare these settings with the factory-set configuration. ## 5.4 M68RAD1 REMOTE INTELLIGENT ANALOG-TO-DIGITAL CONVERSION MODULE The M68RAD1 Remote Intelligent Analog-to-Digital Conversion Module measures fast changing analog voltages with 12 bits of accuracy (unipolar operation). Four programmable full-scale voltage input ranges are available: 0-10 Vdc, 0-5 Vdc, 0-2.5 Vdc, and 0-1 Vdc. Analog current inputs may also be measured by installing appropriately sized voltage dropping (sensing) resistors. Conversion time is 33 us for a selected range. Short cycle operation is programmable for faster operation. An onboard precision reference power supply automatically checks the calibration of the module. An external trigger input is also provided to allow the user to measure waveforms at a particular point in time. The M68RAD1 is controlled by an onboard MC68B09 microprocessor. The module provides a choice of remote parallel or serial operation and 32 single-ended/16 differential A/D channels. I/O Channel address and serial communication port identification is selectable for the application of multiple boards on the I/O Channel and/or a serial I/O network. # 5.4.1 M68RAD1 Standard VERSAdos Configuration Figure 5-4 illustrates the jumper header locations of the M68RAD1 module. Table 5-4 lists the jumper settings required to operate VERSAdos using a system employing the M68RAD1 module. Refer to the Remote Intelligent Analog-to-Digital Conversion Module User's Manual (M68RAD1) to compare these settings with the factory-set configuration. FIGURE 5-3. MVME410 Jumper Header Locations TABLE 5-3. MVME410 VERSAdos-Supported Jumper Settings | | ======================================= | ======================================= | |-----------------------------------------|-----------------------------------------------------|-----------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | ======================================= | | ======================================= | | | MVME410 VERSAdos JUMPER SETTINGS | | | J2 | LED MONITOR | 2-3 | | J3<br>J4 | PORT 1 (P1CA2 P1PAO-P1PA7) DIRECTION | 1-2<br>1-2 | | J5<br>J6 | PORT 1 (P1CB2 P1PB0-P1PB7) DIRECTION | 1-2<br>NO JUMPERS | | J8<br>J9 | PORT 2 (P2CA2 P2PAO-P2PA7) DIRECTION | 1-2<br>1-2 | | J10<br>J11 | PORT 2 (P2CB2 P2PB0-P2PB7) DIRECTION | 1-2<br>NO JUMPERS | | J12<br>J13 | INTERRUPT SELECT (PORT 1) INTERRUPT SELECT (PORT 2) | 2-4, 8-10<br>2-4,8-10 | | J14 | BASE ADDRESS SELECT | NO JUMPERS | | J15 | LED CONTROL SELECT | 2-3 | FIGURE 5-4. M68RAD1 Jumper Header Locations | TABLE 5-4. M68RAD1 VERSAdos-Supported Jumper Setting | TABLE 5-4. | M68RAD1 | VERSAdos-Supported | Jumper | Setting | |------------------------------------------------------|------------|---------|--------------------|--------|---------| |------------------------------------------------------|------------|---------|--------------------|--------|---------| | JUMPER NUMBER | DESCRIPTION | SETTING | |-----------------------------|-------------------------------------------------|---------------| | | RAD VERSAdos JUMPER SETTINGS | | | J6<br>J8<br>J9<br>J7<br>J15 | SINGLE ENDED/DIFFERENTIAL MEASUREMENT<br>SELECT | | | J10<br>J11<br>J12<br>J13 | OPERATION POLARITY SELECT | | | J14 | 16/32 CHANNEL SELECT | | | J24 | I/O CHANNEL BASE ADDRESS SELECT | 1-2, 3-4, 5-6 | | J22 | I/O CHANNEL INTERRUPT LEVEL SELECT | | | J23 | SERIAL ADDRESS IDENTIFIER OPTIONS | | | J17<br>J18<br>J20<br>J21 | SERIAL INTERFACE DRIVER OPTIONS | | | J19 | SERIAL BAUD RATE SELECT | | | J16 | MPU INTERRUPT - E.O.C. SELECT | | ### 5.5 M68RIO1 REMOTE INPUT/OUTPUT MODULE The M68RIO1 Remote Input/Output Module provides for remote parallel operation at distances up to 12 feet from an I/O Channel Master. This module accepts any mix of up to 16 user-supplied Crydom Series 6, Opto-22, or other compatible solid state relay input and output modules. The M68RIO1 enables an I/O Channel interrupt to be generated simultaneously by up to eight solid state input modules. Block select jumpering allows the M68RIO1 to be configured for operation with any of 15 other I/O Channel-compatible modules. # 5.5.1 M68RI01 Standard VERSAdos Configuration Figure 5-5 illustrates the jumper header locations of the M68RIO1 module. Table 5-5 lists the jumper settings required to operate VERSAdos on a system employing the M68RIO1. Refer to the Remote Input/Output Module User's Manual (M68RIO1) to compare these settings with the factory-set configuration. FIGURE 5-5. M68RI01 Jumper Header Locations TABLE 5-5. M68RIO1 VERSAdos-Supported Jumper Settings | | ======================================= | | |-----------------------------------------|----------------------------------------------------|-----------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | ======================================= | | ======================================= | | | RIO VERSAdos JUMPER SETTINGS | | | J2 | I/O CHANNEL INTERRUPT REQUEST LEVEL SELECT (IRQ1A) | 1-2 | | J3 | I/O CHANNEL INTERRUPT REQUEST LEVEL SELECT (IRQ1B) | 1-2 | | J4 | I/O CHANNEL INTERRUPT REQUEST LEVEL SELECT (IRQ2A) | 1-2 | | J5 | I/O CHANNEL INTERRUPT REQUEST LEVEL SELECT (IRQ2B) | 1-2 | | J9 | BASE ADDRESS SELECT | 1-2, 3-4, 7-8 | ## 5.6 I/O CHANNEL ADDRESS SPACE Tables 5-6 through 5-11 consists of the I/O Channel address maps for several modules which utilize the I/O Channel including: M68RAD1 Remote Intelligent A/D Conversion Module M68RIO1 Remote Input/Output Module M68RWIN1 Winchester Disk Controller MVME400 Dual RS-232C Serial Port Module MVME410 Dual Parallel Port Module MVME420 SASI Adapter Module MVME435 Buffered 9-Track Magnetic Tape Adapter Module MVME600 Analog Input Module MVME605 Analog Output Module MVME610 AC Input Module MVME615 AC Output Module MVME616 AC Output Module MVME620 DC Input Module MVME625 DC Output Module These tables describe the configuration of up to four of each module without conflicts in addresses. The SYSGEN file CSYSTEMS.SYSTEM.CI contains the parameter that defines the I/O Channel base address. IOCBASE=\$FE6000, for an MVME110-1 system. Appendix C contains a list of all I/O Channel addresses. TABLE 5-6. Top Level I/O Channel Address Map | I/O ADDRESS DESCRIPTION OF USAGE 000 - OFF Refer to Table 5-7 100 - 1FF Refer to Table 5-8 200 - 2FF Reserved 300 - 3FF Reserved | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 100 - 1FF Refer to Table 5-8<br>200 - 2FF Reserved<br>300 - 3FF Reserved | | 400 - 4FF Reserved (RAD #4) 500 - 5FF Reserved (RAD #3) 600 - 6FF RAD #2 700 - 7FF RAD #1 800 - 8FF Reserved (VME605 #4) 900 - 9FF Reserved (VME605 #3) A00 - AFF VME605 #2 B00 - BFF VME605 #1 C00 - CFF Reserved (VME600 #4) D00 - DFF Reserved (VME600 #3) E00 - EFF VME600 #2 (with up to 5 VME601's) F00 - FFF VME600 #1 (with up to 5 VME601's) | TABLE 5-7. Map of I/O Channel Addresses 000 - OFF | I/O ADDRESS | DESCRIPTION OF USAGE | |-----------------------------------------|----------------------| | ======================================= | | | 000 005 | Defen to Table E 11 | | 000 - 00F | Refer to Table 5-11 | | 010 - 01F | Refer to Table 5-10 | | 020 - 02F | Refer to Table 5-9 | | 030 - 03F | Refer to Table 5-9 | | 040 - 04F | Refer to Table 5-9 | | 050 - 05F | Refer to Table 5-9 | | 060 - 06F | Refer to Table 5-9 | | 070 - 07F | Refer to Table 5-9 | | 080 - 08F | Reserved (VME410 #2) | | 090 - 09F | Reserved (VME410 #3) | | 0A0 - 0AF | Reserved (VME410 #4) | | 0BO - 0BF | Reserved (VME400 #4) | | 0CO - 0CF | Reserved (VME400 #3) | | ODO - ODF | VME400 #2 | | 0EO - 0EF | VME400 #1 | | OFO - OFF | VME410 #1 | | ======================================= | | TABLE 5-8. Map of I/O Channel Addresses 100 - 1FF | TABLE 5 0. Hap | of 1/0 chamic Madresses 100 1 | |------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------| | I/O ADDRESS | DESCRIPTION OF USAGE | | 100 - 11F<br>120 - 13F<br>140 - 15F<br>160 - 17F<br>180 - 19F<br>1A0 - 1BF<br>1C0 - 1DF<br>1E0 - 1FF | Reserved<br>Reserved<br>Reserved<br>Reserved<br>Reserved (VME435 #4)<br>Reserved (VME435 #3)<br>VME435 #2<br>VME435 #1 | TABLE 5-9. Map of I/O Channel Addresses 000 - 07F | TABLE 5 5: Hap 01 1/0 | | |----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | I/O ADDRESS | DESCRIPTION OF USAGE | | | | | 000 - 007<br>008 - 00F<br>010 - 017<br>018 - 01F<br>020 - 027<br>028 - 02F<br>030 - 037<br>038 - 03F<br>040 - 047<br>048 - 04F<br>050 - 057<br>058 - 05F | Refer to Table 5-11 Refer to Table 5-11 Refer to Table 5-10 Refer to Table 5-10 Reserved Reserved Reserved Reserved Reserved Reserved (RIO #4) Reserved (RIO #3) RIO #2 RIO #1 | | 060 - 067 | VME420 #2 | | 068 - 06F | RWIN #1 | | 070 - 077 | RWIN #2<br>VME420 #1 | | 078 - 07F | VIIC42U #1 | TABLE 5-10. Map of I/O Channel Addresses 000 - 01F | 17.022 3 10: 11ap 01 1/0 | | |-------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | I/O ADDRESS | DESCRIPTION OF USAGE | | | | | 000 - 001<br>002 - 003<br>004 - 005<br>006 - 007<br>008 - 009<br>00A - 00B<br>00C - 00D<br>00E - 00F<br>010 - 011 | Refer to Table 5-11 Reserved (VME620 #4) | | 012 - 013 | Reserved (VME620 #3) | | 014 - 015 | (VME620 #2) | | 016 - 017 | (VME620 #1) | | 018 - 019 | Reserved (VME610 #4) | | 01A - 01B | Reserved (VME610 #3) | | 01C - 01D | VME610 #2 | | 01E - 01F | VME610 #1 | TABLE 5-11. Map of I/O Channel Addresses 000 - 00F | I/O ADDRESS | DESCRIPTION OF USAGE | |-----------------------------------------|----------------------| | | | | 000 | Reserved | | 001 | Reserved | | 002 | Reserved | | 003 | Reserved | | 004 | Reserved (VME625 #4) | | 005 | Reserved (VME625 #3) | | 006 | VME625 #2` | | 007 | VME625 #1 | | 800 | Reserved (VME616 #4) | | 009 | Reserved (VME616 #3) | | 00A | VME616 #2 | | 00B | VME616 #1 | | 00C | Reserved (VME615 #4) | | 00D | Reserved (VME615 #3) | | 00E | VME615 #2 | | 00F | VME615 #1 | | ======================================= | | #### CHAPTER 6 #### MISCELLANEOUS VMEmodules ### 6.1 MVME300 GPIB CONTROLLER WITH DMA The MVME300 General Purpose Interface Bus (GPIB) Controller with Direct Memory Access (DMA) provides the user with a complete IEEE-488 bus listener/talker/controller interface for use with a VMEbus system. To a host on the VMEbus, the MVME300 appears as 32 adjacent 16-bit read/write registers with which data transactions are performed using the odd bytes only. Several MVME300 modules may be used as GPIB controllers in a system, each with its own IEEE-488 bus but all controlled by the VMEbus system controller. ## 6.1.1 MVME300 Standard VERSAdos Configuration Figure 6-1 illustrates the jumper header locations of the MVME300 module. Table 6-1 lists the jumper settings required to operate VERSAdos on a system employing the MVME300. Refer to the GPIB Controller with DMA User's Manual (MVME300) to compare these settings with the factory-set configuration. FIGURE 6-1. MVME300 Jumper Header Locations | TABLE 6-1. | MVME300 | VERSAdos- | Supported | Jumper | Settings | |------------|---------|-----------|-----------|--------|----------| |------------|---------|-----------|-----------|--------|----------| | TABLE | 6-1. MVME300 VERSAdos-Supported Jumper | Settings | |--------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME300 VERSAdos JUMPER SETTINGS | | | J1 | BGXIN* TO BGXOUT* BYPASS SELECT | NO JUMPERS | | J2 | BGXOUT* ENABLE SELECT | 7-8 | | J3 | BGXIN* ENABLE SELECT | 7-8 | | J4 | BRX* OUTPUT ENABLE SELECT | 7-8 | | J5 | BASE ADDRESS SELECT | 1-2, 3-4, 5-6, 7-8,<br>11-12, 13-14,<br>15-16, 17-18,<br>19-20 | | J6 | VMEBUS RELEASE COUNT REGISTER COUNT | 1-2, 3-4, 5-6, 7-8 | | J7 | TRI-STATE OR O.C. BUFFER SELECT | 1-2 | | J8 | FIFO RAM CONTROLLER MEMORY SIZE SELECT | 1-2 | | J9 | BCLR* ENABLE | 2-3 | | | MVME300 VERSAdos JUMPER SETTINGS | | | SWITCH NUMBER | | | | S1-1<br>S1-2<br>S1-3<br>S1-4<br>S1-5<br>S1-6<br>S1-7<br>S1-8 | SC<br>DAL<br>DAT<br>A4<br>A3<br>A2<br>A1<br>A0 | OPEN OPEN OPEN OPEN OPEN OPEN OPEN OPEN | | | MVME300 BACKPLANE JUMPER SETTINGS | | | A21-A22<br>B4-B5<br>B6-B7<br>B8-B9<br>B10-B11 | IACKIN* TO IACKOUT* BG0IN* TO BG0OUT* BG1IN* TO BG1OUT* BG2IN* TO BG2OUT* BG3IN* TO BG3OUT* | NO JUMPERS<br>JUMPER<br>JUMPER<br>JUMPER<br>NO JUMPERS | # 6.1.2 MVME300 Communication Between Processors (MVME110-1 or VME/10) The following is an example of using the MVME300 module to communicate between microprocessor-based systems (MVME110-1 or VME/10): # Configuration Information | | MVME300 (I) | MVME300 (II) | |-------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------| | VERSAdos<br>Processor A | "BUSA" Bus is not shareable ATW \$1F (system controller) Primary address: \$01 Board address: \$FF0400 | "BAOA" Device is not shareable ATW \$03 (talker/listener) Primary address: \$10 Board address: \$FF0400 | | VERSAdos<br>Processor B | N/A | "BUSA" Bus is not shareable ATW \$03 (talker/listener) Primary address: \$10 Board address: \$FF0400 | # Jumper Configurations J1 -- BGXIN\* TO BGXOUT\* Bypass Header J2, J3, J4 -- Bus Grant and Bus Request Headers | | MVME300 (I) | MVME300 (II) | |----|-------------|---------------| | J1 | none | 1-2, 3-4, 5-6 | | J2 | 7-8 | 7-8 | | J3 | 7-8 | 7-8 | | J4 | 7-8 | 7-8 | J5 -- VMEbus Board Base Address Header J5 all but 9, 10 all but 9, 10 ... J6 -- VMEbus Release Count Register (VBRCR) Count Header J6 1-2, 3-4, 5-6, 7-8 1-2, 3-4, 5-6, 7-8 J7 -- Three-State or Open-Collector Buffer Selection Header J7 1-2 1-2 J8 -- FIFO RAM Controller Memory Size Header J8 1-2 1-2 J9 -- Bus Clear BCLR\* Enable Header J9 2-3 2-3 ## DIP Switch | | <u>MVME300 (I)</u> | <u>MVME300 (II)</u> | |----------|--------------------|---------------------| | SC | closed | open | | dat | closed | closed | | dal | closed | closed | | A4 | open | closed | | A3 | open | open | | A2 | open | open | | A1 | open | open | | A0 | closed | open | | A2<br>A1 | open<br>open | open<br>open | NOTE: When configuring an MVME300 module that serves as a bus, the MVME300 driver reads the DIP switch to obtain the requested primary address. After the MVME300 driver reads the DIP switch, it takes the l's complement of the number read, and writes that l's complement into the TMS9914A address register. Thus, A4 closed and A3-A0 open as above will result in a primary address of \$10. Also works with: | J7 | 2-3 | |-----|-----| | J8 | 2-3 | | .19 | 1-2 | Processor A: WriteBAOA Processor B: ReadBUSA NOTE: When installing the MVME300 module in a VMEbus system, it is important to remember that whenever there are empty slots between modules in the VMEmodule chassis, jumpers must be installed on the VMEmodule backplane at the empty slot locations to jumper the bus arbitration signals and acknowledge signals across the empty slot(s). Refer to the appropriate hardware manual for further information. If this procedure is not followed, VERSAdos will not boot if the system where the MVME300 module has system controller capabilities. ### 6.2 MVME435A BUFFERED 9-TRACK MAGNETIC TAPE ADAPTER The MVME435A Buffered 9-Track Magnetic Tape Adapter is designed to add magnetic tape data storage capability to microcomputer system resources on the I/O Channel. The module provides the interface for one or two dual-density, 1/2-inch magnetic tape formatters allowing the addition of up to eight compatible tape drivers operating at speeds from 12.5 to 125 inches/second in the start/stop mode. The MVME435A provides software-selectable direct or buffered data transfer modes. In the buffered mode, direct data transfers of 4Kb per operation may occur between drives. ## 6.2.1 MVME435A Standard VERSAdos Configuration Figure 6-2 illustrates the jumper header locations of the MVME435A module. Table 6-1 lists the jumper settings required to operate VERSAdos on a system employing the MVME435A. Refer to the Buffered 9-Track Magnetic Tape Adapter User's Manual (MVME435A) to compare these settings with the factory-set configuration. FIGURE 6-2. MVME435A Jumper Header Locations | TABL | 6-2. MVME435A VERSAdos-Supported Jumpe | r Settings | |---------------|----------------------------------------|------------| | JUMPER NUMBER | DESCRIPTION | SETTING | | | MVME435A VERSAdos JUMPER SETTINGS | | | J2 | I/O CHANNEL INTERRUPT LEVEL SELECT | 1-2 | | J3 | BASE ADDRESS SELECT | NO JUMPERS | | J4 | DNBSY INTERRUPT SELECT | 1-2 | | J5 | INTERRUPT ENABLE SELECT | 3-4 | \_ ### CHAPTER 7 ## VME CHASSIS/CARD CAGES AND BACKPLANES #### 7.1 INTRODUCTION As a reference, the features of Motorola's chassis/card cages and backplanes for the VMEsystem are listed in this chapter. Figures 7-1 and 7-2 depict typical chassis and backplanes used in a VMEsystem. ## 7.2 VME CHASSIS/CARD CAGES ## 7.2.1 MVME940-1 Chassis/Card Cage The MVME940-1 Chassis/Card Cage is designed to help convert individual VMEmodule and I/Omodule components into a complete, compact, self-contained microcomputer system. Features of the MVME940-1 assembly include: . 19-inch rack-mounting card rack . Card slots and hardware for up to seven (double), and up to ten (single) modules. . One MVME921 9-slot VMEbus backplane (motherboard) . Two MVME922 5-slot I/O Channel backplanes (motherboards) . MVME910-3 plug-in power supply . DC wiring harness . I/O Channel signal cables # 7.2.2 MVME941 Chassis/Card Cage The MVME941 is a fully-assembled rack-mountable card cage chassis designed to support a variety of VMEmodules and I/Omodules. This chassis is supplied with all necessary hardware, connectors, and backplanes. The user must provide a power supply and cables. Features of the MVME941 include: . 19-inch rack-mountable card cage . Card guides and hardware for up to nine double, and ten single modules . One MVME921 9-slot VMEbus backplane (motherboard) . Two MVME922 5-slot I/O Channel backplanes (motherboards) . DC power cable assembly . I/O Channel cable assembly # 7.2.3 MVME942 Chassis/Card Cage The MVME942 is a fully-assembled rack-mountable card cage chassis which supports up to 20 VMEmodules. Features of the MVME942 include: . 19-inch rack-mountable card cage - . Card guides and hardware for up to 20 double VMEmodules - . One MVME920 20-slot VMEbus backplane (motherboard) FIGURE 7-1. VME Chassis, Typical Configuration FIGURE 7-2. VME Backplane 0 0 ## 7.2.4 MVME943 Chassis The MVME943 is designed to accommodate a variety of VME components in an efficient housing which can be tailored to a specific user's needs. The MVME943 assembly features: - . 19-inch rack-mountable chassis - . 400-watt power supply - . AC filter/circuit breaker module - . Power switch module, with DC voltage indicators (LEDs) - . AC wiring harness - . DC power terminal strip - . DC wiring harness - . MVME924 3-slot I/O Channel backplanes (2) - . MVME921 9-slot VMEbus backplane - . VMEbus backplane terminating modules (2) - . I/O Channel signal cable - Provision for mass storage unit (user-provided) ### 7.2.5 MVME944 Chassis The MVME944 is designed to accommodate a variety of options geared to meet the specific needs of a wide range of users. The MVME944 assembly features: - . 19-inch rack-mountable chassis - . 400-watt power supply - . AC filter/circuit breaker module - . Power switch module, with DC voltage indicators (LEDs) - . AC wiring harness - . DC wiring harness - . DC power terminal strip - . MVME920 20-slot VMEbus backplane, with terminator modules #### 7.3 VME BACKPLANES # 7.3.1 MVME920 20-Slot VMEbus Backplane The MVME920 20-slot VMEbus Backplane is designed for use with MVME944 chassis. Features of the MVME920 include: - . Suitable for operation at up to 30 MHz - . Provides all signal line and power line connections - . Faston power, sense, and ground connections - . Jumper areas for daisy-chain lines - . Plug-in bus termination, with active negative spike suppression - . DIN 41612C 96-pin sockets for VMEmodules # 7.3.2 MVME921 9-Slot VMEbus Backplane The MVME921 9-slot VMEbus Backplane is intended for use with a variety of VMEmodules and related components. Features of the MVME921 include: - . Suitable operation at up to 20 MHz - . Provides all signal line and power line connections - . Faston power and ground connections - . Jumper areas for daisy-chain lines - . Bus termination networks on both ends - . Test connector for bus signal access - . DIN 41612C 96-pin sockets ## 7.3.3 MVME922 5-Slot I/O Channel Backplane The MVME922 is designed to house I/Omodules in a VME chassis. This component includes: - . All signal and power connections - . Faston power and ground connectors - . DIN 41612C sockets - . Termination for all signal lines -- except INT 1-4\* and XACK\* - . Test connector for signal access ## 7.3.4 MVME924 3-Slot I/O Channel Backplane The MVME924 3-Slot I/O Channel Backplane is intended to house I/Omodules in a VME chassis configuration. Features of the MVME924 include: - . All signal line and power line connections - . Faston power and ground connections - . Bus termination, using 330-ohm/470-ohm SIP resistor packs - . DIN 41612C 96-pin sockets for I/Omodules #### CHAPTER 8 ### STANDARD SYSTEM CONFIGURATIONS #### 8.1 INTRODUCTION This chapter describes the standard VERSAdos configuration for five different VMEsystems. Each system is shown via a block diagram of the components supported in a standard VERSAdos system. ## 8.2 MVME101 SYSTEM Table 8-1 lists the SYSGEN map for the standard VERSAdos-supported system based on the MVME101 Monoboard Microcomputer. Figure 8-1 illustrates the standard MVME101 system. TABLE 8-1. MVME101 Standard System SYSGEN Map | FILENAME | TASK | PROC | SEG | ADDR | TCB | |----------------------------|----------------------|--------------|----------------------|----------------------------------|----------------------------------| | RMS.LO | | RMS | RMSO<br>RMS2 | \$010000<br>\$010100 | | | DRVLIB.LO<br>TERMLIB.LO | | DRVL<br>TERM | DRVL<br>TERM | \$014E00<br>\$015000 | | | M315DRV.LO<br>EPCIDRV.LO | | M315<br>EPCI | M315<br>EPCI | \$016300<br>\$017000 | | | PIADRV.LO<br>FHS.LO | .FHS | PIAD | PIAD<br>.FHS | \$017400<br>\$017A00 | \$018E00 | | IOS.LO<br>FMS.LO<br>EET.LO | .IOS<br>.FMS<br>&EET | | .IOS<br>.FMS<br>.EET | \$019000<br>\$01AB00<br>\$01FF00 | \$01A900<br>\$01FD00<br>\$024200 | | | alli | | .STT<br>&EET | \$020200<br>\$020500 | | | LDR.LO<br>IOI.LO | &LDR<br>.IOI | | &LDR<br>IOSG | \$024400<br>\$025B00 | \$025900<br>\$026C00 | | SYSINIT.LO | | SYSI | .IOI<br>.INT | \$026700<br>\$026E00 | | - FINAL PC VALUE = \$027800 - START-UP ADDRESS = \$026E00 TOTAL NUMBER OF USER DEFINED SYMBOLS = 210 ### O ERRORS ENCOUNTERED To create the above output, execute the VME101.COPYSGEN.CF file to a blank user number followed by STD.SYSGEN.CF. - = USE SYS=9100.VME101 - = SYS:9998.VME101 COPYSGEN.CF SYS,SYS,9110 - = STD.SYSGEN.CF FIGURE 8-1. Standard MVME101 System ## 8.3 MVME110-1 SYSTEM Table 8-2 lists the SYSGEN map for the standard VERSAdos-supported system based on the MVMEllO-1 Monoboard Microcomputer. Figure 8-2 illustrates the standard MVMEllO-1 system. TABLE 8-2. MVME110-1 Standard SYSGEN Map | | ====== | ===== | ===== | | | |------------|--------|-------|-------|-----------|-----------------------------------------| | FILENAME | TASK | PROC | SEG | ADDR | TCB | | ========== | | ===== | ===== | ========= | :====================================== | | | | | | | | | RMS.LO | | RMS | RMS0 | \$040000 | | | | | | RMS2 | \$040100 | | | DRVLIB.LO | | DRVL | DRVL | \$044E00 | | | TERMLIB.LO | | TERM | TERM | \$045000 | •. | | RWINDRV.LO | | RWIN | RWIN | \$046300 | | | M420DRV.LO | | M420 | M420 | \$046E00 | | | M315DRV.LO | | M315 | M315 | \$047700 | | | M320DRV.LO | | M320 | M320 | \$048400 | | | ACIADRV.LO | | ACIA | ACIA | \$049100 | | | MPSCSPR.LO | | MPSC | MPSC | \$049400 | | | MPSCDRV.LO | | MPSC | MPSC | \$049600 | | | PIADRV.LO | | PIAD | PIAD | \$049D00 | | | FHS.LO | .FHS | | .FHS | \$04A300 | \$04B700 | | IOS.LO | .IOS | | .IOS | \$04B900 | \$04D300 | | FMS.LO | .FMS | | .FMS | \$04D500 | \$052700 | | EET.LO | &EET | | .EET | \$052900 | \$056D00 | | | | | .STT | \$052C00 | | | | | | &EET | \$052F00 | | | LDR.LO | &LDR | | &LDR | \$056F00 | \$058400 | | IOI.LO | .IOI | | IOSG | \$058600 | \$05A300 | | | | | .IOI | \$059D00 | | | SYSINIT.LO | | SYSI | .INT | \$05A500 | | | | | | | | | <sup>-</sup> FINAL PC VALUE = \$05AF00 <sup>-</sup> START-UP ADDRESS = \$05A500 TOTAL NUMBER OF USER DEFINED SYMBOLS = 290 O ERRORS ENCOUNTERED FIGURE 8-2. Standard MVME110-1 System ## 8.4 MVME115M SYSTEM Table 8-3 lists the SYSGEN map for the standard VERSAdos-supported system based on the MVME115M Monoboard Microcomputer. Figure 8-3 is a block diagram of the standard MVME115M system. TABLE 8-3. MVME115M Standard SYSGEN Map | ====================================== | TASK | PROC | SEG | | TCB | |----------------------------------------|--------------|----------------------|----------------------|----------------------------------|-----------------------------------------| | | ====== | ===== | ===== | === <b>===</b> ===== | ======================================= | | RMS.LO | | RMS | RMS0<br>RMS2 | \$010000<br>\$010100 | | | DRVLIB.LO<br>TERMLIB.LO | | DRVL<br>TERM | DRVL<br>TERM | \$015200<br>\$015400 | | | M320DRV.LO<br>RWINDRV.LO<br>DARTSPR.LO | | M320<br>RWIN | M320<br>RWIN<br>DART | \$016700<br>\$017400<br>\$017F00 | | | DARTDRV.LO<br>P115DRV.LO | | DART<br>DART<br>P115 | DART<br>P115 | \$017F00<br>\$018100<br>\$018600 | | | FHS.LO<br>IOS.LO | .FHS<br>.IOS | 1113 | .FHS | \$018D00<br>\$018300 | \$01A100<br>\$01BD00 | | FMS.LO<br>EET.LO | .FMS<br>&EET | | .FMS<br>.EET | \$01BF00<br>\$021300 | \$021100<br>\$025700 | | 100.10 | 01.00 | | .STT<br>&EET | \$021600<br>\$021900 | *************************************** | | LDR.LO<br>IOI.LO | &LDR<br>.IOI | | &LDR<br>IOSG<br>.IOI | \$025900<br>\$027000<br>\$027D00 | \$026E00<br>\$028200 | | SYSINIT.LO | | SYSI | .INT | \$027000 | | <sup>-</sup> FINAL PC VALUE = \$028F00 <sup>-</sup> START-UP ADDRESS = \$028400 TOTAL NUMBER OF USER DEFINED SYMBOLS = 248 FIGURE 8-3. Standard MVME115M System ## 8.5 MVME120 FAMILY SYSTEMS Table 8-4 lists the SYSGEN map of the standard VERSAdos-supported systems based on the MVME120, MVME121, and MVME123 Microprocessor Modules. Table 8-5 describes the SYSGEN map for the MVME122 module. Figure 8-4 is a block diagram of the standard system based on all four modules. TABLE 8-4. MVME120 Family Standard SYSGEN Map | | | ===== | ===== | ******** | TOD | |-----------------------------------------|--------|-------|-------|------------|-----------------------------------------| | FILENAME | TASK | PROC | SEG | ADDR | TCB | | ======================================= | ====== | ===== | ===== | ========== | ======================================= | | RMS.LO | | RMS | RMS0 | \$001000 | | | | | | RMS2 | \$001100 | • | | DRVLIB.LO | | DRVL | DRVL | \$006200 | | | TERMLIB.LO | | TERM | TERM | \$006400 | | | M320DRV.LO | | M320 | M320 | \$007700 | | | M315DRV.LO | | M315 | M315 | \$008400 | | | RWINDRV.LO | | RWIN | RWIN | \$009100 | | | MFPDRV.LO | | MFPD | MFP | \$009C00 | | | MPCCDRV.LO | | MPCC | MPCC | \$00A000 | | | P050DRV.LO | | P050 | PRT5 | \$00A400 | | | FHS.LO | .FHS | | .FHS | \$00AB00 | \$00BF00 | | IOS.LO | .IOS | | .IOS | \$00C100 | \$00DB00 | | FMS.LO | .FMS | | .FMS | \$00DD00 | \$012F00 | | EET.LO | &EET | | .EET | \$013100 | \$017500 | | | | | .STT | \$013400 | | | | | | &EET | \$013700 | | | LDR.LO | &LDR | | &LDR | \$017700 | \$018000 | | IOI.LO | .101 | | IOSG | \$018E00 | \$01B500 | | | | | .IOI | \$01B000 | | | SYSINIT.LO | | SYSI | .INT | \$01B700 | | <sup>-</sup> FINAL PC VALUE = \$01C200 <sup>-</sup> START-UP ADDRESS = \$01B700 TOTAL NUMBER OF USER DEFINED SYMBOLS = 268 TABLE 8-5. MVME122 Standard SYSGEN Map | | | | ===== | | | |------------|--------|-------|-------|----------|----------| | FILENAME | TASK | PROC | SEG | ADDR | ТСВ | | | ====== | ===== | ===== | | | | RMS.LO | | RMS | RMS0 | \$001000 | | | | | | RMS2 | \$001100 | | | DRVLIB.LO | | DRVL | DRVL | \$006300 | | | TERMLIB.LO | | TERM | TERM | \$006500 | | | RWINDRV.LO | | RWIN | RWIN | \$007800 | | | TERMDRV.LO | | TERM | TERM | \$008300 | | | MPSCSPR.LO | | MPSC | MPSC | \$00BB00 | | | MPSCDRV.LO | | MPSC | MPSC | \$00BD00 | | | PIADRV.LO | | PIAD | PIAD | \$00C400 | | | FHS.LO | .FHS | | .FHS | \$00CA00 | \$00DE00 | | IOS.LO | .IOS | | .IOS | \$00E000 | \$00FA00 | | FMS.LO | .FMS | | .FMS | \$00FC00 | \$014E00 | | EET.LO | &EET | | .EET | \$015000 | \$019400 | | | | | .STT | \$015300 | • | | | | | &EET | \$015600 | | | LDR.LO | &LDR | | &LDR | \$019600 | \$01AB00 | | IOI.LO | .IOI | | IOSG | \$01AD00 | \$01BF00 | | | | | .IOI | \$01BA00 | | | SYSINIT.LO | | SYSI | .INT | \$01C100 | | | | | | | | | <sup>-</sup> FINAL PC VALUE = \$01CD00 <sup>-</sup> START-UP ADDRESS = \$01C100 TOTAL NUMBER OF USER DEFINED SYMBOLS = 237 FIGURE 8-4. Standard MVME120 Family System ## 8.6 VME/10 SYSTEM Table 8-6 lists the SYSGEN map for the standard VERSAdos-supported system based on the VME/10 Development System. Figure 8-5 is a block diagram of the standard VERSAdos-supported VME/10 system. TABLE 8-6. VME/10 Standard System SYSGEN Map | | ===== | ===== | ====== | | ======================================= | |------------|-------|-------|--------|-----------|-----------------------------------------| | FILENAME | TASK | PROC | SEG | ADDR | TCB | | | ===== | ===== | ===== | ========= | ======================================= | | | | | | | | | RMS.LO | | RMS | RMS0 | \$001000 | | | | | | RMS2 | \$001100 | | | DRVLIB.LO | | DRVL | DRVL | \$006000 | | | TERMLIB.LO | | TERM | TERM | \$006200 | | | M320DRV.LO | | M320 | M320 | \$007500 | | | M315DRV.LO | | M315 | M315 | \$008200 | | | RWINDRV.LO | | RWIN | RWIN | \$008F00 | | | MFPDRV.LO | | MFPD | MFP | \$009A00 | | | MPCCDRV.LO | | MPCC | MPCC | \$009E00 | | | P050DRV.LO | | P050 | PRT5 | \$00A200 | | | FHS.LO | .FHS | | .FHS | \$00A900 | \$00BD00 | | IOS.LO | .IOS | | .IOS | \$00BF00 | \$00D900 | | FMS.LO | .FMS | | .FMS | \$00DB00 | \$012D00 | | EET.LO | &EET | | .EET | \$012F00 | \$017300 | | | | | .STT | \$013200 | | | | | | &EET | \$013500 | | | LDR.LO | &LDR | | &LDR | \$017500 | \$018A00 | | IOI.LO | .IOI | | IOSG | \$018C00 | \$01B300 | | | | | .IOI | \$01AE00 | | | SYSINIT.LO | | SYSI | .INT | \$01B500 | | <sup>-</sup> FINAL PC VALUE = \$01C000 <sup>-</sup> START-UP ADDRESS = \$01B500 TOTAL NUMBER OF USER DEFINED SYMBOLS = 268 FIGURE 8-5. Standard VME/10 System ## 8.7 STANDARD CONFIGURATION PROCEDURE The following step-by-step instructions describe the procedure necessary to properly configure a specific set of hardware. Once the hardware is set and verified as being functional, the user will be able to boot the VERSAdos 4.4 operating system standard boot file. It is noted here that while the following set of instructions pertain specifically to configuring an MVME120-based system, these guidelines can be applied to other VMEsystem configurations. ## STEP 1 Clear a suitable working area large enough to comfortably set-up the hardware. Allocated space should be based on the number of boards, size of chassis, and size of periphals. ## STEP 2 Set-up the VME chassis and power supply. Plug chassis into suitable A/C outlet and verify with VOM that voltages are correct. ## STEP 3 Locate the MVME050 and MVME120 boards, then verify the jumpers are in the correct positions according to paragraphs 2.4 and 2.6 in this manual. ## REMOVE POWER FROM THE VME CHASSIS #### STEP 4 Plug the MVME050 into slot 1 of the VME chassis and remove all backplane jumpers in this slot. #### STEP 5 Plug the MVME120 into slot 2 of the VME chassis and remove all backplane jumpers in this slot. #### STEP 6 Connect a terminal to the RS-232C connector on the front of the MVME120. Apply power to the VME chassis and turn the terminal ON. Depress the reset button on the MVME050. This should result in the Debug Monitor prompt appearing on the screen: #### VME120 1.1> Test the local memory using the BI, BT or MD functions. Test the proper operation of all local peripherals such as the local serial port (in use at this point). The MVME050 serial ports and the MVME050 printer port can be tested by using the TA and PA commands. ## DISCONNECT POWER FROM VME CHASSIS ## STEP 8 Install the memory board(s) making sure they are jumpered somewhere in the address space from the end of MVME120 onboard memory to \$200000. It is generally more efficient to have VMEbus memory boards jumpered contiguous to the onboard memory of the processor. ## STEP 9 Apply power to VME chassis and test the memory boards just installed using the MVME120 Debug Monitor commands BI, BT, or MD. #### DISCONNECT POWER FROM THE VME CHASSIS ## STEP 10 Install the MVME320 disk controller. If empty slots are left between the MVME120 and the MVME320, then the user must jumper the daisy-chained Bus Grant and IACK pins on the VME backplane. Connect the control cable to the front of the MVME320 board J3 to the disk chassis. It is assumed that the user has some kind of box to contain the disk drives and power supply. If the MVME702 transistion board is being used, review Figure 4-2. Connect the hard disk data cable(s) to the MVME320 J1 and J2 connectors. ## STEP 11 Apply power to the VME chassis and then apply power to the disk drive box. If the hard disk drive has been initialized by a MVME320 controller, the MVME120 Debug Monitor command IOP may be used to read sectors to verify that the drive and controller are working properly. If the hard disk has not been initialized, install a known working 5-1/4 inch floppy disk in the floppy disk drive. Use the MVME120 Debug Monitor command IOP to read sectors from the floppy to ensure that the disk and controller are working properly. Locate the VERSAdos 4.4 package of 5-1/4 inch floppy disks. Install the disk that is MVME120-bootable into the 5-1/4 inch drive. Reset the MVME050 controller and answer "Y" to the MVME120 Debug Monitor initialize memory prompt. At the Debug Monitor prompt, enter the command: VME120 1.1>BO 2,0,VME120.VERSADOS.SY ## STEP 13 VERSAdos will clear the terminal screen and request a DEFAULT VOLUME and USER. Enter the name of the floppy disk that was booted from, then enter the date and time when requested. ## **STEP 14** Initialize the hard disk and commence copying the release floppy disk to the hard disk. The system is ready to operate. #### CHAPTER 9 #### SYSTEM MODIFICATIONS #### 9.1 INTRODUCTION This Chapter deals with modifications to the standard system configurations defined in Chapter 8. In order to make the task of configuring a VMEsystem using VERSAdos an orderly one, several questions must be answered by the user. Topics that need to be addressed include: - . Is memory located where it is supposed to be and does it function properly? - . Can the rotating disk media be read? - . Does the information in sectors 0 and 1 appear reasonable? If so, is the BH command in the Debug Monitor functioning? Once these issues are resolved, the Debug Monitor in use will read the Initial Program Loader (IPL) into memory. The user will then be able to boot the file VMExxx.VERSADOS.SY in order to receive the log-on message. This chapter deals with modifications to the standard system configurations defined in Chapter 8. In doing so, the information provided can be used answer the above questions so that the user may design a non-standard VERSAd system. There are only two files necessary to edit for most changes to stand VERSAdos-supported products. They are VERSADOS.CD and <system>.CNFGDRVR... where <system> is the catalog name of the board or system being used. For example, the file VME110.CNFGDRVR.CI is used for any MVME110-1 based system, and the file VME120.CNFGDRVR.CI is used for any MVME120-based system. #### 9.2 ADDING MEMORY Most of the standard system configurations support additional memory simply by jumpering the memory boards and plugging them into the VMEbus. There may be occasions when the standard VERSAdos does not support the desired target configuration. This section describes the methods used to implement various memory configurations. Each example describes the memory requirements of a particular application and the necessary steps required to meet the needs of the application. Example: Default VERSAdos for the MVME110-1 supports one memory partition up to \$200000. Target system requires memory from 0 to \$100000. Solution: Jumper memory boards, plug into VMEbus. No SYSGEN required. Example: Default VERSAdos for the MVME110-1 supports one memory partition up to \$200000. Target system requires memory from 0 to \$280000. Solution: Change parameter MEMEND3 from \$200000 to \$280000. Perform SYSGEN. Example: Default VERSAdos for the MVME101 supports one memory partition up to \$200000. Target system requires memory from \$10000 to \$80000, and from \$100000 to \$180000. Solution: Jumper memory boards, plug into VMEbus. No SYSGEN required. Example: Default VERSAdos for the MVME110-1 supports one memory partition up to \$200000. Target system requires memory from 0 to \$30000 for operating system memory as partition zero, \$30000 to \$80000 for user task memory as partition one, and \$80000 to \$C0000 as special memory partition and type known only to one task. Solution: Change SYSGEN parameter MEMEND1 from \$20000 to \$30000 resulting in partition zero from 0 to \$30000. Change MEMEND2 from 0 to \$30000 and MEMEND3 from 0 to \$80000 resulting in partition one from \$30000 to \$80000. Add a new MTENTRY macro in the file INITDAT.AG as follows. Define in the <system>.MTYPE.SI file entries for the new type and partition. The example below shows this file with the necessary additions. Perform SYSGEN. Example: Default VERSAdos for the MVME120 supports two memory partitions, 0 to \$27F00 and \$27F00 to \$200000. Target system requires memory from 0 to \$30000, \$40000 to \$80000, and \$100000 to \$140000. Memory gaps from \$30000 to \$40000 and from \$80000 to \$100000 present no problem. Solution: Jumper memory boards, plug into VMEbus. No SYSGEN required. ## 9.2.1 Memory Type Addresses The following listing shows the absolute address for the beginning and end of a new partition. This is shown for illustration only. ``` * &.MTYPE.SI - Memory type assignments for standard systems * System memory MTYPE$SRO EQU MTYPO read only MTYPE$SRW EQU MTYPO read/write User memory MTYPE$URO EQU MTYPO read only MTYPE$URW EQU MTYPO read/write Partition types MTYPE$PO EQU MTYPO partition #0 EQU MTYPO partition #1 MTYPE$P1 EQU MTYP7 partition #7 MTYPE$P7 MEMTABL EQU MTENTRY RAM, $00000, \MEMEND1, MTYPE$PO, PARTO, TOP \MEMEND2 MTENTRY RAM, \MEMEND2, \MEMEND3, MTYPE$P1, PART1, BOTTOM ENDC ****** new entry MTENTRY RAM, $80000, $C0000, MTYPE$P7, PART7, TOP ***** end new entry IFNE \$ROPT MTENTRY ROM,\ROMSADDR,\ROMEADDR ENDC MTEND DS.L 10 ENDMEMT EOU END ``` As stated earlier, this listing is shown for illustrative purposes only. The preferred method is to define two additional substitution parameters in the <system>.SYSTEM.CI file such as MEMEND4 and MEMEND5. The entry then would look as follows: MTENTRY RAM, \MEMEND4, \MEMEND5, MTYPE\$P7, PART7, TOP ## 9.2.2 Memory Configuration Files Files that are of interest to the system programmer when changing memory include: <system>.SYSTEM.CI where <system> is the catalog of the desired target system (i.e., VME/10, MVME110-1, MVME120 $\dots$ etc.). This file contains the MEMEND parameters for the existing default memory configurations. <system>.MTYPE.SI contains the memory type definitions and assignments for the <system>. The user may add new type equates in this file. &.INITDAT.AG contains all the SYSPAR definitions and memory table macros. This file is assembled at SYSGEN time. ## 9.2.3 Altering Memory Resources During the development and testing phase of a project it is necessary to support more features and devices than actually required in the final production version of the product. The following memory maps show the allocation of memory resources for systems used in different applications. Changes in the memory configuration are often required during the process of developing a target system. The left-side map details the memory configuration of Partition 0 for a standard VERSAdos 4.4 system. The free area of this partition will be allocated for TCBs and ASQs only. Partition 1 from \$27F00 to \$200000 would be free for user tasks. All tasks will reside in Partition 1, although their TCB will come out of part 0. As tasks are loaded, the free area decreases by .5Kb. The only other significant piece of system memory is allocated in partition 1 for the FMS Data segment. This is currently 32Kb. The right-side map shows the allocation of memory resources after a SYSGEN to configure a smaller system. By reducing the number of devices, the user saves 7Kb by eliminating drivers and 3k of IOSG space. The FMS data segment was reduced from 32Kb to 15Kb (not shown). The total saving realized from re-SYSGEN for this smaller system is approximately 20k. Due to space constrants, the relative size of the maps is distroted. | . ** | \*A | |--------------------|------------------------| | | | | >\$D00<br> Syspar | | | >\$1000 | >\$1000 | | RMS68K and Drivers | RMS68K and<br>Drivers | | | >\$8F00 | | >\$AB00 | System<br>Tasks<br>IOS | | System<br>Tasks | FHS FMS | | IOS<br>FHS<br>FMS | EET LDR | | EET<br>LDR | >\$17000 | | >\$18E00 | IOSG<br>5.75Kb | | IOSG<br>8.75Kb | >\$1A800 | | >\$1B900 | | | | | | | | | Partition 0 Free | Partition 0 | | 36.5Kb | 51.5Kb | | >\$24B00 | | | | <br> >\$25C00 | | System<br> Tables | System | | | Tables | | | 5Kb | | | | #### 9.3 ADDING SERIAL DEVICES Most of the standard VERSAdos configurations support multiple terminals; however, this may not be sufficient for a specific target system. The following example illustrates the method used to alter serial devices in a VERSAdos configuration without changing default parameters. Example: Standard VERSAdos does not support the MVME400 module on the I/O Channel. Target system requires three additional serial ports. Solution: Edit the <system>.CNFGDRVR.CI file. Locate the following series of commands and change as indicated. Perform SYSGEN. NVME400 = 2 (was 0) Number of MVME400 dual 7201 serial port boards IFGT \NVME400 NU400\$1 = 2 (was 0) Number of ports/users on MVME400 #1; max= 2/bd. NU400\$2 = 1 (was 0) Number of ports/users on MVME400 #2; max= 2/bd. **ENDC** #### 9.4 CHANGING DEFAULT PARAMETERS The following example provides a step-by-step procedure for altering standard default parameters of a particular system. Example: The user starts with the standard configurations for the MVME110-1 system and supported modules. Assume a smaller system is required for a particular application. Solution: The following is a step-by-step procedure for changing the standard configuration. ## STEP 1 Review the default system configuration and the particular application requirements to determine what must be eliminated and/or added. Default system supports: MVME110-1 RWIN1 1 HARD 2 FLOPPY'S VME420 W/SASI 5-1/4" 1 HARD 2 FLOPPY'S VME315 1 HARD 4 FLOPPY'S VME320 1 HARD 1 FLOPPY 1 LOCAL TERMINAL VME400 W/2 TERMINALS 1 VME410 W/1 PRINTER MEMORY FROM \$40000 TO \$200000 Application requires: MVME110-1 RWIN1 2 HARD 1 FLOPPY DON'T NEED SASI DON'T NEED VME315 DON'T NEED VME320 1 LOCAL TERMINAL DON'T NEED VME400 1 VME410 W/1 PRINTER MEMORY \$40000 TO \$100000 Now that the major hardware features of the system have been defined, the necessary software requirements need to be determined. Features to be examined include the total numbers of tasks expected to execute at one time, the number of files to be opened at once, and the sizes of various system data tables. A new feature of the VERSAdos 4.4 release enables the SYSGEN process to produce a SYMBOLS listing containing all of the symbols defined during SYSGEN, their final value, and where they are defined and used. This is a useful tool in determining what parameters to set and how large or small to make them. ### STEP 2 Select a user number on the development system to be used for SYSGEN. It is suggested that when performing multiple SYSGENs for various target configurations, a separate user account should be set aside for each configuration. ## Example: SYS:9100.VME101 Containing all files for MVME101 SYSGENs. SYS:9101.VME110 Containing all files for MVME110-1 SYSGENs. Assume the user number 9101 has been selected on the default volume of SYS. It may be desirable to delete all files from that account making it free for MVME110-1 work. Logon to that user number and set the catalog. Execute the COPYSGEN chain file to accumulate all files necessary for the SYSGEN. =SYS:9998.VME110.COPYSGEN.CF SYS,SYS,9101 This procedure generally takes about 15 minutes to copy all files. The above arguments are defined in VME110.COPYSGEN.CF. ``` =/* =/* VME110.COPYSGEN.CF - Chain file to copy files for SYSGEN =/* =/* FORCE CATALOG TO BE SET = VME110 =USE :.VME110 =/* This chain file copies those files required to perform a SYSGEN into a specified volume and user number. =/* =/* Invoke as: =VME110.COPYSGEN.CF arg1, arg2, arg3, arg4, arg5 =/* where: =/* Arql = 1 Source volume name (must specify) =/* Target volume name (must specify) =/* Arg3 = \3 Arg4 = \4 Target user number (must specify) =/* COPY option letter(s) (optional) =/* B = both copy & verify =/* P = pack files =/* Y = overwrite if file exists N = skip copy if file exists (default) =/* VT = verify & show only 1st difference =/* Arg5= \5 include PCDRV driver files (optional) =/* PCDRV = include them =OPT N ``` Using the Editor, review the &.VERSADOS.CD file for any parameter changes appropriate for the system configuration. Most parameters in this file are automatically calculated for a "typical" target. However, a target system that Motorola has defined as "typical" may not satisfy the requirements of the intended application. Review the descriptions of each parameter. Make any changes that appear appropriate at this time. This step is especially important when standard parameters do not meet the needs of the target system. For instance, this specific application may have a large number of tasks. Some of these tasks have a large number of data files open with different logical unit numbers. The following changes may be appropriate for this situation. | PARAMETE | <u>R</u> <u>ORIGINALLY</u> | CHANGED TO | COST/BENEFIT | |--------------------|-----------------------------------------------------------------|----------------------------------------|-----------------------| | UST<br>Reason: | Only one of the tasks | l<br>has need of a semaphore. | saves 256 bytes | | NOTASKS<br>Reason: | 6+(3*\totte<br>There are more tasks the<br>define with only one | han the formula would | | | LUMAX by | tes \totdsk+3 | 30 | cost 8 bytes<br>#lu's | | Reason: | Some of the tasks requ<br>would define with only | ire more than the formula three disks. | | NOFILES 2\*\notasks 3\*\notasks cost 176 bytes per file + 2Kb Reason: Some tasks may require more than three files but the average for all tasks is greater than 2. Compromise is 3. GST (\nofiles/14)+1 4 cost 256 bytes/page Reason: Some tasks have multiple shared segments which require an entry in GST. Change to 4 as a precaution. ### STEP 4 Using the editor, review the VME110.CNFGDRVR.CI file to configure the required boards and drivers. Make the following changes for the example system described in STEP 1. | <u>PARAMETE</u> | <u>R</u> <u>WAS</u> | CHANGE TO | COST/BENEFIT | |-----------------|--------------------------|--------------------------|---------------------------------------| | NHRWIN\$1 | 1 | 2 | save approx. 2-1/4Kb | | Reason: | Need two hard disks. | | (FMS buffers) | | NFRWIN\$1 | 2 | 1 | save approx. 2-1/4Kb | | Reason: | Need only one floppy dis | sk. | (FMS buffers) | | NVME315 | 1 | 0 | eliminate driver and | | Reason: | System does not require | MVME315 disk controller. | system space 4Kb | | NVME320 | 1 | 0 | eliminate driver and | | Reason: | System does not require | MVME320 disk controller. | system space 4Kb | | NVME400 | 1 | 0 | eliminate device- | | | | | dependent driver and system space 500 | | Reason: | Only need one terminal p | bytes bort. | | | NVME420 | 1 | 0 | eliminate device- | | | | | dependent driver and system space 4Kb | | Reason: | System does not require | MVME420 disk controller | | ## STEP 5 The system is now ready to execute SYSGEN. For convenience, use the supplied STD.SYSGEN.CF file which has pre-defined all of the arguments. The calling sequence is =STD.SYSGEN.CF. With the SYSGEN completed, there is still a VME110.VERSADOS.SY file under user :9101. Copy this file to a bootable MVME110-1 5-1/4 inch diskette and boot up the target system. If the user has been developing and performing SYSGENs on a MVME110-1 system, testing can be done on this system but the user should boot directly from the 9101 account rather than copying to the default user 0 file. In case something has gone wrong in the SYSGEN process, do not overwrite the existing VERSADOS.SY file until the new one has been tested. The command from the MVME110-1 Debug Monitor is: VMEbug 4.0 >BO 0,0,:9101.VME110.VERSADOS.SY ### THE SYSTEM IS UP AND RUNNING! Review: The files necessary to change any of the standard Motorola-supported system configurations are: &.VERSADOS.CD contains parameters common to all system configurations device drivers for the boards specified. #### 9.5 ADDING AN OPERATING SYSTEM TASK TO THE VERSAdos SYSTEM The following steps describe the procedure required to add an operating system task to a standard VERSAdos 4.4 system. ## STEP 1 Write the code necessary to handle the desired operating system functions. This could be a particular task which handles events from several user tasks and sends events to other user tasks based on the inputs received. This could be a Server for a TRAP #'x' where 'x' is a number other the those currently assigned to VERSAdos. TRAPS #0-4 are currently used by VERSAdos. #### STEP 2 Debug the task. This could be accomplished prior to building the task into the operating system by using the firmware debugger for the system processor module. Add the necessary commands to the file CNFGTASK.CI. The following listing shows the parameters that need to be confirmed. ``` &.CNFGTASK.CI MSG OPERATING SYSTEM TASK SWITCHES MSG MSG FHS$IOS$ = 1 Set =0 for skip FHS/IOS module, not =0 to include it Set =0 for skip FMS module, not =0 to include it FMS$ = 1 Set =0 for skip EET module, not =0 to include it EET$ Set =0 for skip LDR module, not =0 to include it LDR$ = 1 ****** NEWTSK$ = 1 EXAMPLE ******* ``` The parameter NEWTSK\$ will then be used in the file IFTASK.CI to determine if the task should be included in the system. ``` &. IFTASK.CI MSG MSG PROCESS O/S TASKS AS REQUIRED MSG IFNE \FHS$IOS$+\FMS$ SUBS GET.TASKID.AG ASM GET.TASKID.AG,GET.TASKID.RO,\ASMLS;R IFEQ \ASMLSW =COPY \ASMLS,\WORKLS;A ENDC ENDC IFNE \FHS$IOS$ INCLUDE FHSIOS.VERSADOS.CI ENDC IFNE \FMS$ INCLUDE FMS.VERSADOS.CI ENDC IFNE \EET$ EET. VERSADOS. CI INCLUDE ENDC ***** IFNE \NEWTSK$ INCLUDE NEWTASK. VERSADOS. CI ENDC ***** IFNE \LDR$ IFNE UMM/ INCLUDE MMULDR. VERSADOS. CI ENDC ``` ``` IFEQ \MMU INCLUDE NOMMULDR.VERSADOS.CI ENDC ENDC ``` Build the necessary NEWTASK.VERSADOS.CI file containing the commands to build the new task into the system. ``` NEWTASK. VERSADOS. CI MSG NEWTASK -- TRAP X SERVER MSG MSG TASK &.NEWTASK.LO,.NEW STATE - 'DORM' = 'CRIT' ATTRIB = 'RTIM' ATTRIB = 'SYST' ATTRIB PRIORITY = $D0 NEW load addr. NEWSTR NEW ASR entry point = *+2 NEWASR SUBS &.NEW.LG LINK &.NEW.LG IFEQ \LINKLSW =COPY \LINKLS,\WORKLS;A ENDC END NEW * Build VERSAdos <system>.OSLIST.AG OSLIST.NEW.SI, OSLIST.AG; A * Build VERSAdos patch chain file <system>.VERSAPT.CF VERSAPT.NEW.CF, VERSAPT.CF; A ``` ## STEP 5 Perform SYSGEN and test. If the I/O Initializer (IOI) task is to perform such duties as allocating data segments and starting the target task, the user must add the appropriate command and data blocks to <system>.OSLIST.AG ``` * * OSLIST.BEGIN.AG * XDEF OSMTBL XDEF OSMEND * OPERATING SYSTEM MODULE TASK NAMES ``` # MOTOROLA ``` Included equate files: INCLUDE &.IOE.EQ INCLUDE &.EXE.EQ INCLUDE &.NIO.EQ INCLUDE &.FME.EQ &.FMI.EQ INCLUDE NOLIST INCLUDE &.IOE.EQ INCLUDE &.EXE.EQ &.NIO.EQ INCLUDE &.FME.EQ INCLUDE INCLUDE &.FMI.EQ LIST SECTION 1 The following NOP is required if the user has elected to eliminate all modules from OSLIST such that it becomes a null file. Since LINK 1.6 has difficulty in linking a null module that has XREF and XDEF references, the NOP is here to keep this module from being a null module. NOP OSMTBL: FHS STARTUP VALUE DC.B $20 This value will determine (low to high) the order a task is to be started by IOI. BIT NUMBER DC.B 1 This value represents a bit number that must be set by the task being initiated IOI will attempt to start the next task. Along with STARTUP VALUE, this allows the coordination of bringing up system tasks at boot-time in an orderly process. The offset System Value Table System Task Config- uration Flag (SVTSTCF) is where the bit must be set. If the system task does not require boot-time coordination, the bit number must be set to $FF. ``` | * | DC.L<br>DC.B<br>DC.B<br>DC.L<br>DC.L | FHSID<br>IOSESS<br>0<br>0<br>0<br>0 | FHS TASK NAME SESSION NO ASQ WAS REQUESTED | |---------------------------------------|--------------------------------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | *<br>*<br>* | DC.L 0,0,0,0 * XDEF OESIZE * IOS | NO DATA SEGMENT NEEDED | | | IOSXXX:<br>* | DC.B | \$30 | STARTUP VALUE This value will determine (low to high) the order a task is to be started by IOI | | * * * * * * * * * * * * * * * * * * * | DC.B | 0 | BIT NUMBER This value, if present, represents a bit number that must be set by IOS before IOI will attempt to start the next task. Along with STARTUP VALUE, this value allows the coordination of bringing up system tasks at boot-time in a orderly process. The offset SVTSTCF is where the bit must be set. If the system task does not require boot-time coordination, the bit number must be set to \$FF. | | | DC.L<br>DC.L | IOSID<br>IOSESS | IOS TASK NAME<br>SESSION | | * | DC.B<br>DC.B<br>DC.L<br>DC.L<br>DC.W | 0<br>0<br>0<br>0 | NO ASQ WAS REQUESTED | | * | DC.L | 0,0,0,0 | NO DATA SEGMENT NEEDED | | OESIZE | EQU<br>XDEF | *-IOSXXX<br>FMSDLEN | | | *<br>* | FMS | | | ## (M) MOTOROLA | * | DC.B | \$10 | STARTUP VALUE This value will determine (low to high) the order a task is to be started by IOI | |---------------------------------------|--------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | * * * * * * * * * * * * * * * * * * * | DC.B | 2 | BIT NUMBER This value, if present, represents a bit number that must be set by FMS before IOI will attempt to start the next task. This, along with STARTUP VALUE, allows the coordination of bringing up system tasks at boot-time in an orderly process. The offset SVTSTCF is where the bit must be set. If the system task does not require boot-time coordination, the bit number must be set to \$FF. | | * | DC.L<br>DC.L | FMSID<br>IOSESS | FMS TASK NAME<br>SESSION | | | DC.B<br>DC.B<br>DC.L<br>DC.L<br>DC.W | 0<br>0<br>0<br>0 | NO ASQ WAS REQUESTED | | * FMSDLEN | DC.W<br>DC.L<br>DC.L<br>DC.L | SGOPPA<br>SGATRW+SGATSS<br>FMSD<br>O | OPTIONS-LOG. ADDR=PHYS. ADDR. ATTRIBUTES SEG. NAME LOGICAL ADDRESS SEGMENT LENGTH | | ^<br>*<br>* | OSLIST.EN | D.AG | | | OSMEND | EQU *<br>END | OSMTBL | END OF TABLE | ## 9.6 ADDING USER-WRITTEN COMMANDS TO THE SESSION MANAGER (EET) The following step-by-step procedure is a simplified approach to adding user-written commands to the Session Manager task called &EET. ## STEP 1 Write the code necessary to implement the new command. This code should be tested and debugged as a task using SYMbug. ## STEP 2 \* Add the acronym for the new command to the file CMDLIST.AG. This file will be assembled at SYSGEN time. The user should XDEF the entry point to the command handling module here and XREF the entry point at the beginning of the module containing the code. #### &.CMDLIST.AG ``` 3,27 SESSION CONTROL COMMAND LIST CMDLIST IDNT SECTION 8 XDEF CMDACCTT CMDPWVAL XDEF COMTSKNO XDEF XDEF DEFAULT XDEF EET GFLG EETSBAT XDEF XDEF INDFVOLN XDEF INITPAR INSWORD XDEF XDEF LODRETRY XDEF LOGM LOGNTERM XDEF XDEF LOGTRYNO XDEF PATCH XDEF SYSCMD XDEF SYSCMDS SYSOPT XDEF XDEF SYSTBEND XDEF TIMECNT XDEF UCBMAXLU XDEF UCBPRIBT UCBPRICH XDEF UCBPRILI XDEF ``` \*\* EQUATES # M MOTOROLA ``` EQU SPCCMD \SPCCMD EQU \CHAINBAT CHAINBAT SECURITY EQU \SECURITY EQU TOTTERM \TOTTERM CONBATCH EQU \CONBATCH BATCHPGE EQU \BATCHPGE EQU \NOLOGON NOLOGON EQU \MAXLU MAXLU TERMOCNT EQU \TERMOCNT EQU BATDLY \BATDLY NOLOGONS EQU \NOLOGONS '&EET' EQU EETPNAM DECLARE SHAREABLE DCLSHR EQU 7 EQU GET ASQ GTASQ 31 READ ONLY SGATRO EQU $4000 EQU $1000 GLOBALLY SHAREABLE SGATGS EQU AQSTQE 1 BIT POSITION FOR INITIALIZING CHAINFILE EOU SOSYSMSG 1 CLAIM UNCLAIMED BREAKS IOUCBK EQU $8001 INITIAL SECURITY LEVEL (NONE) ISECLVL EQU 0 INITIAL SECURITY WORD PART 1 ISWORD1 EQU 0 EQU INITIAL SECURITY WORD PART 2 ISWORD2 0 NO. BYTES SCT EVENTS (MAX) EQU 26 MAXVNTLN 8 MAX. NO. OF TASKS COMMUNICATING WITH SCT (TERM, ABORT, ATTN) EQU MAXTSKNO INITIAL USER TASK IPRIUTSK EQU 66 ш LPRIUTSK EQU 127 LIMIT CHAIN MODE USER TASK IPRICTSK EQU 66 INITIAL CHAIN MODE USER TASK EQU 127 LIMIT LPRICTSK BATCH MODE USER TASK EQU INITIAL IPRIBTSK 65 LIMIT BATCH MODE USER TASK LPRIBTSK EQU 65 ** OPTION BITS FOR SYSOPT (1=INCLUDE, 0=EXCLUDE) 1 ACTIVATE INITIALIZING CHAINFILE (PRIV.UPSYSTEM.NW) SESSION INITFILE EQU 1 ** IDENTIFICATION MESSAGE $D8,'\LOGMSG1\REVNUMBR \$DATE\$TIME' LOGM DC.B DS.W DS.B LOGM+80-* ** INITIALIZATION INFORMATION DC.B NO. TERMINALS INITPAR TOTTERM NO. CONCURRENT BATCH JOBS EXECUTING DC.B CONBATCH NO. PAGES BATCH QUEUING (32 JOBS PER PAGE) DC.B BATCHPGE DC.B ISECLVL INITIAL SECURITY LEVEL DC.L INITIAL SYSTEM SECURITY WORD INSWORD ISWORD1 DC.L ISWORD2 SYSTEM DEFAULT VOLUME NAME (DYNAMIC) INDFVOLN DC.L DC.L RESERVED 0 RESERVED DC.L 0 ``` # M MOTOROLA ``` COMTSKNO DC.B MAXTSKNO MAXIMUM NO. TASKS COMMUNICATING WITH SCT DC.B NO. LOGON TRIES BEFORE REJECT LOGON NOLOGON LOGTRYNO PRIORITIES FOR ON LINE MODE USER TASKS DC.B IPRIUTSK, LPRIUTSK UCBPRILI PRIORITIES FOR CHAIN MODE USER TASKS UCBPRICH DC.B IPRICTSK, LPRICTSK DC.B IPRIBTSK, LPRIBTSK PRIORITIES FOR BATCH MODE USER TASKS UCBPRIBT NUMBER MAX LUNS PER TASK UCBMAXLU DC.B MAXLU LOG OFF AFTER SPECIFIED NO. TIME OUTS TIMECNT DC.B TERMOCNT INITFILE << SOSYSMSG SYSTEM OPTION BITS SYSOPT DC.B DC.B RESERVED WAIT TO RETRY LOAD IF NO MEMORY AVAILABLE LODRETRY DC.L BATDLY 0.0 RESERVED DC.L PATCH DS.B $80 PATCH AREA DC.B DEFAULT VOLUME: USN. CAT '\DEFAULT' DEFAULT DC.B $0D,$0A CR.LF FORCE EVEN BYTE BOUNDARY DS 0 PAGE GENERAL USAGE FLAG FOR 'YES' OR 'NO' TYPE CONSIDERATIONS EET GFLG: DC.W \AUTOLOGN MEANING BIT AUTOLOGN 0 0 --> Auto break denied 1 --> Auto break requested 1 0 --> Auto vol:usn.cat denied 1 --> Auto vol:usn.cat requested Available for use 2-15 LOGNTERM: DC.B \AUTOTERM TERMINAL ID AUTO LOGON IS TO OCCUR ON SESSION CONTROL COMMANDS SYSCMDS EQU ** BASIC CONTROL COMMANDS XREF LOGOFF, LOGBYE, LOAD, USTRT, STOPTASK, CONTINU XREF TRMINATE, PROC260, LOGDATE, LOGTIME XREF USE, DEFAULTS, ARG, NOARG BREAKS, BREAKT, OPTCMD, MENUCMD XREF XREF EETSXT, EETSBATE DC.B SYSCMD 'LOG OF',$E6,0 DC.L LOGOFF DC.B 'LOGOF', $E6,0 DC.L LOGOFF 'OFF',0 DC.B LOGOFF DC.L 'BYE',0 DC.B DC.L LOGBYE ``` ## (M) MOTOROLA ``` ***** DC.B 'MENU', 0 EXAMPLE OF DC.L MENUCMD NEW COMMANDS ****** DC.B 'LOAD',0 DC.L LOAD DC.B 'STAR',$F4,0 Ţ DC.L USTRT DC.B 'STOP',0 DC.L STOPTASK 'CONT', $E9, $EE, $F5, $E5, 0 INUE DC.B DC.L CONTINU DC.B 'TERM',$E9,$EE,$E1,$F4,$E5,0 INATE DC.L TRMINATE DC.B '^'.0 HALT TERMINAL INPUT DC.L PROC260 GO WAIT FOR EVENT DC.B 'DATE',0 DC.L LOGDATE DC.B 'TIME',0 DC.L LOGTIME DC.B 'USE',0 DC.L USE 'DEF',$E1,$F5,$EC,$F4,$F3,0 AULTS DC.B DEFAULTS DC.L DC.B 'ARG',$F5,$ED,$E5,$EE,$F4,$F3,0 UMENTS DC.L DC.B 'NOARG',$F5,$ED,$E5,$EE,$F4,$F3,0 UMENTS DC.L NOARG DC.B 'BSTO',$F0,0 DC.L BREAKS DC.B 'BTER',$ED,0 М DC.L BREAKT DC.B 'OPT',$E9,$EF,$EE,$F3,0 IONS DC.L OPTCMD ** OPTIONAL COMMANDS IFNE SPCCMD XREF NEWS, HELP, ASSIGN, CLOSE DC.B 'NEWS',0 DC.L NEWS 'HELP',0 DC.B DC.L HELP DC.B 'ASSI',$E7,$EE,0 GN DC.L ASSIGN 'CLOS',$E5,0 DC.B E DC.L CLOSE ENDC ** CHAIN/BATCH OPTIONAL COMMANDS IFNE CHAINBAT XREF CHAIN, CMDEND, RETRY, PROCEED, REGCHAIN DC.B 'CHAI',$EE,0 N DC.L CHAIN 'END',0 DC.B DC.L CMDEND DC.B 'RETR',$F9,0 Υ ``` ## (M) MOTOROLA ``` DC.L RETRY DC.B 'PROC',$E5,$E5,$E4,0 EED PROCEED DC.L 'R?',0 DC.B REGCHAIN DC.L XREF BATCH, CANCEL, ELIM, QUERY DC.B 'BATC',$E8,0 DC.L BATCH DC.B 'CANC',$E5,$EC,0 EL DC.L CANCEL 'QUER',$F9,0 Υ DC.B DC.L QUERY DC.B 'ELIM', $E9, $EE, $E1, $F4, $E5, 0 INATE DC.L ENDC ** SECURITY OPTIONAL COMMANDS IFNE SECURITY PASS, SWORD, SECURE, PWVAL, ACCTINN XREF DC.B 'PASS', $F7, $EF, $F2, $E4, 0 DC.L PASS DC.B 'SWORD',0 DC.L SWORD DC.B 'SECURE',0 DC.L SECURE ENDC SYSTBEND DC.W 0,0,0 ** TRANSFER FOR BATCH TERMINATION ** IFEQ CHAINBAT EETSBAT BRA EETSXT IGNORE ENDC IFNE CHAINBAT EETSBAT BRA EETSBATE ENDC ** TRANSFER FOR PASSWORD VALIDATION ** SECURITY IFEQ CMDPWVAL RTS ENTRY POINT CMDACCTT MUST HAVE A6=SCT DATA SEGMENT ADDRESS EXIT FROM CMDACCTT WILL HAVE A3=SCT DATA SEGMENT ADDRRESS CMDACCTT: MOVE.L A6,A3 A3=SCT DATA SEGMENT ADDRRESS RTS ENDC IFNE SECURITY ``` =/\* ``` CMDPWVAL BRA PWVAL ENTRY POINT CMDACCTT MUST HAVE A6=SCT DATA SEGMENT ADDRESS EXIT FROM CMDACCTT WILL HAVE A3=SCT DATA SEGMENT ADDRRESS CMDACCTT BRA ACCTINN ENDC LOGM+$300- DS.B SECTION 1 BEGQUEUE, ENDQUEUE, STTABL, STTABLND, JOBQUEUE, JOBQUEND XDEF XDEF TESEGPGM, TESEGSTT, TASQPAR, BRKPAR XREF BEGQUEUE DC.L JOBQUEUE DC.L ENDQUEUE JOBQUEND STTABL EQU EQU STTABL+(8*NOLOGONS) STTABLND STTABLND JOBQUEUE EQU ** FOLLOWING EXEC & FHS CALLS EXECUTED AT INITIALIZATION ** THEN CLEARED TO BECOME STT TABLE AND BATCH JOB QUEUE DCLSHR, 0, 0, SGATRO+SGATGS, EETPNAM DECLARE SHAREABLE DC.L TESEGPGM DCLSHR, 0, 0, SGATRO+SGATGS, '.STT' DECLARE SHAREABLE TESEGSTT DC.L TASQPAR DC.L GTASQ, EETPNAM, 0 GET ASQ DC.B AQSTQE, MAXVNTLN QUEUE LENGTH INITIALIZED AT START UP DC.L DC.L EETASR, 0 BRKPAR DC.W IOUCBK, 0 DC.L DS.B BEGQUEUE+$100 DS.B BATCHPGE-$100 JOBQUEND EQU END STEP 3 the Link file EET.LG the INPUT statement in order to include the code Add to module. =/* =/* &.EET.LG =/* Link chain file run at SYSGEN time to link EET =/* SYSGEN parameter LINKLS = \LINKLS = file/device to which to send =/* the linker listing ``` ``` =/* SYSGEN parameter EETSTR = \EETSTR = address at which to link driver =/* =LINK ,&.EET.LO,\LINKLS;HAMIXS SEGMENT .EET:0 \EETSTR SEGMENT .STT(G):1 SEGMENT &EET(RG):8,14 INPUT &.DAT.RO INPUT &.CMDLIST.RO INPUT &.EET.RO INPUT &.SCTSASR.RO INPUT &.USM.RO INPUT &.SYSCNTRL.RO INPUT &.MENU.CMD LIB &.USMOPT.RO LIB &.UTILIB.RO END =/* =END ``` Execute SYSGEN. The user should then have the command installed in the Session Manager. The search path for commands entered at the prompt is: <cmdtable> -- <user default> -- <system default> The Session Manager locates a command entered at the prompt (=) by searching the command table first for a match on the four characters entered. If a match is found, the corresponding code is executed for the desired command. If no match is found, the Session Manager assumes the command is a Load Module on the User Default Volume. The Session Manager attempts to load the desired module from disk. If an error 'file not found' is returned, the Session Manager will make one more attempt to load from the System Default Volume. ### 9.7 ADDING A USER-WRITTEN DEVICE DRIVER The following general steps should be performed to integrate a user-written device driver for a custom-designed board into VERSAdos-based system. This section makes no assumptions about the type of driver being written. For more information, refer to the Guide to Writing Device Drivers for VERSAdos (M68KDRVGD). #### STEP 1 Become familiar with the hardware characteristics of the device for which the driver is being written. This should include Control and Status register layout and command/status packet format (if applicable). ### STEP 2 Write the device-specific routines needed to "talk" to the device. Build a <DRVNAME>.AF file for use in the assembly. #### STEP 3 Become familiar with VERSAdos data structure for the Device Control Block (DCB), the Channel Data Block (CDB), and the macros used to generate the data structures. There will be one DCB for each device supported by this driver. There will be one CDB for each channel. A channel is defined as a single contiguous segment of memory mapped I/O space. The CDB will be used to build a data structure called the Channel Control Block (CCB). #### STEP 4 Use an existing VERSAdos device driver as a guide, preferably one that comes close in functionality to the device currently being integrated. All driver source is included with VERSAdos object release. a. Define the driver front end, address offset to interrupt, and command and initialization routines. Determine the number of pages needed for CCB allocation as well as revision and version information. #### **EXAMPLE:** SERVICE VECTOR TABLE, REVISION INFORMATION This table is examined by Channel Management Request (CMR) when the channel is allocated to determine where to go for interrupts, commands, and initialization. It must always be at the beginning of the driver code. Also included is a parameter telling the number of extra pages of memory to include in the CCB, and information describing the revision of the driver. SECTION O OPT BRS #### MFPDRV: \* Service vector table. Notice that these values are relative to the \* beginning of the driver so the mechanism is position-independent! DC.L INTERRUPT-MFPDRV Address of interrupt service routine. COMMAND-MFPDRV Address of command service routine. Address of initialization routine. Address of SYSFAIL routine. O = not used. \* Other CMR parameters. DC.B EXTCCBSZ Number of extra pages in the CCB. The CCB may be any size from 1 to 256 pages (a page is 256 bytes): if this field is 0, it will be 1 page, etc. DC.B 0,0,0 DC.L 0,0,0 Reserved. Reserved. \* Revision info: \* DC.B '102384' DC.B ', Date of last assembly as MMDDYY. Space indicates no patches to .LO file. DC.B '4' Major VERSAdos revision number. \* Jump table for use by the generic TERMLIB. BRA.L PUT CHAR BRA.L CK TBE BRA.L DDP RESET BRA.L SETUP BRA.L CLOCK RESET BRA.L GET STAT BRA.L DDP STOP BRA.L DDP\_UNSTOP BRA.L DDP BEG BREAK BRA.L DDP END BREAK PAGE b. Define the Initialization Handling code. In some cases, no specific initialization may be required as a simple RTS would be sufficient at the INIT entry point. #### INITIALIZATION ROUTINE This routine is called by CMR when the channel is allocated. Its purpose is to set up things for command service and interrupt service. The major functions performed are: - 1. Takes over additional vectors required by this driver. - 2. Device-independent initialization in the call to TERM INIT. - 3. Determine if this is the driver for the MVME120. - 4. Device-dependent initialization in a call guarded to DO INIT to initialize the device. This point was reached through a JSR from CMR, and will exit with an RTS. All registers have been saved by CMR and may be used freely. Entry is at interrupt level O. These functions are completed in supervisor mode. ``` Entry: A5 = address of CCB. Calls: TERM INIT in the generic terminal driver TERMLIB. Exit: CMR (via RTS) if all is OK. KILLER if exec won't allocate memory, or can't get background routine entry point. DS 0 * The MC68901 Multifunction Peripheral chip has 4 vectors that * support the USART part of the chip. Currently, there is no * way that CMR can process 4 vectors for one channel. * issue is handled here by reading the address stored away in * the vector given CMR via the channel data block, and storing * that address in the other 3 vectors that CMR has not taken over * Actually, the driver only uses 3 of the four vectors. The vector * number $6C is the one stored in the CCB. The address from vector * number $6C must be put into vector numbers $6B and $6A. The vector * number $69 is used to report transmit errors and is not supported by * this driver. INIT: Take over the additional vectors. MOVEQ.L #0,D0 Clear working register. MOVE.B CCBVECT(A5),DO Get the vector number from our CCB. MULU #4,D0 Multiply by 4 to get the address. MOVE.L DO, AO Copy to address register. MOVE.L (A0),-(A0) Copy contents to address - 4. MOVE.L (A0),-(A0) Copy contents to address - 4. Perform the device-independent initialization by calling the generic routine TERM INIT in TERMLIB. JSR TERM INIT Complete device-independent changes. ΙF <NE> THEN Error occurred with TERM INIT. ΙF <PL> THEN The exec call failed -- \overline{n}0 access to the scheduler's entry point. TRO$.KILLER ELSE RTS The channel is down. ENDI ENDI Read the high order byte of the Module Control Register to determine if the driver is on the MVME120. The high order byte of the MCR is guaranteed to be $FF on the MVME120 board. Set the proper driver code in our CCB. ``` # MOTOROLA MOVE.W MCR,DO CMP.B #\$FF,DO MOVE.B #120,DRV\_FLAG(A5) BRA.S INIT200 #0 Read the MCR. High order byte guaranteed \$FF. Set drive flag for MVME120. Done for the 120. Perform the minimum device-dependent initialization usingcall guarded to the EXEC for a routine resident in background. INIT200 LEA MOVE.L TRAP DO\_INIT(PC),AO #TOGUARD,DO Device-dependent routine address. Call guarded to the EXEC. RTS c. Define the Command Handling jump table. In most cases it should only require slight modification to this table. If a special command handling routine is necessary, simply define the code and enter the offset in the command table. COMMAND TABLE & JUMP TABLE These commands are used by the command service routine to jump to the appropriate routine to handle a command when not in transparent mode. Note that IOHALT (halt I/O) is not in the table -- it is checked for separately. DS 0 CMD\_TBL: DC.W IOWRIT DC.W IOOWIN WRITE command. 100WIN OUTPUT W/ INPUT command. DC.W IOREAD READ command. DC.W IOTBRK TRANSMIT BREAK command. DC.W IOSTAT REQUEST STATUS command. DC.W IOCNFG CONFIGURE command. DC.W IOCHDC CHANGE DEFAULT CONFIGURATION command. NUM\_CMDS EQU (\*-CMD\_TBL)/2 The number of commands in the table. JMP\_TBL: DC.W WRITE-\* DC.W OUTWINP-\* DC.W READ-\* DC.W XMIT\_BRK-\* DC.W REQ\_STAT-\* DC.W CONFIGUR-\* DC.W CHNG\_DEF-\* JMP\_OFF EQU JMP\_TBL-CMD\_TBL Offset between the two tables. Having found the command in the first table, this offset is used to get to the corresponding value in the second. Biases to the corresponding routines. d. Define the interrupt handling routine. This routine contains most of the device dependent code and will require device specific modifications or a totally different method than used in the example. Be sure to adhere to the entry and exit conventions. PC=0000A59E SR=2600=.S6.... USP=0002E9E6 SSP=00000CA8 VBR=00000000 SFC=0 DFC=0 D0-7 0000FF00 FFFFFF00 0000328A 00000000 0001DCD2 0001DD0E 000054E4 00000040 A0-7 0002666C 0000A59E 00006420 0001DC88 0000A500 00026500 0000F300 00000CA8 PC=00A59E 226D0022 MOVE.L 34(A5),A1 Upon entry at the interrupt handling routine the registers above reflect the state of the system. The register of interest to the device driver is A5. This register points to the CCB of the first device on the interrupt polling chain for the vector. #### STEP 5 Define the necessary substitution parameters which will be used with the DCB macro. It may be necessary to define a new macro for the type of device to be supported. The only requirement is to keep the device-independent portion of the macro intact. The specific device may then be defined as device-dependent. Use the files MACRO.DCB.SI and MACRO.DCBDISK.SI as examples. ``` * MACRO.DCB.SI -- DEFINES BASIC DCB AND CDB MACROS See MACRO.DCB*.SI for specific DCB macros, i.e., DISK,TERM,GPIB, etc. * SECTION O DCB = Device Control Block: contains info about device, including default configuration; used heavily by FMS, FHS, IOS. * SECTION 1 CDB = Channel Data Block: used by IOI to allocate channels. ``` \* DIPDCB macro defines device-independent portion of a DCB. Used by the \* other device-dependent macros DSKDCB, CRTDCB, PRTDCB. # (M) MOTOROLA ``` DIPDCB MACRO DC.L *+\1 Address of next DCB in linked list. ASCII identification for this DCB. DC.L \2 Address of DCQ entry. DC.L 0 \3 DC.L Name of task making the request. Session of task making the request. DC.L \4 DC.L Address of LUT. DC.L \5 Device attributes associated with DCB. Write/Read protect codes. DC.W 0 'Device in use' flag. DC.W 0 DC.L 0 Write/Read counts. Device flag (device code). Device flag (device status). DC.B \6 DC.B DC.L Channel identification. \8 Device number associated with the channel. DC.B \9 DC.B Task priority. 0 DC.L Current record #. Storage area for the IOCB being processed. DS.B IOSBLN DC.L Logical address of IOCB in user's address space. DC.B Config. coordination flag (0 --> at defaults). 0 DC.B Break count. 0 Address of break service LUT. DC.L 0 DC.L Break service address. DC.L Event claimer -- task name Event claimer -- session number DC.L Address of supervisor DCB or Session DC.L \A number if this is a supervisor DCB Supervisor/subordinate DCB open count DC.L DC.L 0,0,0,0 Device-independent/dependent buffer zone ENDM The following listing shows the macro used to define a Channel Data Block (CDB). This is used by IOI to allocate channels; equates are in LV5.eq. CDBLN EQU $2E Length of the CDB data structure. CDB MACRO SECTION 1 === CDB SECTION === DC.L *+CDBLN Pointer to next CDB in list. Options for the ALLOCATE command. DC.W \setminus 1 DC.L \2 Channel mnemonic. DC.B \3 Channel type. DC.B \4 Masked interrupt maximum instruction count. DC.L \5 Physical address of driver. Supervisor channel's mnemonic (only if bit 3 of options set). DC.L \6 DC.L \7 Physical address of device in memory mapped I/O space. Number of bytes device occupied in memory mapped I/O space. DC.W \8 DC.B \setminus 9 Vector number. DC.B \A Polling priority. DC.B \B Software priority. DC.B \C Segment count. (Number of polling entries) ``` # (M) MOTOROLA ``` DC.W \D Polling byte offset. -- [#1] -- DC.B \E Polling mask. Polling test value. Offset from physical device address for reset. DC.B \F DC.W \G DC.B \H Value for reset. DC.B 0 Reserved. DC.W \I Polling byte offset. -- [#2] -- DC.B \J Polling mask. DC.B \K Polling test value. DC.W \L Offset from physical device address for reset. DC.B \M Value for reset. DC.B 0 Reserved. ENDM ``` #### STEP 6 Define the CDB Macro. All channel definitions for devices are identical. Therefore, only enter the specific parameters such as channel name, $\rm I/O$ address, and vector number. ``` IOC.MFPDRV.AG Included equate files: &.IOE.EQ &.NIO.EQ NOLIST INCLUDE &.IOE.EQ INCLUDE &.NIO.EQ LIST Included device specific macros: MACRO.DCB.SI * MACRO.DCBTERM.SI NOLIST INCLUDE MACRO.DCB.SI INCLUDE MACRO.DCBTERM.SI LIST ``` \* Assign values from SYSGEN parameters DVCODE SET \&CRTDV Define starting device code LTDA\$01 EQU \LTDA\$01 Define MFP #1 address MFP EQU \MFPDRV Define the physical address of the driver CNAME SET 'CMFP' channel name mnemonic SET UP DCBs & CDBs FOR LOCAL TERMINALS - MFPs \* Define TCP\$ATW once for all terminals TCP\$ATW SET \TCP\$HCPY+\TCP\$XCTL<<1+\TCP\$BITS<<2+\TCP\$STPB<<3+\TCP\$USEP<<4 TCP\$ATW SET TCP\$ATW+\TCP\$PRTY<<5+\TCP\$ECHO<<6+\TCP\$TAHD<<7+\TCP\$TFUL<<8 TCP\$ATW SET TCP\$ATW+\TCP\$PNUL<<9+\TCP\$MODM<<10+\TCP\$OFFH<<11 \*\*\*\* MFP port #1 \*\*\*\* \* MFP port #1 \*-- Data Control Block --\* SET UP DCBs FOR LOCAL TERMINALS CRTDCB DVCODE, IOSID, IOSESS, \$133,35,1, CNAME, 0, \$0FFF, \$7FF3, TCP\$ATW, \TCP\$REC, & \TCP\$RSZ, \TCP\$WTO, \TCP\$RTO, \TCP\$XOF, \TCP\$BRC, \TCP\$BRC, \TCP\$RLN, & \TCP\$CLC, \TCP\$EOL, \TCP\$BRT, \TCP\$NLS, \TCP\$TTP Channel Data Block CDB \$0000,CNAME,XTMFP0,254,MFP,0,LTDA\$01,1,\$6C,6,\$30, & 0,0,0,0,0,0,0,0,0,0 DVCODE SET DVCODE+1 XYZDCB DVCODE, IOSID, IOSESS, \$FFF, 55, 1, CNAME, 0, \$0FFF, \$7FF3, XYZ\$ATW, \XYZ\$REC, & \XYZ\$RSZ, \XYZ\$WTO, \XYZ\$RTO, \XYZ\$XOF, \XYZ\$XON, \XYZ\$BRC, \XYZ\$DOP, \XYZ\$RLN, #### Example: The above example of a DCB macro call is for a newly invented device called the "XYZ". Using the CRTDCB macro, a new macro structure called XYZDCB has been constructed. This macro should then go into MACRO.DCBXYZ.SI to be included when IOC.XYZDRV.AG is assembled. Most cases where a need for a new file or data structure is called for, existing files may be used as samples. # (M) MOTOROLA ``` Example: Macro used to define DCB for device XYZ: XYZDCB MACRO SECTION 0 === DCB SECTION === DIPDCB CDCBLN, 1, 2, 3, 4, 5, 6, 7, 8, 0 DC.B 0,0,0,0 Space for status fields. DC.W Attributes mask. \9 $OFFF DC.W \A Parameters mask. $7FF3 DC.W \B Attributes word. XYZ$ATW DC.W \C # of characters/line. XYZ$REC # of lines/page. DC.L \D XYZ$RSZ ĽΕ DC.L Write time-out. XYZ$WTO DC.L \F Read time-out. XYZ$RTO DC.B \G XOFF char. XYZ$XOF DC.B \H XON char. XYZ$XON DC.B BREAK EQUIVALENT char.XYZ$BRC \I DC.B \J DISCARD OUTPUT char. XYZ$DOP DC.B \K REPRINT LINE char. XYZ$RLN DC.B 0,0,0,0,0,0,0,0,0 Internal use only -- do not use. 0,0,0,0,0,0 Reserved. DC.B ENDM ``` ## STEP 7 Build SYSGEN files to include the driver into the system during the SYSGEN procedure. Step 8 may be added to the <system>.CNFGDRVR.CI file. Essentially, these commands set parameters which will be used in the file <system>.IFDRVR.CI to include the specific commands necessary to link in the required driver. ## STEP 8 The files that need to be built are described here. Example: \* VME120.CNFGDRVR.CI \* Configuration file for device drivers # MOTOROLA ``` * This file sets up the flags used by the "VME120.IFDRVR.CI" file to * conditionally include device drivers. * The user should only have to modify this file to include/exclude drivers. * To add more boards/devices, the user may have to increase the SYSGEN * command T option for more symbols in the "&.SYSGEN.CF" file. * To modify specific items of a driver, edit the corresponding driver file, * "&.xxxxDRV.CI" except as noted where one driver handles multiple boards. * Board/system dependencies are included from the &.VERSADOS.CD file. * VME120.SYSTEM.CI Add processor board/system dependencies, including local terminals and printers. * &.CNFGTASK.CI Add O/S task configuration for ROM/RAM. NVME = 1 Number of terminals on VME120 serial ports (MFP); max= 1 NRWIN = 0 Number of RWIN Winchester controller boards IFGT \NORWIN 1st RWIN1 is controller 2 CONTWIN1 = "2" NHRWIN$1 = 1 # of hard disk drives on 1st M68RWIN1; max= 2 NFRWIN$1 = 2 # of floppy disk drives on 1st M68RWIN1: max= 2 RWINO$1 = "'H5WIN15'" Type of hard disk on 1st M68RWIN1, drive 0 RWIN1$1 = "'H5WIN15'" Type of hard disk on 1st M68RWIN1, drive 1 RWIN2$1 = "'F5DDDSI'" Type of floppy disk on 1st M68RWIN1, drive 2 RWIN3$1 = "'F5DDDSI'" Type of floppy disk on 1st M68RWIN1, drive 3 CONTWIN2 = "5" 2nd RWIN1 is controller 5 NHRWIN$2 = 0 # of hard disk drives on 2nd M68RWIN1; max= 2 NFRWIN$2 = 0 # of floppy disk drives on 2nd M68RWIN1; max= 2 CONTWIN2 = "5" RWINO$2 = "'H5WIN15'" Type of 1st hard disk on 2nd M68RWIN1, drive 0 RWIN1$2 = "'H5WIN15'" Type of 2nd hard disk on 2nd M68RWIN1, drive 1 RWIN2$2 = "'F5DDDSI'" Type of 1st floppy disk on 2nd M68RWIN1, drive 2 RWIN3$2 = "'F5DDDSI'" Type of 2nd floppy disk on 2nd M68RWIN1, drive 3 * NOTE: 5-1/4" and 8" floppies cannot be mixed. Pick one or the other. ENDC NVME050 = 1 Number of VME050 System Controllers ENDC NVME300 = 0 Number of MVME300 IEEE 488 GPIB controller boards ``` ``` NVME315 = 1 Number of MVME315 Winchester/floppy disk controller boards \NVME315 IFGT = "1" CONT315 MVME315 is controller 1 NH315$1 = 1 Number of hard disk drives on 1st MVME315; max=2 NF3158$1 = 2 Number of 8" floppy disk drives on 1st MVME315; max=4 of 5-1/4" floppy disk drives on 1st Number NF3155$1 = 2 MVME315; max=4 = "'H5WIN15'" Type of 1st hard disk on 1st MVME315 board M3150$1 Type of 2nd hard disk on 1st MVME315 board = "'H5WIN15'" M3151$1 M31584$1 = "'F8SDDSM'" Type of 1st floppy disk on 1st MVME315 board M31585$1 = "'F8SDDSM'" Type of 2nd floppy disk on 1st MVME315 board M31556$1 = "'F5DDDSI'" Type of 3rd floppy disk on 1st MVME315 board M31557$1 = "'F5DDDSI'" Type of 4th floppy disk on 1st MVME315 board ENDC NVME316 = 1 Number of MVME316 VMEbus to I/O Channel interface boards; max = 1 NVME320 = 1 Number of MVME320 Winchester/floppy controller boards IFGT \NVME320 MVME320 is controller 0 CONT320 = "0" NH320$1 = 1 Number of hard disk drives on controller; max= 2 NF3205$1 = 1 Number of 5-1/4" floppy disk drives on MVME320; max= 1 Number of of 8" floppy disk drives on MVME320; max= 1 NF3208$1 = 0 = "'H5WIN15'" Type of 1st hard disk on 1st MVME320 board M3200$1 M3201$1 = "'H5WIN15'" Type of 2nd hard disk on 1st MVME320 board M32052$1 = "'F5DDDSI'" Type of 1st floppy disk on 1st MVME320 board M32083$1 = "'F8SDSSI'" Type of 2nd floppy disk on 1st MVME320 board ENDC NVME400 = 0 Number of MVME400 dual 7201 serial port boards IFGT \NVME400 NU400$1 = 0 Number of ports/users on MVME400 bd. #1; max= 2/bd. NU400$2 = 0 Number of ports/users on MVME400 bd. #2: max= 2/bd. ENDC ``` ``` Number of MVME410 dual 16-bit parallel port boards NVME410 = 0 IFGT \NVME410 NU410$1 = 0 NU410$2 = 0 Number of printers in use on MVME410 board #1: max= 2 Number of printers in use on MVME410 board #2: max= 2 ENDC NVME4208 = 0 Number of MVME420 SASI 8" interface controller boards IFGT \NVME4208 CONT4208 = "4" MVME420 (SASI 8) is controller 4 NH4208$1 = 0 Number of hard disk drives on MVME420 (SASI); max= 2 NF4208$1 = 0 Number of floppy disk drives on MVME420 (SASI); max= 4 M42080$1 = "'H8WIN10'" Type of hard disk on 1st MVME420, drive 0 M42081$1 = "'H8WIN10'" Type of hard disk on 1st MVME420, drive 1 M42082$1 = "'F8DDDSI'" Type of floppy disk on 1st MVME420, drive 2 M42083$1 = "'F8DDDSI'" Type of floppy disk on 1st MVME420, drive 3 NOTE: Total disks for SASI= 4, i.e. NH4208$1+NF4208$1 <= 4. ENDC NVME435 = 0 Number of MVME435 mag tape controller boards (max = 2) IFGT \NVME435 N435$1 = 0 Number of tape drives on first MVME435 board = 0 Number of tape drives on second MVME435 board N435$2 NVME600 = 0 Number of MVME600 analog input controller boards NVME605 = 0 Number of MVME605 analog output controller boards \NVME605 NU605 = 0 Number of users (total) for the MVME605 boards ENDC NVME610 = 0 Number of MVME610 AC input controller boards = 0 Number of MVME615/616 AC output controller boards NVME615 \NVME615 IFGT NU615 = 0 Number of users (total) for the MVME615 boards ENDC ``` | NVME620 = | Number of MVME620 DC input controller boards | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NVME625 = I<br>IFGT<br>NU625<br>ENDC | | | IFGT | = 0 Number of RAD users | | IFGT<br>NRIOINT<br>ENDC | | | 'XXX<br>wri<br>Use<br>MFP | XX' is the acronym of the device for which the driver is being tten. VERSAdos conventions have been loosely defined as follows: the chip name or number if driver is for a specific chip (such as). Use the name of the board if the drive is for a specific VME rd such as M400DRV for the driver support of the MVME400 board. | | Exai | mple: | | NVMEXYZ = IFGT \NVMEXY NUXYZ\$1 NUXYZ\$2 ENDC | YZ = 2 Number of ports/users on VMEXYZ bd. #1; max= 2/bd. | # STEP 9 Add the following commands to the file <system>.IFDRVR.CI. IFNE \NVMEXYZ INCLUDE &.XYZDRV.CI ENDZ These commands allow SYSGEN to process the INCLUDE file XYZDRV.CI only if the appropriate switch \NVMEXYZ is set. ## **STEP 10** Build the XYZDRV.CI file. XYZDRV=\* Defines the position within the BOOT file where this file resides. SUBS &.MPSCDRV.LG Allows any parameter substitution. LINK &.MPSCDRV.LG Links the driver. PROCESS &.MPSCDRV.LO Directs SYSGEN to place the driver into the BOOT file. END &.MPSCDRV.LO Indicates the end of processing for this module. ## STEP 11 Build the XYZDRV.LG file. This file is used to link the driver .RO information and .LO file for inclusion into the target BOOT file. Use any existing CRVNAME LG file as an example. LIST ## STEP 12 EQUATE file modifications. An EQUATE file of interest to device driver writers and which may require additions (never deletions) are located in system account :9995. The following list of EQUATEs should be examined to determine which files could be used by the new driver. Some devices may require the construction of a new equate files to contain in one place all the EQUATE definitions necessary for that board or chip. Note the following EQUATE for MK68901.EQ ``` * Include these EQUATE and macro files STR.EQ TCB.EQ CCB.EQ Parameter block offsets, channel type, error codes IOE.EQ Event msg, DCB, LUT, DCQ equates NIO.EQ LV5.EQ Background Activation Block description. BAB.EQ Offsets and EQUATEs for CCBDDP for terminals. TERMCCB.EQ Equates for terminals. TERMINAL.EQ Device description. MK68901.EQ UTILITY.MC Macros. NOLIST INCLUDE 9995.&.STR.EQ NOLIST INCLUDE 9995.&.TCB.EQ NOLIST INCLUDE 9995.&.CCB.EQ NOLIST INCLUDE 9995.&.IOE.EQ NOLIST INCLUDE 9995.&.NIO.EQ NOLIST INCLUDE 9995.&.LV5.EQ NOLIST INCLUDE 9995.&.BAB.EQ NOLIST INCLUDE 9995.&.UTILITY.MC LIST INCLUDE 9995. &. TERMCCB. EQ INCLUDE 9995.&.TERMINAL.EQ INCLUDE 9999.MK68901.MK68901.EQ MK68901 DEVICE DESCRIPTION TTL ``` ### STEP 13 Once all the files have been defined and the code written, perform the SYSGEN. For convenience a file called STD.SYSGEN.CF has been included in the release and should have been copied to the user account containing all the SYSGEN files. Log-on the SYSGEN account specifying the proper catalog. ## Example: =USE SYS:9100.VME120<cr> =STD.SYSGEN.CF<cr> The SYSGEN will take approximately 35 minutes on a single-user system. When the SYSGEN is complete and there are no errors, copy the <system>.VERSADOS.SY to an bootable floppy disk for testing on the target configuration. Or, if the user is already running on the target, boot directly from the user number used to complete the SYSGEN. #### 9.8 ADDING AN UNSUPPORTED DISK DRIVE The following procedure describes the method used to add an unsupported disk drive to a system running VERSAdos. Standard VERSAdos configurations support Winchester disk drives of 15Mb and 40Mb in size. The following example illustrates the steps required to alter SYSGEN in order to add a 20Mb Winchester disk drive to MVME120-based system equipped with an MVME315 disk controller. ## STEP 1 Create a new file named &. H5WIN2O.SI as follows: - a. Copy the existing file &. H5WIN15.SI to &. H5WIN20. - b. Edit &.H5WIN2O and change all driver parameters according to the manufacturer's specifications for the 20Mb Winchester disk drive to be used. ### STEP 2 Edit the file IOC.M315DRV.AG. a. Add a conditional assembly section for the inclusion of the &.H5WIN2O.SI file immediately following the corresponding section for the 15Mb Winchester disk drive, as follows: IFC\M3150\$1,'H5WIN20' INCLUDE &.H5WIN20.SI SIZESET SET 1 ENDC A simple method to complete this step is to duplicate corresponding sections for a 15Mb drive and change appropriate statements. - b. Repeat STEP 2a. for the second hard disk on the first MVME315 disk controller. - c. Repeat STEPS 2a. and 2b. for the second MVME315 disk controller. #### STEP 3 Edit the file VME120.CNFGDRVE.CI. Change appropriate drive definitions to "H5WIN20", for example: "M3150\$1 = H5WIN15" is changed to "M3150\$1 = H5WIN20" If the 20Mb Winchester disk drive is to be used by all disk controllers supported by SYSGEN for the MVME120, similar steps must be taken for the MVME320 and M68RWIN1 disk controllers. STEP 1 does not have to be repeated. The new file &.HWIN20.SI applies to all disk controllers that use the same disk drive (or same drive characteristics). If multiple drives are to be used that have the same nominal size but have different characteristics (e.g. number of cylinders and/or heads), then STEP 1 must be repeated in order to create a new "&.DRIVETYPE.SI" file for each type of disk drive. STEPS 2 and 3 must be repeated for each disk controller. However, in STEP 2 edit: IOC.M320DRV.AG for the MVME320 disk controller and, IOC.RWINDRV.AG for the M68RWIN1 disk controller. #### 9.9 NOTES ON MVME120 AND MVME121 MEMORY ARCHITECTURE #### 9.9.1 Overview The MVME120 and MVME121 microprocessor modules are designed for high-performance within a multiple processor architecture. In order to meet the performance requirements, these boards include an onboard cache, a large onboard memory array, and a new memory array/MMU architecture to enable the MMU translation cycle to execute concurrently with the decoding of the low order address bits. This section describes the impact of the last feature on the system software. ## 9.9.2 Theory of Operation The onboard memory architecture of the MVME120 and MVME121 processor boards is shown in Figure 9-1. Note that the cache is on the logical address bus. If the instruction accessed by a program space read cycle is found within the cache, the cache controller places the instruction on the data bus (D15-D0) and the cycle is terminated. Otherwise, the MC68451 MMU translates the high order address bits (A23-A10) at the same time that the memory array decodes the low order bits (A9-A1). These low order bits are used as the row address in the two dimensional row address/column address memory array. If the MMU cannot translate the high order address bits, it signals a bus error to the processor, and the cycle is terminated. Otherwise, the MMU presents the translated high order address bits to the memory array which uses them as the column address. If these high order bits of the physical address point within the onboard memory array, the memory controller places the data on bits D15-D0 of the data bus. If the memory cycle was a program space read, the cache controller updates one cell in the cache to reflect the current address/data combination. # 9.9.3 Memory Addressing Problem A potential problem arises within VERSAdos because the MMU bypasses the low 10 bits of the effective address. (All previous Motorola processor boards bypassed only the bottom 8 bits, and translated address bits A23-A8.) If either bit A9 or A8 of the logical address is not equal to the equivalent bit of the corresponding physical address, the memory array will use the logical address bits instead of the physical address bits, and access the wrong cell in the memory array. FIGURE 9-1. MVME120/MVME121 Memory Architecture #### 9.9.4 The VERSAdos Solution The solution to this problem is to guarantee that bits A9 and A8 of the logical address are always equal to bits A9 and A8 of the physical address. VERSAdos 4.4 has modified the LINKER, LOADER, and SYSGEN command files to implement this solution. A "pagesize" option was added to the LINKER to describe the granularity of the memory array. For MVME120 and MVME121 systems, this variable should be set to 1024 to reflect the 1Kb pagesize of this family. In order to support the loading of object programs which were not linked with this pagesize option, the LOADER relocates all position-independent tasks so that the beginning logical address of all segments starts on 64Kb boundaries. (64Kb was chosen instead of 1Kb to support future extensions of this basic architecture.) These two fixes guarantee that bits A9 and A8 of the beginning logical address of a segment are always equal to zero. Therefore, we need a corresponding fix to RMS68K's memory manager to ensure that bits A9 and A8 of the beginning physical address are also equal to zero. This fix was implemented in the following three stages: - a. Allocate operating system memory (unmapped by MMU) from a different partition than task memory (mapped by MMU). - b. Ensure that task memory is always allocated in pagesize chunks. - c. Ensure that the partition(s) reserved for task memory start on a pagesize boundary. (Bits A9 and A8 of the beginning physical address are equal to zero.) These individual pieces of the fix are described in the following paragraphs. 9.9.4.1 Operating System vs. Task Memory. RMS68K kernel has access to all of memory (unprotected) and acknowledges all memory mapped with logical addresses equal to their corresponding physical addresses (unmapped). Therefore, the problem involving the MMU bypassing bits that should be translated does not affect RMS68K. A simple solution would have been to force RMS68K to abide by the same constraints as tasks; set memory on pagesize boundaries and in pagesize chunks. This would have forced all system data structures such as TCBs, ASQs, and other internal tables to consume at least 1Kb of memory each instead of the usual 512 or 256 bytes. Instead of wasting so much memory, partition zero is reserved for system memory and partition one is reserved for task memory. Thus RMS68K can allocate its tables from partition zero in 256 byte chunks, but tasks must get memory in 1Kb chunks from partition one. This is implemented by setting the SYSGEN parameters for the default memory types for TCBs and ASQs (MEMTYPT and MEMTYPA) to zero, and the default memory type for user task and system task memory (MEMTYPU and MEMTYPS) to one. (The default type for system tables is always zero.) Thus, a task that allows the GTSEG request for memory (get a segment of memory) to default to the partition type defined at SYSGEN time for task memory will experience little difficulty. However, a task which explicitly requests memory from the partition reserved for system memory, either by directly encoding the partition number or partition type in the GTSEG directive, must request the memory from a specific physical address, and ensure that the physical address is on a pagesize boundary. 9.9.4.2 <u>Pagesize Chunks for Task Memory</u>. RMS68K's memory manager guarantees that all requests for task memory are allocated in pagesize chunks by rounding the length of the segments requested via the GTSEG directive up to the next pagesize boundary. Pagesize is a SYSGEN parameter which is set to 1K for the MVME120 and MVME121. 9.9.4.3 Partition One Starting on Pagesize Boundary. In order to guarantee that allocatable memory within partition one (reserved for task memory) starts on a pagesize boundary, the partition must start on a pagesize boundary minus 256 bytes. The 256 bytes is used for the free memory list header node (FML header) describing the partition. Thus the SYSGEN parameter MEMEND2 (start of partition one) is set to \$28000 - \$100, and the MTENTRY macro describing partition one is written so that the FML header is placed in the BOTTOM of partition one (low memory). Thus, after the FML header is allocated at locations \$27F00 - \$27FFF, the "real" memory available for task allocation will start at location \$28000. (Location \$28000 was chosen as a good value for Motorola's default configurations. The user can change this value as described in the next section.) #### 9.9.5 Changing the Default Configurations There are two ways that the user may change the default memory configurations for the MVME120 or MVME121 modules: - a. Modify the partition zero/partition one boundary. - b. Add additional memory partitions. Partition one is configured to include addresses \$27F00 to \$400000. Therefore, to add more task memory, simply jumper the memory board to fit within this address range and plug it in. No SYSGEN is required. However, if the boundary between partition zero and partition one must be changed, make sure that the boundary is on some pagesize boundary minus \$100 bytes for the FML header. (One easy way to do this is to use a boundary of \$XXXX000 - \$100.) To reconfigure the system, set the SYSGEN parameters MEMEND1 (end of partition zero), and MEMEND2 (start of partition one) to this value and run the SYSGEN utility. To add memory partitions, use the MTENTRY macro in the INITDAT.AG module, and run SYSGEN. Describe all partitions reserved for system memory (TCBs, ASQs, and operating system tables) as type 0, and all memory for user or system task memory as type 1. (If more system memory is required, it would be easier to enlarge partition zero, rather than to add another partition of type 0.) Describe all partitions of task memory in such a way as to reserve one 256 byte chunk for the FML header, leaving the rest of the memory as some integral number of pagesize (1K) chunks. The FML header can be placed at either the BOTTOM (low memory) or the TOP (high memory) of the partition as shown in the following examples: a. FML header at BOTTOM of partition; MTENTRY RAM, \$XXX000-\$100, \$YYY000, MTYP1, PART3, BOTTOM b. FML header at TOP of partition; MTENTRY RAM, \$XXX000, \$YYY000+\$100, MTYP1, PART4, TOP The fields of the macro are as follows: - . MTENTRY name of macro - . RAM or ROM basic type af memory - . Starting address of partition (Note that in the BOTTOM example \$100 bytes are reserved for the FML header at the beginning of the partition.) . Ending address of partition (Note that in the TOP example above, \$100 bytes are reserved for the FML header at the end of the partition.) - . Type of memory (\$0 through \$7) - . Partition number (\$0 through \$F) - . Placement of FML header (TOP or BOTTOM) ### CHAPTER 10 #### **BOOTING A SYSTEM** #### 10.1 INTRODUCTION The System Integrator or System Programmer concerned with altering the Kernel, operating tasks, or the number of drivers is occasionally confronted with a newly SYSGENed system that will not boot. This chapter describes the sequence of events that occur during the boot process. This information may also be valuable for certain applications which might require the modification of this boot sequence. For example, during the RMS68K initialization, the user may require a new data structure table for a specific application with a pointer in SYSPAR. Knowing the sequence of the operations that the SYSINIT routine performs would be helpful when adding the code necessary to allocate a new data table. When adding new user-written drivers, it is helpful to know exactly when a new driver is to be entered for the first time. This is explained in the VERSAdos Initialization paragraph 10.4. The following defines the boot capabilities of various Motorola Debug Monitors. The capabilities are shown by indicating the controller number that corresponds to each module. The lack of a controller number indicates that a Debug Monitor does not provide boot support for a specific module. ### VME CONTROLLERS | DEBUG<br>MONITORS | MVME315 | <u>MVME320</u> | MVME420<br>5-1/4 IN. | MVME420<br><u>8 IN.</u> | M68RWIN1 | |-------------------|---------|----------------|----------------------|-------------------------|----------| | MVME101 1.1 | 0 | | | | | | MVME110 4.0 | 3 | 4 | 1 | 2 | 0 | | MVME115 1.1 | 1 | 0 | 3 | 4 | 2 | | MVME120 1.1 | 1 | 0 | 3 (NOTE) | 4 (NOTE) | 2 (NOTE) | | TENBUG 2.1 | | | | | 0 | NOTE: Current version of MVME120 Debug Monitor does not support boot capabilities from these controllers. The following examples show a sampling of boot commands used by the Debug Monitors. MVME110 4.0 > BO 0, 4 Boot from first hard disk on MVME320. MVME120 1.1 > BO 6, 1 Boot from floppy disk on MVME315. MVME120 1.1 > B0 Boot from default first hard disk on controller 0 (MVME320). ## 10.2 FIRMWARE BOOT SEQUENCE This paragraph describes the sequence of events which the operating system executes from the time the BO command is entered until the Initial Program Loader (IPL) begins to execute. MVME120 1.1> <u>BO</u> This command initiates the boot sequence. - a. The MVME120 Debug Monitor resets controller 0 and drive 0. The HE command specifies which board is controller 0. In this example, the MVME320 is designated as controller 0. - b. The MVME120 Debug Monitor reads sector 0. The following character strings must be at offset \$F8: "EXORMACS" or "MOTOROLA" If either string is not present an error will occur. The data retrieved from sector 0 by the Debug Monitor in order of byte offset value is: | Get the volume ID from offset \$0: | 4 bytes | |----------------------------------------------|---------| | Starting sector to read at offset \$14: | 2 bytes | | Number of blocks to read at offset \$18: | 2 bytes | | Memory address to start load at offset \$1E: | 2 bytes | | Sector address of the media configuration | | | parameters at offset \$90: | 4 bytes | | Length of configuration area offset \$94: | 1 byte | The program load module is defined by the data at locations \$14 and \$18 of Sector O. The program is read and transferred to its memory destination. The processor status register is set to supervisor mode and interrupt level 7. The Stack Pointer (SP) is loaded from locations \$0-3 relative to the beginning of the destination memory. The Program Counter (PC) is loaded from location \$4-7. The registers are set-up as defined below, and the program just loaded by the BO command now has control. ``` DO...DRIVE NUMBER D1...IPC NUMBER D2...DISK CONFIGURATION CODE D3...FLAG FOR IPL; 'ME4U' = 'USE BUGS' DISK READ ROUTINE D4...IPLX; WHERE X ARE BITS INDICATION TRAP 15 AND DISK SUPPORT (NOT DURING AUTOBOOT) D5... D6... D7... AO...ADDRESS OF DISK CONTROLLER BOARD A1...ADDRESS OF PROGRAM JUST LOADED A2...ADDRESS OF DISK CONFIGURATION DATA A3...ADDRESS OF BUGS' DISK READ ROUTINE A4...ADDRESS OF THE DEBUGGER ENTRY POINT A5...START OF TEXT A6...END OF TEXT+1 (WHERE THE NEXT CHARACTER WOULD GO) A7...STACK OF PROGRAM JUST LOADED SR...SUPERVISOR MODE AND LEVEL SEVEN ``` The example below shows the registers as they would appear after a BOOT and HALT. MVME120 1.1 > BO,;H Booting from: SYS Into RAM at: \$010000 Boot in progress ... Boot complete PC=0001EA8A SR=2704.S7..Z.. USP=FFFFFFF SSP=0001F510 VBR=00000000 SFC=0 DFC=0 D0-7 00000060 00F070C6 0001EA00 00000655 00000004 00000000 00000000 000000BF A0-7 00001000 0001DF00 000007B8 0001087E 00FFB000 0001DE0E 00F0056A 0001F510 PC=01EA8A 4ED1 JMP (A1) MVME120 1.1 > The dump of Sector 0 (following) shows the starting sector to read (\$14) as \$2D (note this is a longword (4 bytes)). The number of blocks to read (\$18) is \$23 (this is a word field (2 bytes)). The memory address to read the boot file into is \$10000 (this is also a longword (4 bytes)). Normally, the program load module defined by the data at offsets \$14 and \$18 is the IPL module. This module is booted first and will locate and boot the desired opeating system task or diagnostic. Sometimes it may be useful to point Sector O directly to the task that is supposed to execute independently of the operating system (i.e., a stand-alone task or a diagnostic). This can be done by changing fields \$14, \$18, and \$1E to the appropriate starting sector, length, and memory address, respectively. - (1) Use the DIR; A command to determine where the target code resides on the disk. - (2) Add 1 to the starting sector in order to bypass the Loader Information Block (LIB). - (3) Subtract 1 from the length to compensate for the previous add. - (4) Determine the location to load and execute. - (5) Using the DUMP utility in interactive mode, read in sector 0. Modify the appropriate offsets with the values determined in steps 1 through 4 above. Write out the altered sector 0. | | SN=\$0 | | 0 | | | | | | | | | | | | | | | |----|--------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------| | 00 | | | 53 | 20 | 00 | 00 | 00 | 00 | 00 | 02 | 00 | 1D | 00 | 00 | 00 | 27 | SYS' | | 10 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 2D | 00 | 23 | 00 | 00 | 00 | 00 | 00 | 01 | # | | 20 | 00 | 00 | 00 | 00 | 29 | 91 | 56 | 45 | 52 | 53 | 41 | 44 | 4F | 53 | 20 | 34 | ).VERSADOS 4 | | 30 | 2E | 34 | 20 | 50 | 41 | 53 | 53 | 32 | 2B | 20 | 30 | 34 | 32 | 30 | 82 | B1 | .4 PASS2+ 0420 | | 40 | 0F | 1 E | 2D | 3C | 4B | 5A | 69 | 78 | 87 | 96 | Α5 | B4 | C3 | D2 | Ε1 | F0 | <kzix< td=""></kzix<> | | 50 | 0F | 1 E | 2D | 3C | 4B | 5A | 69 | 78 | 87 | 96 | Α5 | B4 | C3 | D2 | E1 | F0 | <kzix< td=""></kzix<> | | 60 | F1 | F2 | F4 | F8 | F9 | FA | FC | FE | FF | 7F | BF | DF | EF | 6F | ΑF | CF | | | 70 | 4F | 8F | 0F | 07 | 0B | OD | 0E | 06 | 0A | 00 | 04 | 80 | 04 | 02 | 01 | 00 | 0 | | 80 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 1F | 00 | 80 | | | 90 | 00 | 00 | 00 | 01 | 01 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | A0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | B0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | CO | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | D0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | E0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | F0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 45 | 58 | 4F | 52 | 4D | 41 | 43 | 53 | EXORMACS | c. The Debug Monitor will read using the previous parameters obtained from sector 0 for the starting sector, length, and starting memory address. MVME120 1.1> <u>BO</u> Booting from: SYS Into RAM at: \$10000 Boot in progress ... Boot complete d. In the previous example, the Debug Monitor issues the messages: Booting from: SYS Into RAM at: \$10000 At this point, the load of the target code is complete. The task loaded at this time is IPL.SY. Control is transferred to the target code by the Debug Monitor which loads the stack from offset 0 and PC from offset \$4. e. When the Initial Program Loader (IPL) obtains control, it issues the messages: Boot in progress Boot complete "Boot in progress" appears when the loading of VERSADOS.SY begins. "Boot complete" appears when transfer of control to the operating system is about to take place. # Examples of other Boot commands are: VME120 1.1> <u>BO 0,1</u> Boots VERSADOS.SY from controller 1, drive 0. VME120 1.1> BO , , TEST.SY Boots TEST.SY from controller 0, drive 0. VME120 1.1> BO 2,4, VME120. VERSADOS. SY Boots from controller 4, drive 2; the file from :0.VME120.VERSADOS.SY. VME120 1.1> <u>BO 0,0,VERSADOS.SY;H</u> Boots from controller 0, drive 0; the file VERSADOS.SY then halts. The sequence of execution for the IPL is: - a. Save registers by parsing command line received from the Debug Monitor save options and/or filename. Register A5 will contain a address of the string after the controller and drive number. - b. Read sector O using address of the Debug Monitor disk read routine received in register A3. - c. Get pointer to Secondary Directory Block (SDB) from sector 0 offset \$C. By referring to the dump of sector 0, notice that the starting sector for the SDB is \$27 (4-byte field). d. Read SDB, one sector in length. Search this SDB for a match on the user number and catalog entered on the boot command line (or default user 0 and null catalog if none entered). If user:catalog entered does not exist, the message "file not found" is displayed. The starting sector of the Primary Directory Block (PDB) is obtained for the next step in the search for the target boot file. In the example dump of an SDB, note the entry at offset \$10. The first 2 bytes are the user number (0 in this case). The next 8 bytes identify the catalog (null or spaces in this case). The next 4 bytes are the starting sector of the first PDB. The final 2 bytes are reserved. | | SN=\$2 | 27 | | | 39 | | | | | | | | | | | | | |----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------| | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 10 | 00 | 00 | 20 | 20 | 20 | 20 | 20 | 20 | 20 | 20 | 00 | 00 | 00 | 28 | 00 | 00 | | | 20 | 00 | 00 | 50 | 52 | 49 | 56 | 20 | 20 | 20 | 20 | 00 | 00 | 06 | 59 | 00 | 00 | PRI <b>V</b> Y | | 30 | 00 | 00 | 56 | 4D | 45 | 31 | 32 | 30 | 20 | 20 | 00 | 00 | 06 | 74 | 00 | 00 | VME120t | | 40 | 00 | 00 | 50 | 41 | 53 | 53 | 31 | 20 | 20 | 20 | 00 | 00 | 80 | 29 | 00 | 00 | PASS1) | | 50 | 00 | 01 | 20 | 20 | 20 | 20 | 20 | 20 | 20 | 20 | 00 | 00 | 0Α | 09 | 00 | 00 | | | 60 | 00 | 01 | 50 | 52 | 49 | 56 | 20 | 20 | 20 | 20 | 00 | 00 | 10 | 43 | 00 | 00 | | | 70 | 00 | 01 | 56 | 4D | 45 | 31 | 32 | 30 | 20 | 20 | 00 | 00 | 10 | 5E | 00 | 00 | VME120^ | | 80 | | | 50 | | | | | | 20 | 20 | 00 | 00 | 12 | 13 | 00 | 00 | PASS1 | | 90 | 00 | 28 | 43 | 4F | 4E | 46 | 49 | 47 | 20 | 20 | 00 | 00 | 0E | B5 | 00 | 00 | .(CONFIG | | A0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | B0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | CO | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | D0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | E0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | F0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | e. Read PDB, four sectors in length. Locate a match on the filename entered on the boot command line or in VERSADOS.SY. If no file exists by the appropriate name the message "file not found" displays. A check is made to ensure the file found is a contiguous file. The first 4 bytes of the PDB contain the pointer to the sector of the next PDB. The header portion (16 bytes) of the PDB is made up of 2 bytes for the user number, 8 bytes for CATALOG, and 2 bytes in reserve. Each entry is 50 bytes (\$32). For a complete description of each field, refer to the EQUATE file:9995.&.FME.EQ. Each PDB is four sectors in length and accommodates 20 entries. | 00<br>10<br>20<br>30<br>40<br>50<br>60<br>70<br>80<br>90<br>A0<br>B0<br>C0<br>D0<br>F0 | 00 50 00<br>00 00 00<br>00 00 00<br>00 00 00<br>00 00 00 | C 20 20 3<br>0 23 00 0<br>0 00 00 0<br>2 41 43 0<br>0 00 00 0<br>0 00 43 0<br>0 9E 00 0<br>0 00 00 0<br>0 00 00 0<br>0 00 00 0 | 4D 00 00<br>00 00 00<br>4F 50 59<br>00 00 27<br>00 00 00<br>00 44 45<br>C6 00 00<br>00 00 00<br>00 00 00 | 20 20 20 20 20 20 00 00 53 59 00 00 00 00 00 00 00 00 00 00 00 20 00 0 | U IPL SY,#).)BACKUP LOPM).)COPY LODEL LO).)DIR LO). | |----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------| | 00<br>10<br>20<br>30<br>40<br>50<br>60<br>70<br>80<br>90<br>A0<br>B0<br>C0<br>D0<br>F0 | 20 20 4 00 00 0 29 91 2 20 20 2 00 00 0 20 20 2 00 6B 0 00 00 0 45 52 5 00 00 0 00 00 4 02 55 0 | 00 00 00<br>00 00 00<br>9 91 00<br>00 00 00<br>9 91 29<br>00 20 20<br>00 00 00<br>00 00 29<br>02 4F 52<br>02 48 00<br>00 04 01<br>06 52 45<br>00 00 00 | 00 00 00<br>00 00 00<br>00 00 00<br>4F 00 00<br>00 00 00<br>91 00 00<br>20 4C 4F<br>00 00 00<br>91 29 91<br>4D 53 47<br>00 00 AE<br>04 29 91<br>45 20 20 | 00 00 44 4D 54 20 20 20 01 00 00 00 00 00 00 00 00 00 00 00 00 | )DMT LO ).)E LO6 k ERRORMSGSY H | | 00<br>10<br>20<br>30<br>40<br>50<br>60<br>70<br>80<br>90<br>A0<br>B0<br>C0<br>D0<br>F0 | 00 00 00 00 00 00 00 00 00 00 00 00 00 | 0 00 00 00 00 00 00 00 00 00 00 00 00 0 | 00 00 4C<br>00 00 00<br>00 4C 49<br>B2 00 00<br>00 00 00<br>00 00 00<br>00 00 00<br>00 00 | 20 20 20 20 4C 4F 00 00 00 00 00 00 00 00 00 00 00 00 00 | INIT LOeL))LIST LO))MT LO) )PATCH LO | | | SN=\$2 | 2B | | | 43 | | | | | | | | | | | | | |----|--------|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|----|-----------------------------------------| | 00 | 4C | 20 | 20 | 20 | 20 | 20 | 4C | 4F | 00 | 00 | 00 | 00 | 03 | A1 | 00 | 00 | L L0 | | 10 | 00 | 2A | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | .* | | 20 | 00 | 00 | 00 | 00 | 29 | 91 | 29 | 91 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | ) . ) | | 30 | 53 | 50 | 4F | 4F | 4C | 20 | 20 | 20 | 4C | 4F | 00 | 00 | 00 | 00 | 03 | CC | SPOOL LO | | 40 | 00 | 00 | 00 | 12 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | 50 | | | 00 | | | | | | 29 | 91 | 00 | 00 | 00 | 00 | 00 | 00 | ) . ) | | 60 | | | 53 | | | | . – | | 4C | 20 | 4C | 4F | 00 | 00 | 00 | 00 | SYSANAL LO | | 70 | 03 | DF | 00 | 00 | 00 | 70 | 00 | 00 | | | | 00 | | | | | | | 80 | | | 00 | | | | | | | | | 91 | | | | | ) . ) | | 90 | | | 00 | | | | | | 44 | 20 | 20 | 20 | 4C | 4F | 00 | 00 | VALID LO | | Α0 | 00 | 00 | 04 | 50 | 00 | 00 | 00 | 04 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | P | | В0 | | | 00 | | | | | | | | | 91 | | | | | ).).) | | CO | | | 00 | | | | | | 52 | 53 | 41 | 44 | 4F | 53 | 53 | 59 | VERSADOSSY | | D0 | 00 | 00 | 00 | 00 | 04 | 55 | 00 | 00 | 01 | FF | 00 | 00 | 00 | 00 | 00 | 00 | U | | E0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 29 | 91 | 29 | 91 | ) . ) . | | F0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | Next, the IPL reads the Loader Information Block (LIB) of the target file (that is, the first sector of the file). In the example VERSADOS.SY, which is the last directory entry in the PDB, notice the starting sector is \$455 and the length is \$1FF sectors. f. Read the LIB, first sector of the boot file only and determine the load address and length. Then determine if IPL must be relocated. IPL will have to be relocated if the target code must reside in the same place as IPL is currently loaded. IPL will then locate suitable memory outside of the boundary of the target boot file, and relocate itself. | | SN=\$0 | | 0 | | | | | | | | | | | | | | | |----|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------| | 00 | 56 | 45 | 52 | 53 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | VERS | | 10 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 01 | B5 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 20 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 30 | 00 | 00 | 00 | 00 | 56 | 45 | 52 | 30 | 00 | 00 | 10 | 00 | 00 | 01 | B0 | 00 | <b>V</b> ERO | | 40 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | FF | FF | FF | FF | • • • • • • • • • • • • • • • • • • • • | | 50 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | 60 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 70 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 80 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 90 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | A0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | B0 | 00 | 10 | 01 | BF | 00 | 00 | FF | FF | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | CO | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | D0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | E0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | F0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | - g. IPL now outputs the message "Boot in progress" and reads the target file from the disk and starting sector +1 for length -1. When the load is complete, IPL outputs the message "Boot complete". - h. IPL transfers control to the target code by setting the stack (A7) to the contents of offset 0 of the recently loaded file, and by setting the PC to the contents of offset \$4. | | SN=\$1 | | 1 | | | | | | | | | | | | | | | |----|--------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|-----------------------------------------| | 00 | 00 | 00 | 00 | 00 | 00 | 01 | B5 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 10 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 20 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 30 | 00 | 00 | 00 | 00 | 56 | 45 | 52 | 30 | 00 | | | 00 | | | | •• | VERO | | 40 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | FF | FF | FF | FF | | | 50 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 60 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 70 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | 80 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • | 00 | | | | | | | | | 90 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | A0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | | B0 | 00 | 10 | 01 | BF | 00 | 00 | FF | FF | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • | | CO | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | D0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | | | E0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • | | F0 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | 00 | • • • • • • • • • • • • • • • • • • • • | If the halt option was requested at boot time (;H), control will return to the MVME120 Debug Monitor. The boot sequence continues with transfer of control to the operating system initializer "INIT.LO". The following steps describe the INIT sequence. This code executes at interrupt level 7. a. Test for front panel. If one exists, display "BF". EXORmacs is the only system with a front panel displays. Determine if relocation of the operating system needs to take place. The parameter WHERLOAD (if not zero) contains the address to relocate the operating system. This only occurs with M68KVM01 systems with only 32Kb of RAM onboard. The MVME101 also has a status LED but at this point would not be changed. When VERSAdos is booted properly, a "d" will be displayed when the initializer is executed. - b. Set-up the vectors (\$0-\$400) using the VECTTBL.AB file assembled as RMSGEN time. - c. Build the Free Memory List describing the various memory partitions defined in INITDAT.AG - d. Set-up TCBHD and READYHD pointer in SYSPAR offsets \$10 and \$14. - e. Initialize the Memory Management Unit (MMU) (if one exists). JSR to routine in INITIO.AG, which was assembled at SYSGEN time. - f. Set up the following system tables from parameters in INITDAT.AG. !ASN Address Segment Number !GST Global Segment Table !UST User Semaphore Table !IOV I/O Vector Map !PAT Periodic Activation Table !UDR User deDined Directive Vector Use Table Trace Table Trap Assignment Table - g. Initialize any I/O device that may require initialization before dropping the interrupt mask. JSR to routine in INITIO.AG - h. Initialize the timer. JSR to routine in INITIO - i. Put "CO" in front panel (if one exists). - j. Jump to RMS68K dispatcher. Address of STARTRMS in INITDAT. RMS68K execution sequence continues next. All further execution is at interrupt level 0, timer running. The highest priority task on the ready list is placed into execution. This is normally IOI.LO -- the I/O Initializer task for the initialization of operating system tasks and device drivers. ## 10.3 IOI INITIALIZATION SEQUENCE Figure 10-1 shows the structure of the IOI initialization sequence. The following text describes the major tasks that are performed by IOI. - a. IOI gets a data segment called DIOI. - b. IOI then follows the CDB linked list allocating channels defined by each CDB macro. If the channel is present, the appropriate device driver is entered at the INIT entry point with a register pointing to the newly created CCB. The allocate call is a TRAP #1 with DO=60, that is handled by the RMS68K Channel Management Routine (CMR). If the channel is not present as indicated and with CMR receiving a Bus Error when trying to access the memory address specified in the CDB macro, an error is returned and IOI continues to the next CDB. - c. IOI declares the IOSG as globally shareable, then grants shared access of this segment to FMS. - d. IOI then calculates the size of an FMSD segment needed by FMS, based on various SYSGEN parameters. IOI makes a GTSEG call for this segment, declares the segment shareable, grants shared access of FMSD to IOS, and transfers the segment to FMS. - e. IOI then starts the File Management System task FMS. - At this point IOI relinquishes execution and allows FMS to run. FMS completes its initialization sequence and sets a bit in the System Value Table called the System Value Table System Task Configuration Flag (SVTSTCF). IOI is periodically given execution time while FMS is performing initialization, but IOI does not continue from the relinquish loop until FMS has set the required bit. (Refer to paragraph 10.4 for a description of the FMS initialization sequence.) - f. Once FMS has completed initialization, IOI continues to execute. - g. IOI grants shared access of the IOSG to FHS and starts FHS. IOI then relinquishes execution until FHS has completed and set its assigned bit in the SVTSTCF byte. - h. Once FHS has completed initialization, IOI continues execute. - i. IOI grants shared access of the IOSG to IOS and starts IOS. IOI then relinquishes execution until IOS has completed and set its assigned bit in the SVTSTCF byte. - j. IOS completes initialization and IOI continues to execute. At this point, all operating system tasks for which IOI is responsible have completed execution. - k. IOI now starts the Session Manager Task &EET and then terminates itself. This frees the memory segment containing the IOI code but leaves the IOSG segment which has been made globally shareable. FIGURE 10-1. IOI Initialization Sequence Structure ## 10.4 FMS BOOT SEQUENCE FUNCTIONS Figure 10-2 represents the "housekeeping" duties performed by FMS during the Boot sequence. The numbers in parentheses are the order of execution. - (1) IOI has issued a START for task FMS. - (2) FMS receives control with a register pointing to the FMSD segment that IOI has obtained and attached to FMS. FMS then divides this data segment into various functions areas, such as Volume Descriptor Table (VDT) space, File Control Block (FCB) space, File Assignment Table (FAT) space, Default Volume (DV) space, buffer space for File Access Blocks (FAB), and buffer space for Data Blocks (DB). - (3) FMS issues a GTASQ call to obtain an ASQ for message processing. - (4) FMS makes the GTTASKID calls to find out the ID of FHS. This ID will be used in all Queue Events. FIGURE 10-2. FMS Boot Sequence Functions Note in Figure 10-2 that FMSD segment has previously been allocated by IOI and attached to FMS. Once the housekeeping duties are complete, FMS will issue an GTEVNT call which is the idle state for FMS waiting for events to process. ## 10.4.1 Size of FMS Main Data Segment FMS has a data segment that is allocated at initialization time. The segment size is governed by four SYSGEN parameters: \NODIFFIL Maximum number of different files that can be opened at a single time. **\TOTDSK** Number of disk devices on the system. \NOFILES Maximum number of files that can be opened at a single time (not necessarily different). \NODEFVOL Maximum number of default volumes allowed at a single time. The data segment is partitioned into six functional areas: Stack VDT Storage FCB Storage FAT Storage DV Storage Buffer Storage The size of each partition is computed as: Stack &12\*(\NODIFFIL+1)+&100 VDT Storage \TOTDSK\*&374 FCB Storage FAT Storage \NODIFFIL\*&86 \NOFILES\*&144 DV Storage \NODEFVOL11.6\*&8 Buffer Storage \TOTDSK\*&1536 ### 10.4.2 FMS Dynamic Segments In addition to the data segment, FMS allocates dynamic segments for processing noncontiguous files. For each separate assignment to a noncontiguous file, FMS allocates a separate dynamic segment. The size of the segment will be equal to the size of a data block (1K by default, 2K if created by the Editor), plus the size of a FAB (0.25K default) plus 0.25K scratch pad area. If all defaults are used, a 1.5K dynamic segment will be allocated. The segment will be made globally shareable, thus an entry in the GST will also be required. Note that it would be possible to have several such segments in memory simultaneously for the same file if there were several assignments open to that file at the same time. ### 10.4.3 I/O Common Data Segment A data segment containing the Device Connection Queue (DCQ), Logical Unit Table (LUT), and Device Control Blocks (DCBs) is created at SYSGEN time. The size of each portion of the segment is computed as: | DESCRIPTION | SIZE (BYTES) | |-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------| | Header<br>DCQ Space<br>LUT Space<br>DCB Space | \$48 (&72) \$200 (&512) \NOTASKS*(\$10+\$8*(\MACLU+1)) Sum of Individual DCBs (Described below) (\$B8 (&184) per device for the worst case) | | | | NOTE: \NOTASKS is a SYSGEN parameter specifying the maximum number of tasks in the system at a single time. A DCB exists for each separate device on the system. The five types of devices allowed and the different sizes of each are: | <u>TYPE</u> | SIZE | (BYTES) | |--------------------------------------------------------|--------------------------------------|------------------------------------------------| | Terminals<br>Printers<br>Disk<br>Magnetic Tape<br>GPIB | \$B4<br>\$A4<br>\$A8<br>\$B6<br>\$B8 | (&180)<br>(&164)<br>(&168)<br>(&183)<br>(&184) | | | | | An initialization data segment consisting of Channel Data Blocks (CDBs) is required to set up the I/O common data segment. The segment size depends on the number of channels that are in the system. It is common for one channel to control more than one device. The size of the CDB is: CDB (All) \$2E (&46) per channel # 10.4.4 Operating System Task Sizes | FMS | Code Segment<br>Data Segment<br>ASQ<br>TCB | 20.50Kb Variable (Refer to paragraph 10.3.4) (\NOFILES+2)*\$5E rounded to \$100 bytes boundary. 0.50Kb RAM, Not ROMable. | |--------------------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | IOS (ROMable)<br>(TRAP #2 Server) | Code Segment<br>Data Segment<br>ASQ<br>TCB | 6.25Kb<br>0.50Kb<br>0.25Kb<br>0.50Kb RAM \$60 &96 bytes ROM | | FHS (ROMable)<br>(TRAP #3 Server) | Code Segment<br>Data Segment<br>ASQ<br>TCB | 5.00Kb<br>0.50Kb<br>0.25Kb<br>0.50Kb RAM \$60 &96 bytes ROM | | EET<br>(Root task for<br>session control) | Code Segment<br>Data Segment<br>2nd Data Segment<br>ASQ<br>TCB | 15.25Kb<br>0.75Kb<br>0.75Kb<br>\TOTTERM*2**\$1A<br>0.50Kb RAM, Not ROMable | | SCT<br>(Session Control<br>Task) | Code Segment<br>Data Segment<br>2nd Data Segment<br>ASQ<br>TCB | Shared with EET<br>0.75Kb<br>0.25Kb<br>0.25Kb<br>0.50Kb RAM, Not ROMable | | LDR<br>(Task Loader) | Code Segment<br>Data Segment<br>ASQ<br>TCB | 5.25Kb<br>0.75Kb<br>0.25Kb<br>0.50Kb RAM, Not ROMable | | IOI (ROMable)<br>(I/O<br>Initialization<br>Task) | Code Segment<br>Data Segment<br>TCB<br>CDB<br>I/O Common | 1.50Kb<br>0.50Kb<br>0.50Kb RAM \$60 &96 bytes ROM<br>Variable<br>Variable | IOI only runs during initialization time. After completion, the code segments and data segments are given back to the system. A separate SCT task exists for each session that is created on the system. They all share the same code segment with EET. # 10.4.5 RAM/ROM Sizes for Operating System Tasks | DESCRIPTION | SIZE | ROM | RAM | <u>COMMENTS</u> | |------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|----------------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FMS Code<br>IOS Code<br>FHS Code<br>EET Code<br>SCT Code<br>LDR Code<br>IOI Code | 20.50Kb<br>6.25Kb<br>5.00Kb<br>15.25Kb<br>Shared<br>5.25Kb<br>1.50Kb | N<br>Y<br>Y<br>N<br>N<br>N | Y<br>N<br>N<br>Y<br>Y<br>Y | ROMable | | FMS Data IOS Data FHS Data EET Data 1 EET Data 2 SCT Data 1 SCT Data 2 LDR Data IOI Data | Variable<br>0.50Kb<br>0.50Kb<br>0.75Kb<br>0.75Kb<br>0.25Kb<br>0.25Kb<br>0.25Kb | N<br>N<br>N<br>N<br>N<br>N | Y<br>Y<br>Y<br>Y<br>Y<br>Y | Obtained at SYSGEN time Dynamically obtained Dynamically obtained Obtained at SYSGEN time Obtained at SYSGEN time Dynamically obtained Dynamically obtained Dynamically obtained Dynamically obtained | | FMS ASQ<br>IOS ASQ<br>FHS ASQ<br>EET ASQ<br>SCT ASQ<br>LDR ASQ | Variable<br>0.25Kb<br>0.25Kb<br>Variable<br>0.25Kb<br>0.25Kb | N<br>N<br>N<br>N<br>N | Y<br>Y<br>Y<br>Y<br>Y | Dynamically obtained Dynamically obtained Dynamically obtained Dynamically obtained Dynamically obtained Dynamically obtained | | I/O Common<br>CDB<br>FMS TCB<br>IOS TCB<br>FHS TCB | Variable<br>Variable<br>0.50Kb<br>0.50Kb<br>0.50Kb | Y<br>Y<br>N<br>Y<br>Y | Y<br>N<br>Y<br>Y | Moved from ROM to RAM<br>&96 bytes in ROM<br>&96 bytes in ROM | | EET TCB<br>SCT TCB<br>LDR TCB | 0.50Kb<br>0.50Kb<br>0.50Kb | N<br>N<br>N | Y<br>Y<br>Y | Dynamically obtained | ### 10.5 FHS BOOT SEQUENCE FUNCTIONS Figure 10-3 represents the "housekeeping" duties performed by FHS during the Boot sequence. The numbers in parentheses are the order of execution. - (1) IOI has issued a "START" for task FHS. - (2) FHS gets control and issues a GTSEG call to obtain its data space, segment FHSD. - (3) FHS issues a GTASQ call to obtain an ASQ for message processing. - (4) FHS makes the GTTASKID call to find out the ID of IOS. This ID will be used in all Queue Events. - (5) FHS then issues the directive to establish itself as the TRAP #3 server. Once these housekeeping duties are complete, FHS issues a GTEVNT directive which effectively is an idle state for FHS waiting for an event. FIGURE 10-3. FHS Boot Sequence Functions ### 10.6 IOS BOOT SEQUENCE FUNCTIONS The following is a list of the "housekeeping" duties performed by IOS (in order of execution) during the boot sequence. ``` IOI TRAP #1,D0=13 Start task IOS. IOS TRAP #1,D0=1 Get a data segment called IOSD IOS TRAP #1,D0=31 Get an ASQ segment IOS TRAP #1,D0=10 Get task id of task FHS. IOS TRAP #1,D0=10 Get task id of task FMS. IOS TRAP #1,D0=51 Establish self as TRAP #2 server. ``` IOS walks the DCB list doing the following: - . Issue an attach channel (TRAP #1,D0=60) which causes CMR to make the appropriate CCB with the task and session number of IOS. - . TRAP #1,D0=60 to Initiate I/O to configure each device on this channel. IOS then waits for the completion event from the device driver and, if the device is a random access device (disk), IOS queues an event to FMS. IOS continues in this loop until the NULL device is reached. During this initialization, loop IOS occasionally issues the GTEVNT directive resulting in no immediate action. This enables other real-time tasks on the ready list to execute. FMS, as a result of receiving events from IOS for each of the disk devices, assigns the device via a TRAP #3 to a Logical Unit (LU). The LU sequence follows the pattern of the first device being LU 1, next LU 2 ... etc. until all disk devices have been assigned. initialization sequence performed by IOS, all three O/S real-time During the be executing. IOS, FHS, and FMS each will receive processor time tasks will as one or the other enters their GETEVNT state. This continues as all the devices in the DCB list are configured for default configuration, and the disk devices identified by FMS and Sector O are read and written back. The WRITE of Sector O occurs to determine if a device is write-protected. FMS configures each disk device with the MOUNT option bit to make all online, ready devices available for use. When this process is completed, IOS signals to IOI via a bit in the IOSG that all initialization has been completed. Each of the three real-time tasks sets a different bit such that the value is 7 when all initialization is complete. IOS is the last task to set its IOI then breaks out of its RELINQUISH loop and initialization-complete bit. starts the Session Manager Task &EET. Figure 10-4 is a diagram of the IOS Boot Sequence. Figure 10-5 depicts the Initialization Sequence Performed by IOS. FIGURE 10-4. IOS Boot Sequence FIGURE 10-5. Initialization Sequence Performed by IOS ## 10.7 SESSION MANAGER EXECUTION SEQUENCE The execution sequence performed by the Session Manager Task &EET is shown in Figure 10-6. FIGURE 10-6. Session Manager Execution Sequence The Entry/Exit Task (EET) is started by the I/O Initializer (IOI) after all other system tasks have executed their initialization sequences. The following description is for the major operating system functions performed by &EET (TRAPS #1, #2, #3, #4). &EET TRAP #1,D0=7 Declare its code segment as shareable. This code segment will be used by all &SCT task as sessions are created. | TRAP #1,D0=7 | Declare | STT | seament. | as | shareable. | |--------------|---------|-----|----------|----|------------| TRAP #1,D0=31 Get an ASQ. Used to "break" events and notify when an &SCT terminates (session logoff). TRAP #2 command \$8001 Establish self as system break claimer. This tells IOS where to send break events if not claimed by task assigned to the terminal. | | | | A C O | L 7 _ | A C D | |-------------------------|----------|-----------|---------|--------|-------| | TRAP #1 D0=33 Set ASQ s | status t | to enable | ASY and | enable | ASK. | TRAP #1 D0=21 Delay for 1000 ms. TRAP #1 D0=35 Queue an event to self. This is to simulate the break on a terminal used, if SYSGENed for autobreak. TRAP #1 D0=34 Read the event. TRAP #1 D0=11 Create a TCB for &SCT0001. Session Control Task (SCT) for session 0001. TRAP #1 D0=5 Grant shared access to &SCT0001 of &EET code segment. All SCTs use the same code but different data segments. TRAP #1 D0=1 Get a segment called .SCT. TRAP #1 D0=1 Get a segment called .ARG. TRAP #1 D0=6 MOVELL, move data from EET data segment to SCT data segment. This has the effect of priming SCT with certain useful data. TRAP #1 D0=31 Get an ASQ for &SCT0001. TRAP #1 D0=13 Start task &SCT. TRAP #1 D0=37 Return from event. TRAP #1 D0=33 Set ASQ to ASQ enabled TRAP #1 D0=36 Wait for event &SCT starts execution at this point. Figure 10-7 illustrates the &SCT Execution Sequence. From now on SCT controls all activity associated with this session. &EET is the monitor. FIGURE 10-7. &SCT Execution Sequence TRAP #1 D0=33 Set ASQ to ASQ enabled and ASR enabled. TRAP #3 Assign #CN00 to LU 0. This will be the LU that SCT uses for all I/O to the terminal. As a result of the TRAP #3, the server FHS executes to handle the building of the LU entry building of the LU entry. FHS TRAP #1 D0=6 (MOVELL) Move status to user parameter block. FHS TRAP #1 D0=54 (AKRQST) Acknowledge server request -- this allows &SCT to continue execution. FHS TRAP #1 D0=38 (GTEVNT) FHS idle state. &SCT TRAP #3 Assign #CN00 to LU 5 for read access. This becomes the standard input device and is passed to each task started under control of the SCT. Same FHS sequence is executed as above. (MOVELL>AKRQST>GTEVNT) &SCT TRAP #3 Assign #CN00 to LU 6 for write access. This becomes the standard output device and is passed to each task started under control of the SCT. Same FHS sequence is executed as previously described. 10 | &SCT | TRAP | #2 | |-------|------|-----| | α.π.ι | INAP | # / | Write command to CN00 to display the Logon message. As a result of the TRAP #2, the execution sequence that occurs is: IOS TRAP #1 DO=29 (RQSTPA) Start timer for I/O time-out. IOS TRAP #1 D0=60 (CMR) I/O command to device driver. IOS TRAP #1 D0=53 (DERQST) Enable ASQ for more server events. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. IOS TRAP #1 D0=29 (RQSTPA) Cancel timer event. IOS TRAP #1 D0=54 (AKRQST) Acknowledge server request. This allows user to continue. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. #### &SCT TRAP #3 Assign the file ERRORMSG.SY. This assignment is an indication to the SCT whether the default volume is ready for use. The following execution sequence occurs as a result of this assignment: FHS TRAP #1 D0=6 (MOVELL) Moves status to user parameter block. FHS TRAP #1 DO=35 (QEVNT) Queue an event to FMS. FHS TRAP #1 DO=53 (DERQST) Allows more server events. FHS TRAP #1 D0=38 (GTEVNT) FHS idle state. FMS TRAP #2 (READ) Read of sector \$27 (SDB). IOS TRAP #1 D0=60 (CMR) I/O command to device driver. IOS TRAP #1 D0=53 (DERQST) Allow server events. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. IOS TRAP #1 D0=54 (AKRQST) Acknowledge user task (FMS). IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. FMS TRAP #2 (READ) Read of sector \$28 (PDB) The same IOS sequence takes place as for the previous read. FMS TRAP #1 D0=74 (GTDTIM) Retrieve systems date and time. FMS TRAP #1 D0=6 (MOVELL) Moves VOL:USER.CAT. FILE.EX to requestor's parameter block SYS:0.&. ERRORMSG.SY. FMS TRAP #1 D0=54 (AKRQST) Acknowledge user. FMS TRAP #1 D0=38 (GTEVNT) FMS idle state. &SCT TRAP #3 (CLOSE) Close assignment of ERRORMSG.SY. FHS TRAP #1 D0=6 (MOVELL) Move status to user parameter block. FHS TRAP #1 D0=35 (QEVNT) Queue event to FMS. FHS TRAP #1 D0=53 (DERQST) Allow move server events. FHS TRAP #1 D0=38 (GTEVNT) FHS idle state. FMS TRAP #2 (WRITE) Write sector \$28 (PDB). IOS TRAP #1 D0=60 (CMR) I/O command to device driver. IOS TRAP #1 D0=53 (DERQST) Allow server events. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. IOS TRAP #1 D0=54 (AKRQST) I/O has completed, acknowledge user. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. FMS TRAP #1 D0=54 (AKRQST) FMS acknowledges user. FMS TRAP #1 D0=38 (GTEVNT) FMS idle state &SCT TRAP #3 Set default volume. FHS TRAP #1 D0=6 (MOVELL) Updates user parameter block status. FHS TRAP #1 D0=35 (QEVNT) Queues event to FMS. FHS TRAP #1 D0=53 (DERQST) Allow more server events. FHS TRAP #1 D0=38 (GTEVNT) FHS idle state. FMS TRAP #1 D0=54 (AKRQST) Acknowledge user. FMS TRAP #1 D0=38 (GTEVNT) FMS idle state. &SCT TRAP #3 Set default volume. &SCT TRAP #1 D0=6 (MOVELL) Moves default volume from SCT data segment to EET data segment. &SCT TRAP #2 (WRITE) One character write to clear screen. IOS TRAP #1 DO=29 (RQSTPA) Start timer for I/O time-out. IOS TRAP #1 D0=60 (CMR) I/O command to driver. IOS TRAP #1 D0=53 (DERQST) Allows server events. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. IOS TRAP #1 D0=29 (RQSTPA) Cancel time event. IOS TRAP #1 D0=54 (AKRQST) Acknowledge user. IOS TRAP #1 DO=38 (GTEVNT) IOS idle state. #### APPENDIX A #### **VERSAdos CONFIGURATION VALUES** #### A.1 DEVICE DRIVER CONFIGURATION TABLE Appendix A.1 contains a complete list of all device driver information relevant to the Channel Data Block. The information provided under each column heading is explained as follows: DRIVER Lists the name assigned to each device driver. Chip-type drivers are named by the popular name of the chip and drivers for VMEmodules are defined by the number of the module preceded by an "M". SYSTEM/BOARD Probable locations of chip-type drivers. CHANNEL NAME ASCII ID of the channel located in the Channel Control Block. CHANNEL TYPE Unique value used by drivers to verify channel identity. **ADDRESS** Defines the MMIO address where a device resides or, in some cases, the label of the parameter defined in SIO.ADDRESS.CI. VECTOR SOFT PRI Defaults defined for the drivers. NUMBER/LEVEL Relative position of the driver on the CCB list for multiple channels on the save vector. Higher values correspond to closer proximity to the head of the list. SIZE Size of driver (in bytes). CHIP NUMBER Number of the chip for a chip-type driver. VMEmodules are not listed in this column since module names are already listed in the DRIVER column. | | | CHANNEL | CHANNEL | | VECTOR | VECTOR | SOFT | | CHIP | |-----------|--------------|---------|---------------|----------|--------------|-----------|------|--------|--------| | DRIVER | SYSTEM/BOARD | NAME | TYPE | ADDRESS | NUMBER | LEVEL | PRI | SIZE | NUMBER | | ACIADRV | EXORmacs #1 | .cAcx. | XTACD1 (\$66) | \$FEE011 | \$88 | 5 | \$30 | \$300 | M6850 | | | EXORmacs #2 | .cAcx. | XTACD2 (\$67) | \$FEE015 | \$88 | 5 | \$30 | | M6850 | | | MVME110-1 | .cAcx. | XTX110 (\$68) | \$FE8001 | \$1D | 2 | \$30 | | M6850 | | DARTDRV | MVME115M #1 | .cDAx. | XTDRTA (\$6A) | \$F82001 | \$C2 | 5 | \$30 | | SCN268 | | | | 'CDAx' | XTDRTB (\$6B) | \$F82011 | \$C2 | 2 | \$30 | | SCN268 | | DRVLIB | ALL | | | | | | | | | | EPCIDRV | M68KVM01 #1 | 'CEPx' | XTEPCI (\$6E) | \$F70011 | \$10 | 2 | \$30 | | SCN268 | | | M68KVM01 #2 | 'CEPx' | XTEPCI (\$6E) | \$F70011 | \$1D | 2 | \$30 | | SCN268 | | | MVME101 | CEPx, | XTEPCI (\$6E) | \$FE00B1 | <b>\$</b> 1C | 4 | \$30 | | SCN268 | | IPCDRB | M68KVM20 #1 | 'CFD1' | XTDIPC (\$10) | DEVADD | VECTNO | 4 | \$10 | \$1500 | | | | M68KVM20 #2 | .CFD2' | XTDIPC (\$10) | DEVADD | VECTNO | 4 | \$10 | | | | | M68KVM21 #1 | .cnp1, | CTDIPC (\$10) | DEVADD | VECTNO | ٣ | \$10 | | | | | M68KVM21 #2 | .cnp5, | CTDIPC (\$10) | DEVADD | VECTNO | ٣ | \$10 | | | | | M68KVM30 #1 | . COM1 | XTMIPC (\$11) | LV30\$07 | \$F7 | 4 | \$10 | | | | | M68KVM30 #2 | COM2 | XTMIPC (\$11) | LV30\$06 | \$F6 | 4 | \$10 | | | | | M68KVM30 #3 | COM3 | XTMIPC (\$11) | LV30\$05 | \$F5 | 4 | \$10 | | | | | M68KVM30 #4 | COM4 | XTMIPC (\$11) | LV30\$04 | \$F4 | 4 | \$10 | | | | M300DRV | #1 | , BNS0, | XTGBUS (\$4A) | 1300\$01 | \$B0 | 4 | \$40 | \$1900 | | | | #2 | 'BUS1' | XTGBUS (\$4A) | 1300\$02 | \$B0 | 4 | \$40 | | | | M315DRV | | ,M315 | XTD315 (\$23) | L315\$01 | <b>\$</b> FF | ъ | \$10 | \$000 | | | M320DRV | | , M320, | XTD320 (\$25) | L320\$01 | \$FD | ٣ | \$10 | \$000 | | | M420DRV 5 | | ,SAS2, | XTDSAS (\$20) | L420\$02 | 10CVEC3 | IOCLVL3 | \$10 | \$300 | | | M420DRV 8 | | , SAS8, | XTDSAS (\$20) | L420\$01 | IOCVEC3 | IOCLVL3 | \$10 | \$300 | | | M435DRV | #1 | 'MTA0' | XTM435 (\$24) | L435\$01 | IOCVEC1 | IOCLVL1 | \$10 | \$F00 | | | | | MTA0 | XTM435 (\$24) | L435\$01 | 10CVEC2 | 10CLVL2 | \$10 | | | | | | 'MTA0' | XTM435 (\$24) | L435\$01 | 10CVEC3 | IOCLVL3 | \$10 | | | | | | MTA0 | XTM435 (\$24) | L435\$01 | IOCVEC4 | IOCLVL4 | \$10 | | | | | #2 | 'MTA1' | XTM435 (\$24) | L435\$02 | IOCVEC1 | IOCLVL1 | \$10 | | | | | | 'MTA1' | XTM435 (\$24) | L435\$02 | IOCVEC2 | IOCLVL2 | \$10 | | | | | | WTA1 | XTM435 (\$24) | L435\$02 | IOCVEC3 | IOCLVL3 | \$10 | | | | | | 'MTA1' | XTM435 (\$24) | 1435\$02 | 10CVFC4 | 10CI VI 4 | 410 | | | Device Driver Configuration Table (cont'd) | | | | | 5 | | ( ) ) ) ) ) ) ) | _ | | | |----------|----------------|---------|----------------|-----------------|-----------|-----------------|--------------|-------|-----------| | | | CHANNEL | CHANNEL | | VECTOR | VECTOR | SOFT | | CHIP | | DRIVER | SYSTEM/BOARD | NAME | TYPE | ADDRESS | NUMBER | LEVEL | PRI | SIZE | NUMBER | | M600DRV | #1 | , ADØ1. | \$80 | L600\$01 | I OCVEC 1 | IOCLVL1 | \$FF | \$500 | | | | #2 | , AD01, | \$80 | L600\$02 | IOCVEC1 | IOCLVL1 | \$<br>FF | | | | M605DRV | | 'DAC1' | \$80 | L605\$01 | IOCVEC1 | IOCLVL1 | \$50 | \$400 | | | M610DRV | #1 | · 1001 | \$80 | L610\$01 | 10CVEC1 | IOCLVL1 | \$<br>7<br>7 | \$700 | | | | #2 | .IN02. | \$80 | L610\$02 | 10CVEC2 | IOCLVL2 | \$FF | \$700 | | | M615DRV | | .DC01. | \$80 | L615\$01 | 10CVEC1 | IOCLVL1 | \$50 | \$600 | | | M625DRV | | ,DC01, | \$80 | L615\$01 | I OCVEC1 | IOCLVL1 | \$50 | \$500 | | | MFPDRV | MVME120 | .CMFP. | XTMFPO (\$6C) | \$F20001 | \$60 | 9 | \$30 | | MC68901 | | MPCCDRV | MVME050 #1 | . CMC× | XTMPC1 (\$72) | \$FF1000 | \$80 | 3 | \$30 | | R68560 | | | MVME050 #2 | .cMC×. | XTMPC2 (\$73) | \$FF1041 | \$81 | 3 | \$30 | | R68560 | | MPSCDRV | M68KVM02 A | .CMP× | XTS7A2 (\$60) | \$F70015 | \$80 | 9 | \$30 | \$700 | NEC7201 | | | M68KVM02 B | CMPx' | XTS7B2 (\$61) | \$F70017 | \$80 | 9 | \$30 | | NEC7201 | | | M68KVM03 A | .CMD×. | XTS7A3 (\$74) | \$F80065 | \$43 | 4 | \$30 | | NEC7201 | | | M68KVM03 B | .CMPx. | XTS7B3 (\$75) | \$F80067 | \$43 | 4 | \$30 | | NEC7201 | | | # | .CMPx. | XTS7AR (\$64) | L400\$01 | IOCVEC4 | IOCLVL4 | \$30 | | NEC7201 | | | MVME400 #1 B | .CMPx. | XTS7BR (\$65) | L400\$01+2 | IOCVEC4 | IOCLVL4 | \$30 | | NEC7201 | | | ∢ | , CMD×, | XTS7AR (\$64) | L400\$02 | IOCVEC4 | IOCLVL4 | \$30 | | NEC7201 | | | #2 B | .CMPx. | XTS7BR (\$64) | L400\$02+2 | IOCVEC4 | 10CLVL4 | \$30 | | NEC7201 | | PøSøDRV | MVME050 | 'CPRx' | XTPV050 (\$53) | \$FF1081 | \$8B | 2 | \$10 | \$700 | discretes | | P115DRV | MVME115M | .CPRx. | XTPV115 (\$54) | \$F81081 | \$C1 | 5 | \$10 | | M68230 | | P117DRV | MVME117 | .CPRx. | XTPV117 (\$ ) | \$F54001 | | | \$10 | | discretes | | | MVME117 #2 | .czix, | XTZI01 (\$79) | \$F48005 | | | \$30 | | Z8530 | | P.I AURV | EXORmacs | 'CPRx' | XTPEXM (\$50) | <b>\$FEE009</b> | \$8B | 2 | \$10 | \$600 | M6821 | | | MVME101 | 'CPRx' | XTPRTL (\$52) | \$FE00C1 | \$1B | 2 | \$10 | | M6821 | | | <b>∀</b><br>#: | 'CPRx' | $\overline{}$ | \$L410\$01 | IOCVEC1 | IOCLVL1 | \$10 | | M6821 | | | #1<br>B | .CPRx | _ | \$L410\$01+8 | IOCVEC1 | IOCLVL1 | \$10 | | M6821 | | | #2 ¥ | CPR×, | | \$L410\$01 | 10CVEC1 | IOCLVL1 | \$10 | | M6821 | | | MVME410 #2 B | .CPR×. | XTPRIL (\$52) | \$L410\$01+8 | I OCVEC 1 | JOCLVL1 | \$10 | | M6821 | Device Driver Configuration Table (cont'd) | DRIVER | CHANNI<br>SYSTEM/BOARD NAME | CHANNEL | CHANNEL | ∢ | ADDRESS | VECTOR<br>NUMBER | VECTOR VECTOR SOFT<br>NUMBER LEVEL PRI | | SIZE | CH I P<br>NUMBER | |---------------|-----------------------------|---------|-------------------------|----------|-----------|------------------|----------------------------------------|------|-------|------------------| | 7001670 | . ~ 800). +# + POPY/1897 | . >BB. | XTPVM1 (1\$51) \$F70020 | \$51) \$ | ;F70020 | \$1E | 9 | \$10 | | discretes | | V N U : 0 V N | M68KVM01 #2 | CPR×. | XTPVM1 (L\$51) \$F70022 | 551) \$ | F70022 | \$1E | 9 | \$10 | | discretes | | RADORV | | .RA01 | \$80 | | _RAD\$01 | 10CVEC3 | 10CVEC3 IOCLVL3 | \$20 | \$E00 | | | RIODRV | | 'RI01' | \$80 | _ | _RIO\$01 | 10CVEC3 | IOCVEC3 IOCLVL3 | \$20 | \$000 | | | RWINDRV | + | . INIM. | XTDWIN (\$21) | _ | LWIN\$01 | I OCVEC3 | 10CLVL3 | \$10 | \$800 | | | | ## == X | .WINZ, | XTDWIN (\$21) | | LWIN\$02 | 10CVEC3 | IOCLVL3 | \$10 | | | | STODRY | # ₹<br>M68KVM04 #1 | .xISO. | XTS100 (\$76) | | \$FFB0040 | \$44 | 22 | \$30 | | MK68564 | | | | .×.iso. | XTS100 (\$77) | | \$FFB0050 | \$44 | 5 | \$30 | | MK68564 | | TERMORV | VME/10 | .CN00. | XTSEXS (\$6F) | | \$8200 | \$42 | ы | \$30 | | | | TERMLIB | ALL | | | | | | | | | | | VM22DRV | | .VM22 | XTVM22 (\$12) | | DEVM22 | VECTNO | ы | \$10 | | | | ZIODRV | MVME117 #1 | 'CZIx' | XTZ100 (\$78) | | SF48001 | | | \$30 | | 28530 | # A.2 INTERRUPT/VECTOR LEVELS The following defines the relationship between Interrupt Levels and Vector values for the four interrupt capabilities on the I/O Channel. Note that IOCLVL1 corresponds to IOCVEC1, etc. | ======= | ===== | ===== | ===== | ====== | ===== | ======= | ========= | ======= | ======= | ====== | |-----------------------------------------------------------------|-----------------------------------------------|-----------------------------------------------|--------------------------------------------------|--------------------------------------------------|-----------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------| | VECTOR<br>LEVEL | EXOR<br>macs | VM01 | VM02 | VM03 | VM04 | VME101 | VME110-1 | VME115M | VME122 | VME/10 | | | | | | | | | | · | | | | IOCLVL1 IOCLVL2 IOCLVL3 IOCLVL4 IOCVEC1 IOCVEC2 IOCVEC3 IOCVEC4 | N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A | N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A | 2<br>3<br>4<br>5<br>\$71<br>\$72<br>\$73<br>\$74 | 3<br>4<br>5<br>6<br>\$49<br>\$4A<br>\$4B<br>\$4C | N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A<br>N/A | 3<br>4<br>5<br>2<br>\$1B<br>\$1C<br>\$1D<br>\$1A | 1<br>2<br>3<br>4<br>\$19<br>\$1A<br>\$1B<br>\$1C | 2<br>3<br>4<br>5<br>\$50<br>\$51<br>\$52<br>\$53 | 2<br>3<br>4<br>5<br>\$50<br>\$51<br>\$52<br>\$53 | 2<br>4<br>5<br>6<br>\$41<br>\$43<br>\$44<br>\$45 | | | | | | | | | | | | | #### A.3 SYSGEN PARAMETER MATRIX The following matrix defines the values for all SYSGEN parameters for several VMEsystem configurations. The CSYSTEMS.SYMBOLS.LS listings provide convenient references to determine the location of each parameter. Note that the parameters for the MVME120 also apply to the MVME121, and the parameters for the MVME122 also apply to the MVME123. | Parameter | VHE101 | VHE110 | VME115 | VHE120 | VHE122 | VMES10 | |-----------|----------------|----------------|--------------------|--------------|-------------|------------------| | &ADDRESS | _ | \$FE60E1 | - | - | <b> -</b> | - | | &CRTDV | \$434E3032 | \$434E3033 | \$434E3032 | \$434E3033 | \$434E3033 | \$434E3033 | | &DEFVOL | \$4 | <b>\$</b> 6 | \$4 | <b>\$</b> 6 | <b>\$</b> 5 | <b>\$</b> 6 | | &DEVADD | - | - | - | <del>-</del> | [- | - | | &DSKDV | \$2F00 | \$2F00 | \$2F00 | \$2F00 | \$2F00 | \$2F00 | | &FILENAM | &. XPIA101. SI | &. XPIA410.SI | - | - | - | & XPIA410.SI | | &IOCBASE | \$0 | \$FE6000 | <b>\$</b> FFE000 | \$FFE000 | \$FFE000 | <b>\$</b> F1C000 | | &M4200 | - | 'H5WIN15' | - | - | - | - | | &M4201 | - | 'HSWIN15' | - | - | - | - | | &M4202 | ]- | 'F5000SI' | - | - | - | - | | &H4203 | - | 'F5000SI' | - | - | - | - | | &M420FLG | \$0 | \$1 | \$0 | \$0 | \$0 | \$0 | | &MPSCFLG | \$0 | <b>\$</b> 1 | <b>\$</b> 0 | \$0 | \$0 | \$1 | | &NF420 | <b> -</b> | \$2 | - | - | - | - | | &NH420 | - | <b>\$</b> 1 | - | - | - | - | | &PCDRV | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | &PIAFLAG | \$1 | <b>\$</b> 1 | \$0 | \$0 | \$0 | \$1 | | &PRTDV | \$50523120 | \$50523120 | <b>\$5052</b> 3120 | \$50523120 | \$50523120 | \$50523120 | | &SDRVADD | - | \$49400 | - | - | - | \$8600 | | &SDRVR | - | MSPR | - | - | - | MSPR | | &SERFLAG | \$1 | \$2 | \$1 | \$2 | \$2 | \$1 | | &SPRFLAG | \$0 | <b>\$</b> 1 | \$0 | \$0 | \$0 | \$1 | | &SUPFLAG | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | &T | - | - | - | \$F80006 | \$F80006 | <del>-</del> | | &TOTDSK | \$6 | <b>\$</b> D | <b>\$</b> 5 | \$A | \$A | \$2 | | &TOTPRT | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | &TOTTERM | \$2 | \$3 | \$2 | \$3 | \$3 | \$3 | | &VECTNO | - | - | - | - | - | - | | ACIADRV | - | \$49100 | ļ <b>-</b> | - | - | - | | ASMLS | SYSCEN. TF | SYSGEN. TF | SYSGEN. TF | SYSGEN. TF | SYSGEN. TF | SYSGEN. TF | | ASMLSW | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | ASN | \$0 | \$0 | \$7F | \$7F | \$7F | \$7F | | AUTOLOGN | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | AUTOTERM | 'CN00' | 'CN00' | 'CN00' | , CN00, | 'CN00' | ,CN00, | | BATCHPGE | \$2 | \$2 | \$2 | \$2 | \$2 | \$2 | | BATDLY | \$3E80 | <b>\$3E</b> 80 | \$3E80 | \$3E80 | \$3E80 | \$3E80 | | BCLRV | - | - | - | - | 1- | - | | CACHE020 | - | - | - | - | - | - | | Parameter | VME101 | VME110 | VHE115 | VHE120 | VHE122 | VMES10 | |------------|---------------|------------|-----------|-----------|-----------|------------| | CACHEF | \$30 | \$0 | \$0 | \$F80006 | \$F80006 | \$0 | | CACHESO | _ | _ | - | _ | - | - | | CACHESI | | - | _ | - | 1- | - | | CACHELID | _ | - | - | - | - | - | | CACHEUI | _ | - | - | _ | - | - | | CHAINBAT | <b>35</b> 3 | \$1 | \$1 | \$1 | \$1 | \$1 | | CLOCKFRO | <b>\$3</b> 20 | \$320 | \$7A1200 | \$0 | \$0 | \$0 | | CMULT | _ | \$2 | \$2 | \$2 | \$2 | \$2 | | CONBATCH | \$3 | \$1 | \$1 | \$1 | \$1 | \$1 | | CONT3151 | la | 3 | - | 1 | 11 | <b>j</b> - | | CONT3152 | 1 | 3 | - | 6 | 6 | - | | CONT320 | - | 4 | 0 | 0 | 0 | - | | CONT4205 | - | 1 | - | - | - | - | | CONTWIN1 | _ | o | 2 | 2 | 2 | 0 | | CONTWIN2 | - | 5 | 15 | 5 | 5 | 1 | | DARTORV | - | - | \$18100 | 1- | - | - | | DARTSPR | - | - | \$17F00 | - | - | - | | DCP\$RTD | so so | \$0 | \$0 | \$0 | \$0 | \$0 | | DCP\$VSS | \$100 | \$100 | \$100 | \$100 | \$100 | \$100 | | DCPSWTD | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | DOUPGE | 2 | \$2 | \$2 | \$2 | \$2 | \$2 | | DEFAULT | SYS: 0. & | 3YS: 0, & | SYS: 0. & | SYS: 0. & | SYS: 0. & | SYS: 0. & | | DEFDAT | <b>S</b> 4 | \$4 | \$4 | \$4 | \$4 | \$4 | | DEFFAB | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | DPR:/AO | _ | _ | - | _ | - | - | | DRVL | \$14E00 | \$44E00 | \$15200 | \$6200 | \$6000 | \$6300 | | EET'S | SI . | \$1 | \$1 | \$1 | \$1 | \$1 | | EETSTR | \$20000 | \$52900 | \$21300 | \$13100 | \$12F00 | \$15000 | | EPCIDRV | \$17000 | - | - | _ | - | - | | FAIL | _ | <b> </b> - | - | - | - | - | | FHS\$10S\$ | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | FHSASR | \$17A02 | \$4A302 | \$18002 | \$AB02 | \$A902 | \$CA02 | | FHSSTR | \$17A00 | \$4A300 | \$18000 | \$AB00 | \$A900 | \$CA00 | | FMS\$ | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | FMSASR | \$1AC02 | \$40502 | \$1BF02 | \$0002 | \$0802 | \$FC02 | | FMSSTR | \$1AC00 | \$40500 | \$1BF00 | \$0000 | \$0800 | \$FC00 | | FOUR | 4 | 4 | 4 | 4 | 4 | 4 | | GST | <b>52</b> | \$3 | \$2 | \$3 | \$3 | \$3 | | Parameter | VHE101 | VHE110 | VHE115 | VHE120 | VHE122 | VMES10 | |------------------|------------------|----------|------------------|------------------|-----------|----------| | HOGHODE | - | - | - | _ | 1- | _ | | INTSTR | \$227200 | \$5A600 | \$28400 | \$18800 | \$18600 | \$10100 | | IOCBASE | \$00 | \$FE6000 | \$FFE000 | \$FFE000 | SFFE000 | \$F10000 | | IOCLVL1 | \$33 | \$1 | \$2 | \$2 | \$2 | \$2 | | IOCLVL2 | \$44 | \$2 | \$3 | \$3 | \$3 | \$4 | | IOCLVL3 | <b>\$6</b> 5 | \$3 | \$4 | \$4 | \$4 | \$5 | | IOCLVL4 | \$22 | \$4 | \$5 | \$5 | \$5 | \$6 | | IOCM | ITESG | IOSG | IOSG | IOSG | IOSG | IOSG | | IOCSTR | \$22,5000 | \$58600 | \$27000 | \$18E00 | \$18C00 | \$1AD00 | | IOCVEC1 | \$18 | \$19 | \$50 | \$50 | \$50 | \$41 | | IOCVEC2 | \$-1C | \$1A | \$51 | \$51 | \$51 | \$43 | | IOCVEC3 | \$-10 | \$18 | \$52 | \$52 | \$52 | \$44 | | IOCVEC4 | \$174 | \$1C | \$53 | \$53 | \$53 | \$45 | | IOSASR | \$19002 | \$48902 | \$1A302 | <b>\$</b> C102 | \$8F02 | \$E002 | | IOSSTR | \$19000 | \$48900 | \$1A300 | \$C100 | \$8F00 | \$E000 | | VOI | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | IPCDRV | - | - | 1- | - | 1_ | 1- | | (BDOVRD | - | - | - | l_ | _ | \$0 | | (ILVECT | _ | - | - | <b> </b> _ | _ | - | | .050\$01 | \$FFF1000 | \$FF1000 | <b>\$</b> FF1000 | SEFF 1000 | SEFF 1000 | \$FF1000 | | .300\$01 | \$FF0400 | \$FF0400 | <b>S</b> FF0400 | \$FF0400 | \$FF0400 | \$FF0400 | | .300\$02 | <b>\$</b> FF0440 | \$FF0440 | <b>SFF</b> 0440 | \$FF0440 | SFF0440 | \$FF0440 | | .315\$01 | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | | 315\$02 | \$FF0200 | \$FF0200 | \$FF0200 | <b>\$</b> FF0200 | \$FF0200 | \$FF0200 | | 320\$01 | \$FFB000 | \$FF8000 | SFFB00D | \$FFB000 | SFFB000 | SFFB000 | | 320\$02 | \$FFACOD | SFFAC00 | SFFACOD | SFFACOD | SFFACOD | \$FFACOD | | 331 <b>\$</b> 01 | \$FF3000 | \$FF3000 | \$FF3000 | \$FF3000 | \$FF3000 | \$FF3000 | | 331\$02 | \$FF3100 | \$FF3100 | <b>\$</b> FF3100 | \$FF3100 | SFF3100 | \$FF3100 | | 331\$03 | \$FF3200 | \$FF3200 | <b>S</b> FF3200 | \$FF3200 | \$FF3200 | \$FF3200 | | 331\$04 | \$FF3300 | \$FF3300 | <b>\$</b> FF3300 | <b>S</b> FF3300 | \$FF3300 | \$FF3300 | | 331 <b>\$0</b> 5 | \$FF3400 | \$FF3400 | <b>SFF3400</b> | <b>S</b> FF3400 | \$FF3400 | \$FF3400 | | 331\$06 | \$FF3500 | \$FF3500 | \$FF3500 | \$FF3500 | \$FF3500 | \$FF3500 | | 333\$01 | \$FF3800 | \$FF3800 | \$FF3800 | \$FF3800 | \$FF3800 | \$FF3800 | | 333\$02 | \$FF3900 | \$FF3900 | <b>\$</b> FF3900 | \$FF3900 | \$FF3900 | \$FF3900 | | 333\$03 | SFF3A00 | \$FF3A00 | \$FF3A00 | SFF3A00 | SFF3A00 | SFF3A00 | | 333\$04 | \$FF3B00 | \$FF3B00 | \$FF3B00 | \$FF3B00 | \$FF3B00 | \$FF3800 | | 333\$05 | \$FF3C00 | \$FF3C00 | \$FF3C00 | \$FF3C00 | SFF3C00 | \$FF3C00 | | 333\$06 | \$FF3D00 | | | \$FF3000 | \$FF3000 | \$FF3000 | | - | SFE61CD<br>SFE61AD | \$FFE100 | | | 1 | |------------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | \$FE61AD | | \$FFE1CO | SFFE1CD | \$F1C1CD | | - | | \$FFE1AD | SFFE 1AD | SFFE1AD | \$F1C1AD | | | \$FE61E1 | \$FFE1E1 | SFFE1E1 | \$FFE1E1 | \$F101E1 | | _ | <b>\$</b> FE6121 | \$FFE121 | \$FFE121 | \$FFE121 | \$F1C121 | | - | \$FE60F1 | \$FFE0F1 | SFFE0F1 | \$FFE0F1 | \$F1C0F1 | | - | \$FE60E1 | \$FFE0E1 | \$FFE0E1 | SFFE0E1 | \$F1C0E1 | | - | \$FE63E9 | \$FFE3E9 | \$FFE3E9 | \$FFE3E9 | \$F1C3E9 | | - | \$FE63A9 | \$FFE3A9 | \$FFE3A9 | \$FFE3A9 | \$F1C3A9 | | _ | SFE7E03 | \$FFFE03 | \$FFFE03 | \$FFFE03 | \$F10E03 | | - | \$FE7C03 | \$FFFC03 | \$FFFC03 | \$FFFC03 | \$F10C03 | | - | \$FE1601 | \$FFF601 | <b>\$</b> FFF501 | <b>\$</b> FFF601 | \$F1D601 | | - | \$FE6005 | \$FFE005 | \$FFE005 | \$FFE005 | \$F1C005 | | _ | \$FE6009 | \$FFE009 | \$FFE009 | \$FFE009 | \$F1C009 | | - | \$FE6003 | \$FFE003 | \$FFE003 | \$FFE003 | \$F1C003 | | _ | \$FE6001 | SFFE001 | SFFE001 | \$FFE001 | \$F1C001 | | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | \$24600 | \$56F00 | \$25900 | \$17700 | \$17500 | \$19600 | | SYSGEN. TE | SYSGEN, TF | SYSGEN, TF | SYSGEN, TF | SYSGEN. TF | SYSGEN. TF | | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | • | VERSAdos | VERSAdos | VERSAdos | VERSAdos | VERSAdos | | | _ | <b>SF</b> 81001 | _ | _ | - | | - | - | - | _ | - | - | | _ | SFF6E01 | SFFEE01 | SFFEE01 | SFFEE01 | \$F10E01 | | _ | 1 * | <b>S</b> FFE021 | SFFE021 | \$FFE021 | \$F10021 | | SEFOOA1 | 1 | \$F82001 | \$F20001 | \$F20001 | _ | | <b>4. 4. 4. . . . . . . . . . </b> | 1 ** | 1 4. 4-44 | - | - | - | | + | 1 * - | · · · | so | <b>S</b> 20 | \$5 | | - | * · - | 1 * - | \$FF1000 | \$FF 1000 | \$FF1000 | | 4 | 14 | | SFF 1200 | SFF 1200 | \$FF1200 | | T | | SFF 1400 | SFF1400 | SFF 1400 | \$FF1400 | | | 1 | 1 | SFF 1600 | SFF 1600 | \$FF1600 | | - | | 1 | SFFE0D3 | | \$F1C0D3 | | - | • | | SFFE0E3 | | \$F1C0E3 | | 'HSWTN10' | 1 | _ | 1 | | - | | | | _ | 1 | | _ | | | , | _ | 1 | | - | | | | _ | 1 | | l <u>-</u> | | | | _ | 1 | 1 | - | | | \$24600 | - SFE60E1 - SFE63E9 - SFE63E9 - SFE63A9 - SFE7C03 - SFE7C03 - SFE6005 - SFE6005 - SFE6009 - SFE6003 - SFE6001 \$1 \$24600 S56F00 SYSGEN. TF SYSGE | SFE60E1 SFFE0E1 | - \$FE60E1 \$FFE0E1 \$FFE0E1 \$FFE0E1 \$FE63E9 \$FFE3E9 \$FFS3E9 \$FFE3E9 \$FFE3E9 \$FFE3E9 \$FFE3E9 \$FFE3E9 \$FFE3E9 \$FFE3E9 \$FFS | - \$FE60E1 \$FFE0E1 \$FFE0E29 \$FFE3E9 \$FF | | Parameter | VHE101 | VME110 | VME115 | VHE120 | VHE122 | VHES10 | |-------------------|-----------|-------------|-----------|--------------|-----------|----------| | M3154\$2 | 'F8SDDSH' | 'F8S00SM' | - | "F8S009M" | 'F8SDDSM' | ]_ | | M3155\$1 | 'F8SDDSM' | 'F8S00SM' | - | "F8SDDSM" | 'F8SDOSM' | - | | M3155\$2 | 'F8SDDSH' | 'F8S00SM' | - | "F8SDOSM" | 'F8SDDSM' | _ | | M3156\$1 | 'F5000SI' | 'F5000SI' | - | "F5DDDSI" | 'F5DDDSI' | - | | M3156\$2 | 'F5000SI' | 'F5000SI' | - | "F5000SI" | 'F5000SI' | - | | M3157\$1 | 'F5000SI' | 'F5DDDSI' | - | "F5000SI" | 'F5000SI' | - | | M3157\$2 | 'F5DDDSI' | 'F5000SI' | ]- | "F5DODSI" | 'F5000SI' | - | | M315DRV | \$16300 | \$47700 | - | \$38400 | \$8200 | - | | M320 <b>\$D</b> D | - | \$36 | \$36 | \$≊36 | \$36 | - | | M320 <b>\$H</b> D | - | <b>\$</b> F | \$F | \$F | \$F | - | | M320\$LT5 | - | \$23 | \$23 | \$23 | \$23 | - | | M320\$LT8 | - | \$23 | \$23 | \$23 | \$23 | - | | M320\$LTH | - | \$0 | \$0 | \$20 | \$0 | - | | M320\$SD | - | \$1B | \$18 | <b>\$</b> 18 | \$1B | - | | M320\$ST5 | - | <b>\$</b> F | \$F | \$2F | \$F | - | | M320\$ST8 | - | \$F | \$F | \$F | \$F | - | | M320\$STH | - | \$0 | \$0 | \$90 | \$0 | - | | M3200\$1 | - | 'H5WIN15' | 'H5WIN15' | 'HSWIN15' | 'HSWIN15' | - | | 13201\$1 | - | 'HSWIN15' | 'H5WIN15' | 'HSWIN15' | 'HSWIN15' | - | | H3202\$1 | _ | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5DDDSI' | - | | 13203\$1 | - | 'F8SDSSI' | 'F8SDSSI' | 'F8SDSSI' | 'F8SDSSI' | 1- | | 13200RV | - | \$48400 | \$16700 | \$7700 | \$7500 | - | | 142050\$1 | - | 'H5WIN15' | - | - | - | - | | 142051\$1 | _ | 'HSWIN15' | - | - | _ | - | | 142052\$1 | - | 'F5000SI' | - | - | 1_ | _ | | 142053\$1 | - | 'F5DDOSI' | - | <del>-</del> | _ | - | | 1420DRV | _ | \$46E00 | _ | - | - | - | | 1AXLU | \$9 | \$10 | \$8 | \$0 | \$0 | \$8 | | EHBEG | \$17A00 | \$4A300 | \$18000 | \$AB00 | \$A900 | \$CA00 | | EMEND1 | \$200000 | \$200000 | \$200000 | \$27F00 | \$27F00 | \$2FF00 | | EHEND2 | \$0 | \$0 | \$0 | \$27F00 | \$27F00 | \$2FF00 | | EMENO3 | \$0 | \$0 | \$0 | \$200000 | \$200000 | \$280000 | | FPDRV | - | _ | - | \$9000 | \$9A00 | - | | MU | \$0 | \$0 | \$1 | \$1 | \$0 | \$1 | | PCCDRV | - | - | - | \$A000 | \$9E00 | - | | PSCORV | _ | \$49600 | - | - | - | \$8000 | | PSCSPR | _ | \$49400 | _ | _ | _ | \$8600 | | PSCSUP | <b>_</b> | - | _ | _ | _ | - | | Parameter | VME101 | VMEI 10 | VHE115 | VHE120 | VHE122 | VHES10 | | |------------------|-----------|-------------|-------------|-------------|-------------|-------------|--| | | \$4 | \$4 | - | \$4 | \$4 | | | | NF315\$1 | \$0 | \$0 | _ | \$0 | \$0 | - | | | NF315\$2 | - | \$1 | \$1 | \$1 | \$1 | - | | | NF320\$1 | 1_ | \$2 | - | - | - | - | | | NF4205\$1 | 1 | - | <b> </b> _ | _ | - | - | | | NF4208\$1 | 1_ | \$2 | \$2 | \$2 | \$2 | \$1 | | | NFRUIN\$1 | | \$0 | \$0 | \$0 | \$0 | \$0 | | | NFRWINS2 | 1 | - | - | 1. | - | - | | | NFV20\$1 | - | | 1_ | _ | - | - | | | NFV20\$2 | - | _ | _ | _ | _ | - | | | NFV21\$1 | - | 1_ | 1_ | <b> </b> _ | <b> </b> _ | - | | | NFV21\$2 | <b> </b> | 1_ | <u> </u> | _ | _ | - | | | NFV22\$1 | - | | 1_ | \$1 | \$1 | - | | | NH315\$1 | \$2 | \$1 | <u>-</u> | \$0 | \$0 | - | | | NH315\$2 | - | \$0 | 1 | \$1 | \$1 | 1- | | | NH320\$1 | <b> -</b> | \$1 | \$1 | <b>3</b> 1 | - | _ | | | NH4205\$1 | - | \$1 | - | 1_ | | 1_ | | | NH4208\$1 | - | - | - | | \$1 | \$1 | | | NHRUIN\$1 | - | \$1 | \$1 | \$1 | 1 ' | \$0 | | | NHRWIN\$2 | <b>[-</b> | \$0 | <b>\$</b> 0 | \$0 | \$0 | - | | | NHV21\$1 | - | - | - | - | - | 1_ | | | NHV21\$2 | - | - | - | 1- | - | - | | | NHV22\$1 | - | <b> -</b> | - | - | 1- | <b>\$</b> 6 | | | NODEFVOL | \$4 | <b>\$</b> 5 | \$4 | <b>\$</b> 5 | <b>\$</b> 5 | | | | NODIFFIL | \$18 | \$1E | \$18 | \$1E | \$1E | \$1E | | | NOFILES | \$18 | \$1E | \$18 | \$1E | \$1E | \$1E | | | NOLOGON | \$3 | <b>\$</b> 3 | <b>\$</b> 3 | \$3 | \$3 | \$3 | | | NOLOGONS | \$2 | \$3 | \$2 | \$3 | \$3 | . \$3 | | | NOLPRT | \$1 | _ | \$1 | - | - | - | | | NOLTERM | \$2 | \$1 | \$2 | \$1 | \$1 | \$1 | | | NORWIN | \$0 | \$1 | \$1 | \$1 | \$1 | \$1 | | | NOTASKS | \$C | \$F | \$C | \$F | \$F | \$F | | | NOTINT | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | NOVM20 | _ | - | - | 1- | - | 1- | | | | 1_ | _ | 1- | - | - | - | | | NOVM21<br>NOVM22 | | \_ | - | - | <b> -</b> | 1- | | | | _ | ]_ | 1- | Ţ | - | - | | | NOVM30 | <u>-</u> | 1_ | - | \$1 | \$1 | - | | | NP050\$1 | 1 | - | <b> </b> _ | - | 1- | - | | | NPV30\$1 | - | | | | | | | | Parameter | VME101 | VHE110 | VHE115 | VHE120 | VHE122 | VHES10 | | | | | |-----------|------------|------------|---------|----------------|---------|-------------|--|--|--|--| | NPV30\$2 | - | _ | - | - | - | - | | | | | | NPV30\$3 | - | - | - | 1 | - | - | | | | | | NPV30\$4 | - | - | - | \ <del>-</del> | - | | | | | | | NRAD | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NRIO | \$0 | \$0 | \$0 | \$0 | \$0 | \$3 | | | | | | NT050\$1 | - | - | - | \$2 | \$2 | - | | | | | | NTV30\$1 | - | - | - | - | - | - | | | | | | NTV30\$2 | - | - | - | - | 1- | - | | | | | | NTV30\$3 | - | - | - | - | - | - | | | | | | NTV30\$4 | - | - | - | - | - | 1_ | | | | | | NU400\$1 | _ | \$2 | - | 1- | - | \$2 | | | | | | NU400\$2 | _ | \$0 | - | - | - | - | | | | | | NU410\$1 | 1- | \$1 | - | - | - | \$1 | | | | | | NU410\$2 | ļ <u> </u> | \$0 | - | - | - | \$0 | | | | | | NVME050 | \$0 | \$0 | \$0 | \$1 | \$1 | \$0 | | | | | | NVME300 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME315 | \$1 | \$1 | \$0 | \$1 | \$1 | \$0 | | | | | | NVME316 | \$0 | \$0 | \$1 | \$1 | \$1 | \$0 | | | | | | NVME320 | \$0 | \$1 | \$1 | \$1 | \$1 | \$0 | | | | | | NVME400 | \$0 | \$1 | \$0 | \$0 | \$0 | <b>\$</b> 1 | | | | | | NVME410 | \$0 | \$1 | \$0 | \$0 | \$0 | <b>\$</b> 1 | | | | | | NVME4205 | | \$1 | - | - | - | | | | | | | NVME4208 | 1_ | \$0 | - | - | - | ļ | | | | | | NVME4206 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | - | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME600 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME605 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME610 | \$0<br>\$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME615 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME620 | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | NVME625 | SFFF | SFFF | SFFF | SIFFFF | \$1FFFF | \$05FFFF | | | | | | OFFBO\$HI | 1 ** | \$0 | \$0 | \$0 | \$0 | \$000000 | | | | | | OFFBOSLO | \$0 | SFFF | SFFF | \$1FFFF | \$1FFFF | \$SFFFF | | | | | | ONBOSHI | \$FFF | \$0 | \$0 | \$0 | \$0 | \$0 | | | | | | ONBOSLO | \$0 | <b>5</b> 0 | | \$A400 | \$A200 | - | | | | | | POSODRV | - | 1_ | \$18600 | 12,100 | - | - | | | | | | P115DRV | - | E100 | \$100 | \$800 | \$800 | \$100 | | | | | | PAGESIZE | \$100 | \$100 | \$0 | \$000 | \$0 | \$0 | | | | | | PANEL | \$0 | \$0 | 40 | | | | | | | | | Parameter | VHE101 | VHE110 | VHE115 | VME120 | VHE122 | VMES10 | |-----------|--------------|---------------|-------------|-----------|-------------|-------------| | PAT | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | PCDRV | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | POPSAFF | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | PCPSELC | \$20 | \$0 | \$0 | \$0 | <b>\$</b> D | <b>\$</b> D | | POPSL NED | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | POPSLRL | \$84 | \$84 | \$84 | \$84 | \$84 | \$84 | | POPSREC | <b>\$B</b> 4 | \$84 | \$84 | \$84 | \$84 | \$84 | | POPSRSZ | \$42 | \$42 | \$42 | \$42 | \$42 | \$42 | | POPSTLRL | \$0 | \$0 | <b>\$</b> 0 | \$0 | \$0 | \$0 | | POPSWITD | \$10400 | \$1D4C0 | \$1D4C0 | \$1D4C0 | \$1D4C0 | \$1D4C0 | | PIADRV | \$17400 | \$49000 | - | - | - | \$C400 | | PTHVECT | - | - | - | - | - | - | | PV01DRV | _ | _ | - | - | - | - | | RAMSSID | \$0 | \$0 | \$0 | \$0 | \$0 | \$000000 | | REVNUMBR | 4. 4 | 4.4 | 4. 4 | 4.4 | 4. 4 | 4.4 | | ROMEADOR | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | ROMSADOR | \$10000 | \$40000 | \$10000 | \$1000 | \$1000 | \$1000 | | RWINOS1 | _ | 'H5WIN15' | 'HSWIN15' | 'H5WIN15' | 'HSWIN15' | 'HSWIN15' | | RWINOS2 | _ | 'H5WIN15' | 'HSWIN15' | 'H5WIN15' | 'H5WIN15' | 'HSWIN15' | | RWIN1\$1 | _ | 'HSWIN15' | 'H5WIN15' | 'HSWIN15' | 'HSWIN15' | 'HSWIN15' | | RWIN1\$2 | _ | 'HSWIN15' | 'HSWIN15' | 'H5WIN15' | 'HSWIN15' | 'HSWIN15' | | RWIN2\$1 | _ | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5000SI' | | RWIN2\$2 | I_ | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5DDDSI' | | RWIN3\$1 | _ | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5000SI' | 'F5000SI' | | RWING\$2 | 1_ | 'F5000SI' | 'F5000SI' | 'F5DDDSI' | 'F5000SI' | 'F5DDDSI' | | RWINDRV | I <u>-</u> | \$46300 | \$17400 | \$9100 | \$8F00 | \$7800 | | SECURITY | \$1 | \$1 | \$1 | \$1 | <b>\$</b> 1 | \$1 | | SERFLAG | \$1 | \$2 | \$1 | \$2 | \$2 | \$1 | | SERPRIS | 1- | - | - | - | - | - | | SET1 | - | <u>-</u> | - | DONT-CARE | DONT-CARE | - | | SET2 | - | - | - | - | - | - | | SIDBASE | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | \$FF0000 | | SIDDRV | - | - | _ | - | 1- | - | | SIX | 6 | 6 | 6 | 6 | 6 | 6 | | SPCCHO | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | STACK | \$000 | <b>\$</b> C00 | \$000 | \$000 | \$000 | \$E00 | | STARTRMS | \$10100 | \$40100 | \$10100 | \$1100 | \$1100 | \$1100 | | SWABRT | - | _ | 1_ | 1. | _ | l <b>-</b> | | Parameter | VHE101 | VHE110 | VME115 | VME120 | VHE122 | VMES10 | | |-------------------|-----------|-----------------|-----------|-----------------|----------------|---------------------|--| | SYSFAIL | - | <b>-</b> | - | - | - | _ | | | TOP\$BITS | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$BRC | \$3 | \$3 | \$3 | <b>\$</b> 3 | \$3 | \$3 | | | TCP <b>\$B</b> RT | \$E | \$E | \$E | \$E | \$E | \$E | | | TOPSOLO | \$18 | \$18 | \$18 | \$18 | \$18 | \$18 | | | TCPSDOP | \$F | \$F | \$F | \$F | \$F | \$F | | | TCP\$ECHO | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCPSEOL | \$D0A0000 | \$D0A0000 | \$00A0000 | \$D0A0000 | \$D0A0000 | \$D0A0000 | | | TCP\$HCPY | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$HODH | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TOP\$NLS | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$OFFH | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$PNUL | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TOP\$PRTY | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$REC | \$50 | \$50 | \$50 | \$50 | \$50 | \$50 | | | TCP\$RLN | \$1A | \$1A | \$1A | \$1A | \$1A | \$1A | | | TOP\$RSZ | \$18 | \$18 | \$18 | \$18 | \$18 | \$18 | | | TCP\$RTD | \$088A0 | <b>\$066</b> A0 | \$DBBA0 | <b>\$088</b> A0 | \$08BA0 | \$088A0<br>\$006000 | | | TOP\$RTV | \$D0E0000 | \$DDE0000 | \$00E0000 | \$DDE0000 | \$00E0000 | \$DDE0000 | | | TCP\$STPB | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$TAHD | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TOPSTFUL | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | | TCP\$TRC | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$TTP | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$USEP | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$WTO | \$088A0 | \$088A0 | \$08BA0 | \$08BA0 | \$DBBA0 | \$DBBA0 | | | TCP\$XCTL | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TCP\$XOF | \$13 | \$13 | \$13 | \$13 | \$13 | \$13 | | | TCP\$XON | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | TERHORV | - | - | - | - | - | \$8300 | | | TERHLIB | \$15000 | \$45000 | \$15400 | \$6400 | <b>\$</b> 5200 | \$6500 | | | TERMOONT | \$2 | \$2 | \$2 | \$2 | \$2 | \$2 | | | TIMER | \$FE0000 | \$FE8010 | \$F81001 | \$F20001 | \$F20001 | \$F1A081 | | | TIMINTV | \$A | \$A | \$A | \$A | \$A | \$10 | | | TIMSLIC | \$2 | \$2 | \$2 | \$2 | \$2 | \$2 | | | TOTOSK | \$6 | <b>\$</b> D | \$5 | \$A | \$A | \$2 | | | TOTTER! | \$2 | \$3 | \$2 | \$3 | <b>\$</b> 3 | \$3 | | | TRACE | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | | Parameter | VME101 | VME110 | VHE115 | VHE120 | VHE122 | VMES10 | |-----------|------------|------------|------------|-----------|------------|------------| | TROFLAG | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | TWO | 2 | 2 | 2 | 2 | 2 | 2 | | UOR | \$1 | \$1 | \$1 | \$1 | \$1 | \$1 | | UST | \$2 | \$2 | \$2 | \$2 | \$2 | \$2 | | WHERLOAD | \$0 | \$0 | \$0 | \$0 | \$0 | \$0 | | WORKLS | SYSASML.LS | SYSASML.LS | SYSASML.LS | SysashlLs | Sysasml.ls | SYSASML.LS | | ZERO | 0 | 0 | 0 | 0 | 0 | 0 | THIS PAGE INTENTIONALLY LEFT BLANK. #### APPENDIX B #### MEDIA AND DISK CONTROLLER ATTRIBUTE TABLES #### **B.1** MEDIA ATTRIBUTE TABLE The following table lists the media files (.SI) from User 9998 (null catalog), the media related attributes values, and a cross reference displaying which media files can be used with the currently supported disk controllers. | | _ | 1 | ī | 1 | T | _ | 1 | Τ. | 1 | T - | τ- | | 1 | | r – | | | | | - | | _ | |---------------------------------------------------------|----------|--------------|-----------|----------|------------|------------------|----------------|-----------|----------|------------|-----------|-------------|---|-------|-------|-------|----------------|----------|------|--------|-------|---| | | | | | | | | | | | | | | | | | | | | | | | | | F8SDSSI<br>floppy 6", IBM<br>sngl dens, sngl sided | Species | 8 | 2 | 12 | 0 | 128 | 0 | 12 | 88 | 0 | 0 | 4 | | • | | • | | | • | • | • | | | F8000SI floppy 8", IBM dbl dens, dbl sided | SOZO | 88 | 2 | 11 | 0 | 256 | 0 | 11 | 88 | 0 | 0 | 4 | | • | | • | | | • | • | • | | | FXLRK25<br>fixed LARK 25mb | 20000 | 2 | 2 | 624 | 0 | 256 | 2 | 624 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | RMLRK25<br>renovable LMRK 25mb | Second | 2 | 2 | 624 | 0 | 952 | 0 | 624 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | FXLRIKOB<br>Fixed LARK Beb | COUR | 2 | 2 | 206 | 0 | 256 | 2 | 206 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | RMLRIKOB<br>renovable LANK Brib | \$000 | 2 | 2 | 206 | 0 | 256 | 0 | 206 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | FXCHD80<br>fixed CHD 80% | \$2001 | প্র | S | 823 | 2 | 256 | 16 | 823 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | FXCHD16<br>fixed CHD 16Hb | Store | 3 | 1 | 823 | 0 | 256 | 16 | 823 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | RENCHID16<br>removable CHD 16mb | Stoort | 2 | 1 | 823 | 0 | 256 | 0 | 823 | 0 | 0 | 0 | 0 | | | | | | • | • | | | | | F5DDOSI<br>floopy 5-1/4", IBM<br>dbl dens, dbl sided | \$00\$ | 16 | 7 | 90 | 0 | 256 | 0 | 88 | \$ | 0 | 0 | 0 | | • | • | | | | • | • | • | | | FBSDSSH<br>flogov 8", Hotorola<br>sngl dens, sngl sided | \$0200 | 83 | 2 | 77. | 0 | 128 | 0 | $\pi$ | 38 | 0 | 0 | 4 | | • | | | • | • | • | • | | | | FESDOSH floopy 6", Hotorola sngl dens, dbl sided | *OZO\$ | 92 | 2 | 11 | 0 | 128 | 0 | $\pi$ | 88 | 0 | 0 | \$ | | • | | | • | • | • | • | | | | H5WIN40<br>Win 5-1/4", 40Mb | \$0010 | æ | 9 | 830 | 0 | 256 | 0 | 830 | 400 | 0 | 0 | 8 | | • | • | | | | | | • | | | <b>H5VIN15</b><br>Win 5-1/4", 15mb | 01.00\$ | æ | 9 | 306 | 0 | 256 | 0 | 306 | 153 | 0 | 0 | 307 | | • | • | | , | | | • | • | | | H5UIN12<br>Win 5-1/4", 12mb | \$0010 | 32 | 4 | 360 | 0 | 256 | 0 | 360 | 128 | 0 | 0 | 98 | | | | | | | | • | | | | H5WIN10<br>Hin 5-1/4", 10mb | 0100\$ | æ | 4 | 900 | 0 | 256 | 0 | 306 | 153 | 0 | 0 | 307 | | • | • | | | | | • | • | | | HSWINOS<br>Win 5-1/4", SNb | 0100\$ | Œ | 2 | 38 | 0 | 952 | 0 | 306 | 153 | 0 | 0 | 307 | | • | • | | | | | • | • | | | HOWIN10<br>Nún 6°, 10mb | \$100 | 83 | 4 | 922 | 0 | 927 | 0 | ঠ্ | 23 | 0 | 0 | 237 | | • | | • | | | | • | • | | | ATTRIBUTE<br>TABLE | ATT_WORD | SECT PER TRK | NLM HEADS | CM. DISK | SPIRAL OFF | BYTES_PER_SECTOR | START HEAD NUM | CML_DRIVE | PRE CONP | SECT DRIVE | STEP PATE | R_W_PRECORP | | RWIN1 | SASIS | SASIB | WEO Floppy IPC | VHZ1 LDC | VHZZ | VHE315 | WE320 | | ### **B.2** DISK CONTROLLER ATTRIBUTE TABLE The Disk Controller Attribute Table is a cross reference displaying the controller related attributes for the currently supported disk controllers. | DISK<br>CONTROLLER<br>ATTRIBUTE<br>TABLE | RWIN1 | SASI5 | SASI8 | VM20 floppy IPC | VM21 ucc | VM22 | VME315 | VME320 | | |------------------------------------------|--------------|-------|-------|-----------------|----------|------|--------|--------|--| | CHAN_ID | WIND | SAS5 | SAS8 | CFD1 | CUD1 | VH22 | M315 | M320 | | | ATT_MASK herd disk | 0410 | 0015 | 0210 | N/A | 03FF | 0490 | 0110 | 0210 | | | ATT_MASK floppy disk | 001F | 0015 | 0215 | 03FF | 03FF | 025F | 021F | 0215 | | | PAR_MASK | 1 <b>AF3</b> | 02F3 | 02F3 | FFF3 | FFF3 | 5FF3 | D8F3 | 53F3 | | | INTERLEAVE hard disk | 1 | 4 | 4 | n/a | 0 | 1 | 5 | 11 | | | INTERLEAVE floppy disk | 1 | 8 | 13 | 1 | 1 | 1 | 1 | 1 | | | ECC_LEN | 0 | 0 | 0 | 0 | 0 | 0 | 11 | 0 | | | | | | | | | | | | | THIS PAGE INTENTIONALLY LEFT BLANK. #### APPENDIX C ### MODULE BASE ADDRESSES AND OFFSETS The following defines the VERSAdos Base Addresses and Board Offsets for a variety of Motorola components. # **Base Addresses** | System | IPL. SY | I/O Channel | SID Address | STARTRHS | CRASHSAY | SYSPAR | |----------|---------|-------------------|------------------|---------------|---------------|---------------| | EXORMACS | \$0 | N/A | \$FF0000 | \$C00 | \$400 | \$900 | | VHQ1 | N/A | N/A | \$FF0000 | <b>\$</b> F00 | \$800 | \$C00 | | VH02 | \$10000 | \$F80000 | \$FF0000 | <b>\$</b> F00 | \$800 | \$C00 | | VHQ3 | \$10000 | \$FA0000 | \$FF0000 | \$1200 | \$800 | <b>\$</b> F00 | | VMO4 | \$10000 | N/A | \$FFFF0000 | \$2700 | \$2000 | \$2400 | | VME101 | \$10000 | \$FFE000 | \$FF0000 | \$10100 | \$800 | \$C00 | | VHE110 | \$40000 | \$FE6000 | \$FF0000 | \$40100 | \$800 | \$C00 | | VHE115 | \$10000 | \$FFE000 (VHE316) | \$FF0000 | \$10100 | <b>\$800</b> | \$000 | | VHE120 | \$10000 | \$FFE000 (VHE316) | \$FF0000 | \$1100 | <b>\$8</b> 00 | \$000 | | VHE122 | \$10000 | #FE000 (VHE316) | <b>\$</b> FF0000 | \$1100 | <b>\$600</b> | <b>\$</b> 000 | | VHE128 | \$10000 | #FFE000 (VHE316) | <b>\$</b> FF0000 | \$1100 | <b>\$8</b> 00 | \$000 | | VHES10 | \$10000 | \$F1C000 | \$FF0000 | \$1100 | \$A00 | \$E00 | # **Board Offsets** | I/O Channel | | SIO Address | | | |-------------|---------------|--------------|--------|--| | Board | Offset. | <u>Board</u> | Offset | | | VHE400 #1 | \$1CD | VHE050 | \$1000 | | | <b>*</b> 2 | \$1AD | VHE300 #1 | \$400 | | | VIE410 #1 | \$1E1 | #2 | \$440 | | | #2 | <b>\$</b> 121 | VHE315 #1 | \$000 | | | VHE420 #1 | <b>\$0F1</b> | #2 | \$200 | | | #2 | \$0E1 | VHE320 #1 | \$8000 | | | VHE435 #1 | \$3E9 | <b>#2</b> | \$ACOD | | | #2 | \$3A9 | VHE331 #1 | \$3000 | | | VME500 #1 | \$1E03 | <b>#2</b> | \$3100 | | | #2 | \$1003 | #3 | \$3200 | | | VME605 | \$1601 | #4 | \$3300 | | | VHE510 #1 | <b>\$005</b> | <b>#5</b> | \$3400 | | | <b>\$</b> 2 | <b>\$009</b> | #6 | \$3500 | | | VME615 | \$003 | VHE333 #1 | \$3800 | | | VME625 | <b>\$00</b> 1 | #2 | \$3900 | | | RAD | <b>\$</b> E01 | #3 | \$3A00 | | | RIO | <b>\$021</b> | #4 | \$3800 | | | RWIN #1 | \$003 | <b>#</b> 5 | \$3000 | | | <b>\$2</b> | \$0E3 | #6 | \$3000 | | | | | VH30 #1 | \$1000 | | | | | #2 | \$1200 | | | | | #3 | \$1400 | | | | | #4 | \$1600 | | | | | | | | THIS PAGE INTENTIONALLY LEFT BLANK. #### APPENDIX D #### RS-232C INTERFACE SPECIFICATION FOR SERIAL DRIVERS #### D.1 RS-232C INTERFACE SPECIFICATION This appendix provides configuration information for most serial RS-232C devices implemented on various Motorola components. To assist in the hardware configuration of a serial device, this appendix describes the chip signal relationship to the RS-232C connector for both terminal and modem connections. ### D.1.1 SIODRV/MK68564 on the M68KVM04 | ****** | | | | | |--------|----|----------|---|--| | * | to | TERMINAL | * | | | ****** | | | | | | | CHIP<br>SIGNALS DI | J5 on RS-232C<br>STRIBUTION BOARD | USED IN: | |--------|--------------------|-----------------------------------|-----------------| | | CTS | RTS pin 4 | | | PORT 0 | > RTS | CTS pin 5 | DDP_STOP/UNSTOP | | | > DTR | DSR pin 6 | | | | | DCD pin 8 +12V | | | | < DCD | DTR pin 20 | GETSTAT | | | > TxD | RxD pin 3 | | | + | <br> < RxD | TxD pin 2 | | \*\*\*\*\*\*\*\*\*\*\*\*\*\* \* to MODEM \* \*\*\*\*\*\*\*\*\*\*\* | + | | |---------------------------------|--------| | > RTS RTS pin 4 | | | < CTS CTS pin 5 | | | PORT 1<br> MK68564 DSR pin 6 | | | < DCD DCD pin 8 G | ETSTAT | | > DTR DTR pin 20 | | | > TxD TxD pin 2 | | | | | # D.1.2 DARTDRV/SCN2681 on the MVME115M | CHIP<br>SIGNALS | RS-232C<br>CABLE | USED IN: | |------------------------|----------------------------------|-----------------| | > Port A | DSR pin 6 | DDP_STOP/UNSTOP | | > Port B | DSR pin 6 | DDP_STOP/UNSTOP | | < Port B | DTR pin 20 | GETSTAT | | > | RxD pin 3 | | | <br> <<br><del> </del> | TxD pin 2 | | | | SIGNALS> Port A> Port B < Port B | ***** | NOTE: Port A is always "READY" | | CHIP<br>SIGNALS | RS-232C<br>CABLE | USED IN: | |--------------------------|-----------------|------------------|----------| | OP0 | > Port A | DSR pin 6 | | | OP1<br>SCN2681<br>on the | > Port B | DSR pin 6 | | | MVME115M<br>IP2 | < Port B | DTR pin 20 | GETSTAT | | TxD | > | TxD pin 2 | | | RxD | <br> < | RxD pin 3 | | NOTE: Port A is always "READY" # D.1.3 SCCDRV/Z8530 on the MVME117 | | CHIP<br>SIGNALS | FRONT PANEL<br>RS-232C PORT | USED IN: | |------------------|-----------------|-----------------------------|-----------------| | | RxD | TxD pin 2 | | | <br> <br> Z8530 | > TxD | RxD pin 3 | | | on the | < DCD | RTS pin 4 | | | PIVME117 | | CTS pin 5 +12V | | | | > RTS | DSR pin 6 | DDP_STOP/UNSTOP | | | | DCD pin 8 +12V | | | ļ | CTS | DTR pin 20 | GETSTAT | | | | CHIP<br>SIGNA | LS | TRANSI | TION | BOARD | USED IN: | |--|---------|-----------------|-----------------------------------------|--------|------|--------|-----------------| | | <b></b> | +<br> < RxD | | . TxD | pin | 2 | | | | Z8530 | <br> > TxD | | . RxD | pin | 3 | | | | | <br> < DCD | | . RTS | pin | 4 | | | | HAMET11 | <br> <br> | | . CTS | pin | 5 +12V | | | | | <br> > RTS | ••••• | . DSR | pin | 6 | DDP_STOP/UNSTOP | | | | [<br> <br> | • • • • • • • • • • • • • • • • • • • • | . DCD | pin | 8 +12V | | | | | <br> < CTS<br>+ | • • • • • • • • | . DTR | pin | 20 | GETSTAT | | | CHIP<br>SIGNAL | S | TRANSI | TION | BOARD | USED IN: | |---------|----------------|-----------------------------------------|--------|------|---------|----------| | | > TxD | • • • • • • • • • | TxD | pin | 2 | | | • | < RxD | | RxD | pin | 3 | | | | > RTS | | RTS | pin | 4 | | | MVME117 | < CTS | | CTS | pin | 5 | GETSTAT | | | < DCD | • • • • • • • • • • • • • • • • • • • • | DSR | pin | 6 | | | | | | DCD | pin | 8 | | | | _ | • • • • • • • • • | DTR | pin | 20 +12V | | ## D.1.4 MFPRV/MK68901 on the MVME120 to TERMINAL \* \*\*\*\*\*\* CHIP RS-232C CABLE USED IN: SIGNALS RTS PIN 4 MK68901 DSR pin 6 +12V on the MVME120 DCD pin 8 +12V GPIP DTR pin 20 **GETSTAT** bit 6 <--- DTR\* ..... ---> TxD ...... RxD pin 3 | <--- RxD ..... TxD pin 2 MODULE CONTROL DDP\_STOP/UNSTOP ---> CTS\* ..... CTS pin 5 REGISTER on the MVME120 # D.1.5 MPCCDRV/R68560 on the MVME050 | | CHIP<br>SIGNALS | RS-232C<br>CABLE | USED IN: | |-------------------------------------|-----------------|------------------|-----------------| | | DSR | RTS pin 4 | | | Deoleo | > DTR | CTS pin 5 | DDP_STOP/UNSTOP | | R68560<br> on the<br> MVME050<br> | > RTS | DSR pin 6 | DDP_STOP/UNSTOP | | | < DCD 0v | DCD pin 8 +12V | | | | < CTS | | GETSTAT | | | > TxD | RxD pin 3 | | | <br> <br> | <br> < RxD | TxD pin 2 | | \*\*\*\*\*\*\*\*\*\*\*\* \* to MODEM \* \*\*\*\*\*\*\*\*\*\*\* | | CHIP<br>SIGNALS | | | -232C<br>BLE | USED IN: | |------------------|-----------------|-----------------------------------------|-----|--------------|----------| | | > RTS | • • • • • • • • • • | RTS | pin 4 | | | R68560<br>on the | < CTS | • • • • • • • • • • | CTS | pin 5 | GETSTAT | | | < DSR | • • • • • • • • • | DSR | pin 6 | | | MVME050 | < DCD | • • • • • • • • • | DCD | pin 8 | | | | > DTR | • • • • • • • • • • • • • • • • • • • • | DTR | pin 20 | | | | > TxD | • • • • • • • • • • • • • • • • • • • • | TxD | pin 2 | | | ļ<br>+ | RxD | • • • • • • • • • | RxD | pin 3 | | ## D.1.6 MPSCDRV/NEC7201 on the MVME400 NOTE: For Port 1 to talk to a TERMINAL the board is jumpered as: J14 is open. J15 is shorted. J16 1-3 and 2-4 are shorted (for hardware handshaking). \*\*\*\*\*\* to MODEM \*\*\*\*\*\* | | | CHIP<br>SIGNALS | | | -232C<br>BLE | USED IN: | |--------------------------------------|------------|-----------------|-----------------------------------------|--------|--------------|----------| | | | > RTS | | RTS | pin 4 | | | | NEC7201 | < CTS | • • • • • • • • • • • • • • • • • • • • | CTS | pin 5 | | | | | < DCD | | DCD | pin 8 | | | | PIVILAGO | > DTR | | DTR | pin 20 | | | | | > TxD | | TxD | pin 2 | | | | | RxD | • • • • • • • • • • • • • • • • • • • • | RxD | pin 3 | | | <b>⊤</b> | | τ<br>∔ | | | | | | | | < [DSR] | | DSR | pin 6 | GETSTAT | | M6821 (PIA)<br> on the<br> MVME400 | <br> [RI] | • • • • • • • | RI | pin 22 | | | | т | | T | | | | | Note: For Port 2 to talk to a MODEM the board is jumpered as: J8 is shorted. J9 is open. J7 5-7 and 6-8 are shorted. # D.1.7 MPSCDRV/NEC7201 on the M68KVM02/M68KVM03 | | CHIP<br>SIGNALS | | RS-232C<br>CABLE | | · USED IN: | |-------------------------|-----------------|-----------------------------------------|------------------|--------|-----------------| | | <br> < DCD | • • • • • • • • | RTS | pin 4 | | | <br> <br> NEC7201 | > DTR | | CTS | pin 5 | DDP_STOP/UNSTOP | | on the | !<br> <br> - | | DSR | pin 6 | DDP_STOP/UNSTOP | | M68KVM02/<br> M68KVM03 | <br> > RTS | • • • • • • • • • | DCD | pin 8 | | | | < CTS | • • • • • • • • • • • • • • • • • • • • | DTR | pin 20 | ALWAYS "READY" | | | > TxD | • • • • • • • • • • • • • • • • • • • • | RxD | pin 3 | | | <u> </u> | <br> < RxD | • • • • • • • • • | TxD | pin 2 | | \*\*\*\*\*\*\*\*\*\*\*\*\*\* \* to MODEM \* \*\*\*\*\*\*\*\*\*\*\*\* | | CHIP<br>SIGNALS | | RS-232C<br>CABLE | | USED IN: | |--------------------|-----------------|-----------------------------------------|------------------|--------|----------------| | | +<br> > RTS | • • • • • • • • | RTS | pin 4 | | | <br> <br> NEC7201 | < CTS | • • • • • • • • | CTS | pin 5 | | | on the M68KVM02/ | | | DSR | pin 6 | ALWAYS "READY' | | | < DCD | ••••• | DCD | pin 8 | | | | > DTR | • • • • • • • • • • • • • • • • • • • • | DTR | pin 20 | | | | > TxD | • • • • • • • • • | TxD | pin 2 | | | + | <br> < RxD | • • • • • • • • | RxD | pin 3 | | #### D.1.8 ACIADRV/M6850 on the MVME110-1 #### D.1.9 ACIADRV/M6850 on the EXORmacs ## D.1.10 EPCIDRV/SCN2661 on the MVME101 to MODEM \*\*\*\*\* CHIP RS-232C USED IN: **SIGNALS** CABLE ---> RTS ..... RTS pin 4 <--- CTS -- OV CTS pin 5 SCN2661 **GETSTAT** on the |<--- DSR ..... DSR pin 6 MVME101 <--- DCD -- OV DCD pin 8 DTR pin 20 ---> DTR ---> TxD TxD pin 2 <--- RxD RxD pin 3 ## D.1.11 IPCDRV/SCN2661 on the MCCM (M68KVM30) to TERMINAL \*\*\*\*\*\* CHIP RS-232C USED IN: **SIGNALS** CABLE <--- DSR RTS pin 4 CTS pin 5 ---> DTR SCN2661 DSR pin 6 on the ---> RTS MCCM <--- DCD -- OV DCD pin 8 +12V DTR pin 20 <--- CTS ---> TxD RxDpin 3 <--- RxD TxD pin 2 \*\*\*\*\*\*\*\*\*\*\*\*\* \* to MODEM \* \*\*\*\*\*\*\*\*\*\*\*\* | | CHIP<br>SIGNALS | | | -232C<br>BLE | USED IN: | |------|-----------------|-----------------------------------------|-----|--------------|----------| | | > RTS | | RTS | pin 4 | | | | < CTS | • • • • • • • • • • • • • • • • • • • • | CTS | pin 5 | | | | < DSR | • • • • • • • • • • • • • • • • • • • • | DSR | pin 6 | | | MCCM | < DCD | • • • • • • • • | DCD | pin 8 | | | | > DTR | • • • • • • • • • | DTR | pin 20 | at a | | | > TxD | ••••• | TxD | pin 2 | | | | < RxD | • • • • • • • • • | RxD | pin 3 | | #### D.2 SELECTED RS-232C DEVICES # D.2.1 UDS 212A MODEM | RS-<br>CAB | 232C<br>SLE | FUNCTION: | | |----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------| | > RTS < CTS < DSR < DCD> DTR> TxD < RxD < RxC < TxC < RxC> TxC < RXC> TxC < RXC> TxC < RI < SPEED> EXSPD | pin 4<br>pin 5<br>pin 6<br>pin 8<br>pin 20<br>pin 2<br>pin 3<br>pin 9<br>pin 10<br>pin 15<br>pin 17<br>pin 24<br>pin 22<br>pin 22<br>pin 23 | not used +12V when DTR is active +12V = valid carrier +12V makes DSR active +12V @ 3mA -12V @ 3mA for synchronous operation for synchronous operation for synchronous operation +12V = phone is ringing 1200 baud = +12V +12V = 1200 baud | 212A MODEM | # D.2.2 DATA I/O PROM PROGRAMMER | | S-232C<br>ABLE | CHIP<br>SIGNALS | | | | | | |------|----------------|-----------------|-----------------------------------------|-----|-----|------------------------------------|--------| | < R | TS pin | 4 | • • • • • • • • | RTS | < | "STOP/UNSTOP" | <br> | | > C | TS pin | 5 | • • • • • • • • • • • • • • • • • • • • | CTS | > | | | | > D | CD pin | 8 | • • • • • • • • • • • • • • • • • • • • | DCD | > | DATA I/O<br>model 19 | | | > D: | SR pin | 6 | | | 1 | model 19<br>model 29A<br>model 29B | | | < D | TR pin | 20 | | | | model 230 | | | > R | xD pin | 3 | | RxD | > | ! | | | < T | xD pin | 2 | | TxD | < | | <br> - | | | | | | | . т | | J | # D.2.3 EXORterm 155 TERMINAL | | RS-23<br>CABLE | | | | CHIP<br>IGNALS | | | | |---|----------------|-----|----|-----------------------------------------|----------------|----|----------|--| | < | RTS | pin | 4 | • • • • • • • • | RTS | < | | | | > | CTS | pin | 5 | ••••• | CTS | > | EXORterm | | | > | DSR | pin | 6 | ••••• | [DSR] | ]> | | | | > | DCD | pin | 8 | • • • • • • • • • | DCD | > | | | | < | DTR | pin | 20 | • • • • • • • • | DTR | < | | | | > | RxD | pin | 3 | • • • • • • • • • • • • • • • • • • • • | RxD | > | | | | < | TxD | pin | 2 | • • • • • • • • | TxD | < | | | # D.3 DEFINITION OF RS-232C SIGNALS | RS-232C<br>PIN | SIGNAL<br>NAME | | DESCRIPTION | |----------------|----------------|---------------------|-------------------------------------------------------------------------------------------------------------------------| | 1 | | Not used. | | | 2 | TxD | TRANSMIT DATA | Data to be transmitted is furnished on this line to the modem from the terminal. | | 3 | RxD | RECEIVE DATA | Data on the receive line is presented to the terminal from the modem. | | 4 | RTS | REQUEST TO SEND | RTS is supplied by the terminal to the modem when required to transmit a message. | | 5 | CTS | CLEAR TO SEND | CTS is supplied to the terminal by the modem which indicates that it is permissible to begin transmission of a message. | | 6 | DSR | DATA SET READY | DSR is supplied to the terminal by the modem to indicate that the modem is ready to transmit data. | | 7 | GND | SIGNAL GROUND | | | 8 | DCD | DATA CARRIER DETECT | Sent by the modem to the terminal to indicate that a valid carrier is being received. | | 15 | TxC | TRANSMIT CLOCK | This line clocks output data to the modem from the terminal. | | 17 | RxC | RECEIVE CLOCK | This line clocks input data from a terminal to a modem. | | 20 | DTR | DATA TERMINAL READY | A signal from the terminal to the modem indicating that the terminal is ready to send or receive data. | | 22 | RI | RING INDICATOR | RI is sent by the modem to the terminal. This line indicates to the terminal that an incoming call is present. | | 24 | TxC | TRANSMIT CLOCK | Refer to TxC on pin 15. | #### D.4 SELECTED ROUTINES USED BY SERIAL DRIVERS #### D.4.1 Selecting Device Ready/Unready (Flow Control) There are two methods of flow control. First, the default method used in VERSAdos between a computer and a terminal in close proximity is to change the level of a hardware output line. The port must be set with the "USE XOFF/ON" attribute off to allow hardware handshaking. The second method of flow control is XON/XOFF. The industry standard is to use DC1 and DC3 for XON and XOFF, respectively (DC1 = \$11 and DC3 = \$13). The default values for VERSAdos are any character and DC3. This method of flow control requires no adjustments of hardware output lines and is the method used with modems. The port must be set with the "USE XOFF/ON" attribute ON to allow this method of flow control. - D.4.1.1 <u>DDP-Unstop</u> (<u>Device-Dependent Unstop</u>). This routine will assert the appropriate line(s) to allow the external device to continue transmitting. This routine is called when the type-ahead buffer has been emptied enough to allow more characters to be received. - **D.4.1.2** <u>DDP-Stop</u> (<u>Device-Dependent Stop</u>). This routine will negate the appropriate line(s) to stop the external device from transmitting. This routine is called when the type-ahead buffer is full so that no more characters are received. #### D.4.2 Detecting Device Ready/Unready (GETSTAT) The GETSTAT routine is called to check the status of the external device. The proper signal for each driver is read and the result is returned. #### D.5 CONFIGURATION EXAMPLES #### D.5.1 M68KVM04 PORT 1 and an EXORterm 155 Terminal Port 1 on the M68KVM04 was designed to be interfaced with Data Communication Equipment (DCE) such as modems. It can be used with terminals, as in the following example. | + | <b></b> | + | | | Adapter cable | <b></b> - | + | | |-----------------------|---------|------------------|-----|----|-----------------------------------------|-----------|------|----------| | MCOKAMO4 | TxD | <br> <b>-</b> > | pin | 2 | | pin 2 < | TxD | EXORterm | | M68KVM04<br> MK68564 | RxD | <br> < | pin | 3 | • | pin 3> | RxD | | | Port 1 | RTS | > | pin | 4 | • • • • • • • • • • • • • • • • • • • • | pin 4 < | RTS | | | | CTS | <b> </b> < | pin | 5 | • • • • • • • • • • • • • • • • • • • • | pin 5> | CTS | | | | | <br> | pin | 6 | | pin 6> | [DSR | ] | | | DCD | <br> < | pin | 8 | | pin 8> | DCD | | | | DTR | > | pin | 20 | • | pin 20 < | DTR | | | | GND | <b> </b> < | pin | 7 | • • • • • • • • • • • • • • • • • • • • | pin 7> | GND | | | <br>+ | <b></b> | !<br>+ | | | | - | <br> | + | ### D.5.2 MVME115M Combined with an MVME400 To connect the MVME115M to an MVME400 for an application such as UPLOADS, use the configuration: | + | + | | | | Adap | ter o | cable | | <b>+</b> | | <br>! | |------------------|------------------|---|-----|----|---------|---------|-----------|-----|----------|------|---------------------| | | RxD | < | pin | 2 | • • • • | | | pin | 2> | RxD | NEC7201 | | SCN2681 on the T | TxD | > | pin | 3 | | • | | pin | 3 < | TxD | on the <br>MVME400 | | | OP1 | > | pin | 6 | | | <br>I | pin | 4> | DCD | Port 1 | | Port B | | | | | | | <br> <br> | pin | 5 < | DTR | roit 1 | | ļ I | IP2 | < | pin | 20 | | | <br> | pin | 6 < | DTR | į | | | ļ | | | | | | <br> | pin | 8 < | RTS | | | | | | | | | • • • • | | pin | 20> | CTS, | [DSR] | | 6 | GND | < | pin | 7 | | | | pin | 7> | GND | ! | | + | <br><del>+</del> | | | | | | | | <br> | | ا<br>+ | J121 3-4 J152 1-2, 3-4 as a TERMINAL: The MVME115M is jumpered J128 1-3 The MVME400 is jumpered as a TERMINAL: J14 - all open J15 - all shorted J16 - 1-3, 2-4 # D.5.3 MVME115M and a UDS 212A MODEM To connect the MVME115M to a MODEM, such as a UDS 212A, use the configuration: | + | | <del> </del><br> - | | Ac | dapte | er cable | | , <del>1</del> | | + | |---------|-----|--------------------|-----|----|---------|----------|-----|----------------|-----|----------| | SCN2681 | RxD | <br> < | pin | 2 | • • • • | | pin | 2> | TxD | UDS 212A | | on the | TxD | <br> > | pin | 3 | • • • • | • | pin | 3 < | RxD | MODEM | | | 0P1 | <br> > | pin | 6 | | | pin | 5 < | CTS | | | Port B | | <br> | | | | | pin | 6 < | DSR | - | | | IP2 | < | pin | 20 | | | pin | 8 < | DCD | - | | | | | | | | <br> | pin | 20> | DTR | | | | GND | <br> < | pin | 7 | • • • • | | pin | 7> | GND | | | + | | <br><del> </del> | | | | | | | | + | The MVME115M is jumpered as a TERMINAL: J121 3-4 J152 1-2, 3-4 J128 1-3 # D.5.4 MVME115M and a Data I/O PROM Programmer To connect the MVME115M to a PROM programmer, such as the DATA I/O model 29B, use the configuration: | + | | + | | A | dapter cable | | 4 | <b></b> | | |---------------|-----|------------------|-----|----|-----------------------------------------|-------|------|---------|-----------------------| | <br> SCN2681 | RxD | <br> | pin | 2 | | pin 2 | < | TxD | DATA I/O | | on the | TxD | > | pin | 3 | | pin 3 | > | RxD | DATA I/O<br>model 29B | | Port B | 0P1 | <br> > | pin | 6 | | pin 5 | > | CTS | | | POPL B | | <br> <br> | | | | pin 8 | > | DCD | | | | IP2 | <br> < | pin | 20 | • • • • • • • • • • • • • | pin 4 | < | RTS | | | | | <br> <br> | | | | pin 6 | | | | | | | | | | | pin 2 | 0 | | | | | GND | <br> < | pin | 7 | • • • • • • • • • • • • • • • • • • • • | pin 7 | > | GND | | | + | | <br><del> </del> | | | | | <br> | | | The MVME115M is jumpered as a TERMINAL: J121 3-4 J152 1-2, 3-4 J128 1-3 #### D.6 MISCELLANEOUS NOTES A SPACE = +3 to +15 volts. A MARK = -3 to -15 volts. A TERMINAL will drive pins 4 and 20 and monitor pins 5, 6 and 8. A MODEM will drive pins 5, 6 and 8 and will monitor pins 4 and 20. THIS PAGE INTENTIONALLY LEFT BLANK. # SUGGESTION/PROBLEM REPORT Motorola welcomes your comments on its products and publications. Please use this form. To: Motorola Inc. Microsystems 2900 S. Diablo Way Tempe, Arizona 85282 Attention: Publications Manager Maildrop DW164 | Product: | Manual: | | |--------------|-----------------|--| | COMMENTS: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | Please Print | | | | Name | Title | | | Company | Division | | | Street | Mail Drop Phone | | | City | State Zip | | For Additional Motorola Publications Literature Distribution Center 616 West 24th Street Tempe, AZ 85282 (602) 994-6561 Four Phase/Motorola Customer Support, Tempe Operations (800) 528-1908 (602) 438-3100 **MOTOROLA** Semiconductor Products Inc. P.O. BOX 20912 • PHOENIX, ARIZONA 85036 • A SUBSIDIARY OF MOTOROLA INC.