# APPENDIX A. (Continued) P2 CONNECTOR PIN ASSIGNMENT OF OPTIONAL BUS SIGNALS | | (CO | MPONENT SIDE) | | (0 | CIRCUIT SIDE) | |----------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | PIN | MNEMONIC | DESCRIPTION | PIN | MNEMONIC | DESCRIPTION | | 1<br>3<br>5<br>7<br>9<br>11<br>13 | GND<br>5 VB<br>-5 VB<br>12 VB<br>PFSR/ | Signal GND<br>+5V Battery<br>Reserved<br>-5V Battery<br>Reserved<br>+12V Battery<br>Power Fail Sense Reset | 2<br>4<br>6<br>8<br>10<br>12 | GND<br>5 VB<br>VCCPP<br>-5 VB<br>Reserved<br>12 VB<br>Reserved | Signal GND<br>+5V Battery<br>+5V Pulsed Power<br>-5V Battery<br>+12V Battery | | 15<br>17<br>19<br>21<br>23<br>25<br>27<br>29<br>31<br>33<br>35<br>37 | -12 VB<br>PFSN/<br>PFIN/<br>GND<br>+15V<br>-15V<br>PAR1/<br>PAR2/ | -12V Battery<br>Power Fail Sense<br>Power Fail Interrupt<br>Signal GND<br>+15V<br>-15V<br>Parity 1<br>Parity 2 | 16<br>18<br>20<br>22<br>24<br>26<br>28<br>30<br>32<br>34<br>36<br>38 | -12 VB ACLO MPRO/ GND +15V -15V -15V ALT WAIT/ ALE Reserved AUX RESET/ | -12V Battery AC Low Memory Protect Signal GND +15V -15V Bus Master HALT Bus Master WAIT STATE Bus Master ALE | | 39<br>40<br>43<br>45<br>47<br>49<br>51<br>53<br>55<br>57 | Reserved | | 40<br>42<br>44<br>46<br>48<br>50<br>52<br>54<br>56<br>58<br>60 | Reserved | Reset switch | ### Notes: - 1. PFIN, on slave modules, if possible, should have the option of connecting to INT0/ on P1. 2. All undefined pins are reserved for future use. All Mnemonics © Intel Corporation 1978 APPENDIX B BUS TIMING SPECIFICATIONS SUMMARY | Parameter | Description | Minimum | Maximum | Units | |--------------------|---------------------------------------------------------------------------------------------------------------|--------------------------|-----------------------------|-------| | tBCY | Bus Clock Period | 100 | D.C. | ns | | tBW tBW | Bus Clock Width | 0.35 t <sub>BCY</sub> | 0.65 t <sub>BCY</sub> | | | <sup>t</sup> SKEW | BCLK/skew | | 3 | ns | | tPD . | Standard Bus<br>Propagation Delay | | 3 | | | <sup>t</sup> AS | Address Set-Up Time<br>(at Slave Board) | 50 | | ns | | tps | Write Data Set ·<br>Up Time | 50 | | ns | | <sup>t</sup> AH | Address Hold Time | 50 | | ns | | tDHW | Write Data Hold Time | 50 | | ns | | <sup>t</sup> DXL | Read Data Set<br>Up Time To XACK | 0 | | ns | | <sup>t</sup> DHR | Read Data Hold Time | 0 | 65 | ns | | <sup>†</sup> XAH | Acknowledge Hold<br>Time | 0 | 65 | ns | | <sup>t</sup> XACK | Acknowledge Time | 0 | tтоит | ns | | <sup>t</sup> CMD | Command Pulse<br>Width | 100 | <sup>t</sup> TOUT | ns | | t <sub>ID</sub> | Inhibit Delay | 0 | 100<br>(Recommend < 100 ns) | ns | | <sup>t</sup> XACKA | Acknowledge Time of<br>of an Inhibited Slave | t <sub>IAD</sub> + 50 ns | <sup>t</sup> TOUT | | | <sup>†</sup> XACKB | Acknowledge Time of<br>an Inhibiting Slave | 1.5 | <sup>t</sup> TOUT | μs | | <sup>†</sup> IAD | Acknowledge Disable from Inhibit (An internal parameter on an inhibited slave; used to determine tXACKA Min.) | 0 | 100<br>(arbitrary) | ns | | <sup>†</sup> AIZ | Address to Inhibits<br>High delay | | 100 | ns | | tINTA | INTA/ Width | 250 | | ns | | <sup>t</sup> CSEP | Command Separation | 100 | | ns | # APPENDIX B (Continued) BUS TIMING SPECIFICATIONS SUMMARY | Parameter | Description | Minimum | Maximum | Units | |--------------------|-----------------------------------------------------------------------|-----------|------------------------------------------|-------| | <sup>†</sup> BREQL | ∔BCLK/ to BREQ/<br>Low Delay | 0 | 35 | ns | | <sup>†</sup> BREQH | ∔BCLK / to BREQ /<br>High Delay | 0 | 35 | ns | | †BPRNS | BPRN / to ↓BCLK /<br>Setup Time | 22 | | ns | | <sup>t</sup> BUSY | BUSY/ delay<br>from ∔BCLK/ | 0 | 70 | ns | | <sup>t</sup> BUSYS | BUSY/ to \BCLK/<br>Setup Time | 25 | | ns | | <sup>t</sup> BPRO | #BCLK/ to BPRO/<br>(CLK to Priority Out) | 0 | 40 | ns | | <sup>†</sup> BPRNO | BPRN / to BPRO /<br>(Priority In to Out) | 0 | 30 | ns | | <sup>t</sup> CBRO | ↓BCLK/ to CBRQ/<br>(CLKto Common<br>Bus Request) | 0 | 60 | ns | | <sup>†</sup> CBRQS | CBRQ/ to ↓BCLK/<br>Setup Time | 35 | | ns | | tCPM | Central Priority<br>Module Resolution<br>Delay (Parallel<br>Priority) | 0 | ¹BCY-¹BREQ<br>-2tpD<br>-¹BPRNS<br>-¹SKEW | | | tCCY | C-clock Period | 100 | 110 | ns | | tcw | C-clock Width | 0.35 tCCY | 0.65 t <sub>CCY</sub> | ns | | †INIT | INIT/Width | 5 | | ms | | INITS | INIT/ to MPRO/<br>Setup Time | 100 | | ns | | tPBD | Power Backup<br>Logic Delay | 0 | 200 | ns | | tPFINW | PFIN/ Width | 2.5 | | ms | | <sup>t</sup> MPRO | MPRO/ Delay | 2.0 | 2.5 | ms | | <sup>t</sup> ACLOW | ACLO/ Width | 3.0 | | ms | | tpfsrw | PFSR/ Width | 100 | 1 | ns | | tTOUT | Timeout Delay | 5 | ∞ | ms | | †DCH | D.C. Power Supply<br>Hold from ALCO/ | 3.0 | | ms | | tDCS | D.C. Power Supply<br>Setup to ACLO/ | 5 | | ms | APPENDIX C BUS DRIVERS, RECEIVERS, AND TERMINATIONS | Driver 1,3 | | | | | Receiver 2,3 | | | | Termination | | | | | |---------------------------|-------------------------------------------------------------------------------|------|--------------------------|---------------------------|-------------------------------------|-------------------------------------------------------------------|--------------------------|--------------------------|-------------------------------------|--------------------------------------------|------------------|------------|--------| | Bus Signals | Location | Туре | IOL<br>Min <sub>ma</sub> | IOH<br>Min <sub>µ</sub> a | C <sub>O</sub><br>Max <sub>p1</sub> | Location | liL<br>Max <sub>ma</sub> | IIH<br>Max <sub>µa</sub> | C <sub>I</sub><br>Max <sub>pf</sub> | Location | Туре | R | Units | | DAT0/→DATF/<br>(16 lines) | Masters<br>and Slaves | TRI | 16 | -2000 | 300 | Masters<br>and Slaves | -0.8 | 125 | 18 | 1 place | Pullup | 2.2 | KΩ | | ADR0/-ADRB/, | Masters | TRI | 16 | -2000 | 300 | Slaves | -0.8 | 125 | 18 | 1 place | Pullup | 2.2 | KΩ | | BHEN/<br>(21 lines) | | | | | | | | | | | | | | | MRDC/,MWTC/ | Masters | TRI | 32 | -2000 | 300 | Slaves<br>(Memory;<br>memory-<br>mapped I/O) | -2 | 125 | 18 | 1 place | Pullup | 1 | KΩ | | IORC/,IOWC/ | Masters | TRI | 32 | -2000 | 300 | Slaves<br>(I/O) | -2 | 125 | 18 | 1 place | Pullup | 1 | KΩ | | XACK/ | Slaves | TRI | 32 | -2000 | 300 | Masters | -2 | 125 | 18 | 1 place | Pullup | 510 | Ω | | INH1/,INH2/ | Inhibiting<br>Slaves | ос | 16 | - | 300 | Inhibited<br>Slaves<br>(RAM, PROM,<br>ROM, Memory-<br>Mapped I/O) | -2 | 50 | 18 | 1 place | Pullup | 1 | KΩ | | BCLK/ | 1 place<br>(Master us) | TTL | 48 | -3000 | 300 | Master | -2 | 125 | 18 | Mother-<br>board | To +5V<br>To GND | 220<br>330 | Ω<br>Ω | | BREQ/ | Each<br>Master | TTL | 5 | -400 | 60 | Central<br>Priority<br>Module | 2 | 50 | 18 | Central<br>Priority<br>Module<br>(not req) | Pullup | 1 | KΩ | | BPRO/ | Each<br>Master | TTL | 5 | -400 | 60 | Next Master<br>in Serial<br>Priority<br>Chain at<br>its BPRN/ | -1.6 | 50 | 18 | (not req) | | | | | BPRN/ | Parallel:<br>Central<br>Priority<br>Module<br>Serial:Prev<br>Masters<br>BPRO/ | TTL | 5 | -400 | 300 | Master | -2 | 50 | | (not req) | | | | | BUSY/, CBRQ | All Masters | O.C. | 32 | _ | 300 | All Masters | -2 | 50 | 18 | 1 place | Pullup | 1 | KΩ | | INIT/ | Master | O.C. | 32 | _ | 300 | All | -2 | 50 | 18 | 1 place | Puliup | 2.2 | KΩ | | CCLK/ | 1 place | TTL | 48 | -3000 | 300 | Any | -2 | 125 | 18 | Mother-<br>board | To +5V<br>To GND | 220<br>330 | | | INTA/ | Masters | TRI | 32 | -2000 | 300 | Slaves<br>(Interrupting<br>I/O) | -2 | 125 | 18 | 1 place | Pullup | 1 | KΩ | | INT0/→INT7/<br>(8 lines) | Slaves | o.c. | 16 | - | 300 | Masters | -1.6 | 40 | 18 | 1 place | Pullup | 1 | KΩ | | PFSR/ | User's Fron<br>Panel? | TTL | 16 | -400 | 300 | Slaves,<br>Masters | -1.6 | 40 | 18 | 1 place | Pullup | 1 | KΩ | | PFSN/ | Power Back<br>Up Unit | TTL | 16 | -400 | 300 | Masters | -1.6 | 40 | 16 | 1 place | Pullup | 1 | KΩ | | ACLO | Power<br>Supply | O.C. | 16 | -400 | 300 | Slaves,<br>Masters | -1.6 | 40 | 18 | 1 place | Pullup | 1 | KΩ | | PFIN/ | Power Back-<br>Up Unit | o.c. | 16 | -400 | 300 | Masters | -1.6 | 40 | 18 | 1 place | Pullup | 1 | ΚΩ | | MPRO/ | Power Back-<br>Up Unit | TTL | 16 | -400 | 300 | Slaves<br>Masters | -1.6 | 40 | 18 | 1 place | Pullup | 1 | ΚΩ | ## **APPENDIX C (Continued) BUS DRIVERS, RECEIVERS, AND TERMINATIONS** | Driver 1,3 | | | | | Receiver 2,3 | | | Termination | | | | | | |-------------|---------------------------|------------------|--------------------------|--------------------------|-------------------------------------|----------|--------------------------|---------------------------|-------------------------------------|----------|------|---|-------| | Bus Signals | Location | Туре | IOL<br>Min <sub>ma</sub> | IOH<br>Min <sub>µa</sub> | C <sub>O</sub><br>Max <sub>pf</sub> | Location | liL<br>Max <sub>ma</sub> | IIH<br>Max <sub>µ</sub> a | C <sub>I</sub><br>Max <sub>pf</sub> | Location | Туре | R | Units | | Aux Reset/ | User's<br>Front<br>Panel? | Switch<br>to GND | _ | _ | _ | Masters | -2 | 50 | 18 | None | | | | ### Notes: 1. Driver Requirements 1<sub>OH</sub> = High Output Current Drive IOL = Low Output Current Drive CO = Capacitance Drive Capability TRI = 3-State Drive O.C. = Open Collector Driver TTL = Totem-pole Driver 2. Receiver Requirements I<sub>IH</sub> = High Input Current Load I<sub>IL</sub> = Low Input Current Load Ci = Capacitive Load 3. TTL low state must be ≥ -0.5v but ≤ 0.8v at the receivers TTL high state must be ≥ 2.0v but ≤ 5.5v at the receivers 4. For the iSBC 80/10 and the iSBC 80/10A use only a 1K pull-up resistor to +5v for BCLK/ and CCLK/ termination. # APPENDIX D BUS POWER SPECIFICATIONS | | | Standa | rd (P1) | | Optional (P2) | | | | | | | |--------------------------------------------|---------------------------------------|--------------------------------------|----------|----------------|----------------|--------------------------|------------------|----------------|----------------|----------|--| | | | | | | Analog | Power Battery Power Back | | | | р | | | | Ground | + 5 | + 12 | - 12 | + 15 | 15 | +5 | + 12 | - 12 | - 5 | | | Mnemonic | GND | + 5V | + 12V | - 12V | + 15V | – 15V | + 5B | + 12B | – 12B | – 5B | | | Bus Pins | P1 + 1,2,<br>11,12,<br>75,76<br>85,86 | P1 + 3,4,<br>5,6,81,<br>82,83,<br>84 | P1 + 7,8 | P1 + 79,<br>80 | P2 + 23,<br>24 | P2 + 25,<br>26 | P2 + 3,4,<br>5,6 | P2 + 11,<br>12 | P2 + 15,<br>16 | P2 – 7,8 | | | Nominal Output | Ref. | + 5.0V | + 12.0V | - 12.0V | + 15.0V | - 15.0V | + 5.0V | + 12.0V | - 12.0V | - 5.0V | | | Tolerance from Nominal <sup>1</sup> | Ref. | ± 5% | ± 5% | ±5% | ± 3% | ± 3% | ±5% | ± 5% | ± 5% | ±5% | | | Ripple<br>(Pk-Pk)² | Ref. | 50 mV | 50 mV | 50 mV | 10 mV | 10 mV | 50 mV | 50 mV | 50 mV | 50 mV | | | Transient<br>Response<br>Time <sup>3</sup> | | 500 μs | 500μs | 500 μs | 100 μs | 100 μs | 500 μs | 500 μs | 500 μs | 500 μs | | | Transient<br>Deviation <sup>4</sup> | | ± 10% | ± 10% | ± 10% | ± 10% | ± 10% | ± 10% | ± 10% | ± 10% | ± 10% | | ### NOTES: - 1. Tolerance is worst case, including initial voltage setting line and load effects of power source, temperature drift, and any additional steady state influences - 2. As measured over any bandwidth not to exceed 0 to 500 kHz. - 3. As measured from the start of a load change to the time an output recovers within $\pm 0.1\%$ of final voltage. - 4. Measured as the peak deviation from the initial voltage. # APPENDIX E **MECHANICAL SPECIFICATIONS** ### NOTES BOARD THICKNESS: 0.062 MULTIBUS CONNECTOR: 86-PIN, 0.156 SPACING CDC VFB01E43D00A1 VIKING 2VH43/1ANE5 3> AUXILIARY CONNECTOR: 60-PIN, 0.100 SPACING CDC VPB01B30D00A1 TI H311130 AMP PE5-14559 EJECTOR TYPE: SCANBE #S203 - BUS DRIVERS AND RECEIVERS SHOULD BE LOCATED AS CLOSE AS POSSIBLE TO THEIR RESPECTIVE MULTIBUS PIN CONNECTIONS - BOARD SPACING: 0.6 - COMPONENT HEIGHT: 0.4 - CLEARANCE ON CONDUCTOR NEAR EDGES: 0.050 ### APPENDIX F ### APPENDIX G November 1978 # sing the ise vehicle code sing the children code and ©Intel Corporation, 1978 ### I. INTRODUCTION The iSBC 957 Intellec—iSBC 86/12 Interface and Execution Package contains the hardware and software required to interface an iSBC 86/12 Single Board Computer with an Intellec Microcomputer Development System. The iSBC 957 package gives the 8086 user the capability to develop software on an Intellec System and then debug this software on an iSBC 86/12 board using a program download capability and an interactive system monitor. The 8086 user has all the capabilities of the Intellec system at his disposal and has the powerful iSBC 86/12 system monitor commands to use for debugging 8086 programs. The iSBC 86/12 board is an Intel 8086 based processor board which, in addition to the processor, contains 32K bytes of dual port RAM, sockets for up to 16K bytes of ROM/EPROM, a serial I/O port, 24 parallel I/O lines, 2 programmable counters, 9 levels of vectored priority interrupts, and an interface to the MULTIBUS™ system bus. The iSBC 957 package consists of monitor EPROMs for the iSBC 86/12 board, Loader software for the Intellec system, four (4) cable assemblies, assorted line drivers and terminators, and signal adapters. The iSBC 957 package provides the capability of downloading and uploading program and data blocks between an iSBC 86/12 board and an Intellec system. In addition, monitor commands and displays may be input and viewed from the Intellec system console. The iSBC 957 package, when used with the iSBC 86/12 board and an Intellec Microcomputer Development System, provides the user with the capability to edit, compile or assemble, link, locate, download, and interactively debug programs for the 8086 processor. The iSBC 957 package and the iSBC 86/12 board form an excellent "execution vehicle" for users developing software for the 8086 processor regardless of whether the users are 8086 component users or iSBC 86/12 board users. Using the iSBC 957 package 8086 programs may be debugged at the full 5 MHz speed of the processor. The recommended hardware for the execution vehicle is an iSBC 660 system chassis with an 8 card slot backplane and power supply, an iSBC 032 32K byte RAM memory board, the iSBC 957 package, and the iSBC 86/12 board. This application note will describe how the iSBC 957 package may be used to develop and debug 8086 programs. First a description of the iSBC 86/12 board will be presented. Readers familiar with the iSBC 86/12 board may want to skip this section. Next follows a detailed description of the iSBC 957 package and the iSBC 86/12 system monitor commands. A program example of a matrix multiplication routine will then be presented. This example will contain both assembly language and PL/M-86 procedures. The steps required to compile, assemble, link, locate and debug the program code will be explained in detail. A typical debugging session using the iSBC 86/12 system monitor will be presented. # II. THE iSBC™ 86/12 SINGLE BOARD COMPUTER The iSBC 86/12 Single Board Computer, which is a member of Intel's complete line of iSBC 80/86 computer products, is a complete computer system on a single printed-circuit assembly. The iSBC 86/ 12 board includes a 16-bit central processing unit (CPU), 32K bytes of dynamic RAM, a serial communications interface, three programmable parallel I/O ports, programmable timers, priority interrupt control, MULTIBUS control logic, and bus expansion drivers for interface with other MULTIBUScompatible expansion boards. Also included is dual port control logic to allow the iSBC 86/12 board to act as a slave RAM device to other MULTIBUS masters in the system. Provision is made for user installation of up to 16K bytes of read only memory. Figure 1 contains a block diagram of the iSBC 86/12 board and in Appendix A is a simplified logic diagram of the iSBC 86/12 board. ### Central Processing Unit The central processor for the iSBC 86/12 board is Intel's 8086, a powerful 16-bit H-MOS device. The 225 sq. mil chip contains 29,000 transistors and has a clock rate of 5MHz. The architecture includes four (4) 16-bit byte addressable data registers, two (2) 16-bit memory base pointer registers and two (2) 16-bit index registers, all accessed by a total of 24 operand addressing modes for complex data handling and very flexible memory addressing. Instruction Set — The 8086 instruction repertoire includes variable length instruction format (including double operand instructions), 8-bit and 16-bit signed and unsigned arithmetic operators for binary, BCD and unpacked ASCII data, and iterative word and byte string manipulation functions. The instruction set of the 8086 is a functional superset of the 8080A/8085A family and with Figure 1. iSBC™ 86 / 12 Single Board Computer Block Diagram available software tools, programs written for the 8080A/8085A can be easily converted and run on the 8086 processor. **Architectural Features** — A 6-byte instruction queue provides pre-fetching of sequential instructions and can reduce the $1.2\,\mu$ sec minimum instruction cycle to 400 nsec by having the instruction already in the queue. The stack oriented architecture facilitates nested sub-routines and co-routines, reentrant code and powerful interrupt handling. The memory expansion capabilities offer a 1 megabyte addressing range. The dynamic relocation scheme allows ease in segmentation of pure procedure and data for efficient memory utilization. Four segment registers (code, stack, data, extra) contain program loaded offset values which are used to map 16-bit addresses to 20-bit addresses. Each register maps 64K-bytes at a time and activation of a specific register is controlled explicitly by program control and is also selected implicitly by specific functions and instructions. ### **Bus Structure** The iSBC 86/12 board has an internal bus for communicating with on-board memory and I/O options, a system bus (the MULTIBUS) for referencing additional memory and I/O options, and the dual-port bus which allows access to RAM from the on-board CPU and the MULTIBUS System Bus. Local (on-board) accesses do not require MULTIBUS communication, making the system bus available for use by other MULTIBUS masters (i.e. DMA devices and other single board computers transferring to additional system memory). This feature allows true parallel processing in a multiprocessor environment. In addition, the MUL-TIBUS interface can be used for system expansion through the use of other 8- and 16-bit iSBC computers, memory and I/O expansion boards. ### **RAM Capabilities** The iSBC 86/12 board contains 32K-bytes of dynamic read/write memory. Power for the on-board RAM and refresh circuitry may be optionally provided on an auxiliary power bus, and memory protect logic is included for RAM battery backup requirements. The iSBC 86/12 board contains a dual port controller which allows access to the on-board RAM from the iSBC 86/12's CPU and from any other MULTIBUS master via the system bus. The dual port controller allows 8- and 16-bit accesses from the MULTIBUS System Bus and the on-board CPU transfers data to RAM over a 16-bit data path. Priorities have been established such that memory refresh is guaranteed by the onboard refresh logic and that the on-board CPU has priority over MULTIBUS requests for access to RAM. The dual-port controller includes independent addressing logic for RAM access from the on-board CPU and from the MULTIBUS system bus. The on-board CPU will always access RAM starting at location 00000H. Address jumpers allow onboard RAM to be located starting on any 8K-byte boundary within a 1 megabyte address range for accesses from the MULTIBUS system bus. In conjunction with this feature, the iSBC 86/12 board has the ability to protect on-board memory from MULTIBUS access to any contiguous 8K-byte segments. These features allow multi-processor systems to establish local memory for each processor and shared system (MULTIBUS) memory configurations where the total system memory size (including local on-board memory) can exceed 1 megabyte without addressing conflicts. ### **EPROM/ROM Capabilities** Four sockets are provided for up to 16K-bytes of non-volatile read only memory on the iSBC 86/12 board. Configuration jumpers allow read only memory to be installed in 2K, 4K, or 8K increments. On-board ROM is accessed via 16 bit data paths. System memory size is easily expanded by the addition of MULTIBUS compatible memory boards available in the iSBC 80/86 family. ### Parallel I/O Interface The iSBC 86/12 board contains 24 programmable parallel I/O lines implemented using the Intel 8255A Programmable Peripheral Interface. The system software is used to configure the I/O lines in any combination of unidirectional input/output and bidirectional ports. Therefore, the I/O interface may be customized to meet specific peripheral requirements. In order to take full advantage of the large number of possible I/O configurations, sockets are provided for interchangeable I/O line drivers and terminators. Hence, the flexibility of the I/O interface is further enhanced by the capability of selecting the appropriate combination of optional line drivers and terminators to provide the required sink current, polarity, and drive/termination characteristics for each application. The 24 programmable I/O lines and signal ground lines are brought out to a 50-pin edge connector that mates with flat, woven, or round cable. ### Serial I/O A programmable communications interface using the Intel 8251A Universal Synchronous/Asynchronous Receiver/Transmitter (USART) is contained on the iSBC 86/12 board. A software selectable baud rate generator provides the USART with all common communication frequencies. The USART can be programmed by the system software to select the desired asynchronous or synchronous serial data transmission technique (including IBM Bi-Sync). The mode of operation (i.e., synchronous or asynchronous), data format, control character format, parity, and baud rate are all under program control. The 8251A provides full duplex, double buffered transmit and receive capability. Parity, overrun, and framing error detection are all incorporated in the USART. The RS232C compatible interface on each board, in conjunction with the USART, provides a direct interface to RS232C compatible terminals, cassettes, and asynchronous and synchronous modems. The RS232C command lines, serial data lines, and signal ground line are brought out to a 26 pin edge connector that mates with RS232C compatible flat or round cable. The iSBC 530 teletypewriter adapter provides an optically isolated interface for those systems requiring a 20 mA current loop. The iSBC 530 adapter may be used to interface the iSBC 86/12 board to teletypewriters or other 20 mA current loop equipment. ### **Programmable Timers** The iSBC 86/12 board provides three independent, fully programmable 16-bit interval timers/event counters utilizing the Intel 8253 Programmable Interval Timer. Each counter is capable of operating in either BCD or binary modes. Two of these timers/counters are available to the systems designer to generate accurate time intervals under software control. Routing for the outputs and gate/trigger inputs of two of these counters is jumper selectable. The outputs may be independently routed to the 8259A Programmable Interrupt Controller and to the I/O line drivers associated with the 8255A Programmable Peripheral Interface, or may be routed as inputs to the 8255A chip. The gate/trigger inputs may be routed to 1/O terminators associated with the 8255A or as output connections from the 8255A. The third interval timer in the 8253 provides the programmable baud rate generator for the iSBC 86/12 RS232C USART serial port. In utilizing the iSBC 86/12, the systems designer simply configures, via software, each timer independently to meet system requirements. Whenever a given time delay or count is needed, software commands to the programmable timers/event counters select the desired function. The contents of each counter may be read at any time during system operation with simple read operations for event counting applications, and special commands are included so that the contents can be ready "on the fly". ### MULTIBUS™ and Multimaster Capabilities The MULTIBUS system bus features asynchronous data transfers for the accommodation of devices with various transfer rates while maintaining maximum throughput. Twenty address lines and sixteen separate data lines eliminate the need for address/data multiplexing/demultiplexing logic used in other systems, and allow for data transfer rates up to 5 megawords/sec. A failsafe timer is included in the iSBC 86/12 board which can be used to generate an interrupt if an addressed device does not respond within 6 msec. Multimaster Capabilities — The iSBC 86/12 board is a full computer on a single board with resources capable of supporting a great variety of OEM system requirements. For those applications requiring additional processing capacity and the benefits of multiprocessing (i.e., several CPUs and/or controllers logically sharing system tasks through communication over the system bus), the iSBC 86/ 12 board provides full MULTIBUS arbitration control logic. This control logic allows up to three iSBC 86/12 boards or other bus masters, including iSBC 80 family MULTIBUS compatible 8-bit single board computers, to share the system bus in serial (daisy chain) priority fashion, and up to 16 masters to share the MULTIBUS with the addition of an external priority network. The MULTIBUS arbitration logic operates synchronously with a MULTI-BUS clock (provided by the iSBC 86/12 board or optionally provided directly from the MULTIBUS System Bus) while data is transferred via a handshake between the master and slave modules. This allows different speed controllers to share resources on the same bus, and transfers via the bus proceed asynchronously. Thus, transfer speed is dependent on transmitting and receiving devices only. This design prevents slow master modules from being handicapped in their attempts to gain control of the bus, but does not restrict the speed at which faster modules can transfer data via the same bus. The most obvious applications for the master-slave capabilities of the bus are multiprocessor configurations, high speed direct memory access (DMA) operations, and high speed peripheral control, but are by no means limited to these three. ### Interrupt Capability The iSBC 86/12 board provides 9 vectored interrupt levels. The highest level is the NMI (Non-Maskable Interrupt) line which is directly tied to the 8086 CPU. This interrupt cannot be inhibited by software and is typically used for signalling catastrophic events (e.g., power failure). The Intel 8259A Programmable Interrupt Controller (PIC) provides vectoring for the next eight interrupt levels. The PIC accepts interrupt requests from the programmable parallel and serial I/O interfaces, the programmable timers, the system bus, or directly from peripheral equipment. The PIC then determines which of the incoming requests is of the highest priority, determines whether this request is of higher priority than the level currently being serviced, and, if appropriate, issues an interrupt to the CPU. Any combination of interrupt levels may be masked, via software, by storing a single byte in the interrupt mask register of the PIC. The PIC generates a unique memory address for each interrupt level. These addresses contain unique instruction pointers and code segment offset values (for expanded memory operation) for each interrupt level. In systems requiring additional interrupt levels, slave 8259A PIC's may be interfaced via the MULTIBUS system bus, to generate additional vector addresses, yielding a total of 65 unique interrupt levels. **Interrupt Request Generation**—Interrupt requests may originate from 16 sources. Two jumper selectable interrupt requests can be automatically generated by the programmable peripheral interface. Two jumper selectable interrupt requests can be automatically generated by the USART when a character is ready to be transferred to the CPU or a character is ready to be transmitted. A jumper selectable request can also be generated by each of the programmable timers. Eight additional interrupt request lines are available to the user for direct interface to user designated peripheral devices via the system bus, and two interrupt request lines may be jumper routed directly from peripherals via the parallel I/O driver/terminator section. ### **Power-Fail Control** Control logic is also included to accept a power-fail interrupt in conjunction with the AC-low signal from the iSBC 635 Power Supply or equivalent. ### **Expansion Capabilities** Memory and I/O capacity may be expanded and additional functions added using Intel MULTIBUS compatible expansion boards. High speed integer and floating point arithmetic capabilities may be added by using the iSBC 310 high speed mathematics unit. Memory may be expanded to 1 megabyte by adding user specified combinations of RAM boards, EPROM boards, or combination boards. Input/output capacity may be increased by adding digital I/O and analog I/O expansion boards. Mass storage capability may be achieved by adding single or double density diskette controllers. Modular expandable backplanes and cardcages are available to support multiboard systems. ### III. THE iSBC™ 957 PACKAGE The iSBC 957 Intellec-iSBC 86/12 Interface and Execution Package extends the software development capabilities of the Intellec Microcomputer Development systems to the Intel 8086 CPU. Programs for the 8086 may be written in PL/M-86 and/or assembly language and compiled or assembled on the Intellec system. These programs may then be downloaded from an Intellec ISIS-II disk file to the iSBC 86/12 board for execution and debug. The programs will execute at the full 5 MHz clock rate of the 8086 CPU with no speed degradation caused by the iSBC 957 hardware or software. Special communication software allows transparent access to the powerful interactive debug commands in the iSBC 86/12 monitor from the Intellec console terminal. These debug commands include single-step instruction execution, execution with breakpoints, memory and register displays, memory searches, comparison of two memory blocks and several other commands. After a debugging session, the debugged program code may be uploaded from the iSBC 86/12 board to an Intellec ISIS-II disk file. The iSBC 957 Intellec—iSBC 86/12 Interface and Execution Package consists of the following: - a. Four Intel 2716 EPROMs which contain the system monitor program for the iSBC 86/12 board. - b. An ISIS-II diskette containing loader software for execution in the Intellec which provides for communications between the user or an Intellec ISIS-II file and the iSBC 86/12 board. Also included on the diskette are a library of routines for system console I/O. - c. Four cable assemblies used for transmitting commands, code and data between the iSBC 86/12 board and the Intellec system. - d. An iSBC 530 adapter assembly which converts serial communications signals from current loop to RS232C. - e. Line drivers and terminators used for the iSBC 86/12 parallel ports. - f. A small printed circuit board which is plugged into an iSBC 86/12 receiver/terminator socket and is used when program code is downloaded or uploaded using the parallel cable. ### iSBC<sup>™</sup>—Intellec<sup>™</sup> Configurations There are two distinct functional configurations for the iSBC 957 package; one configuration for the Intellec Series II, Models 220 or 230 development systems and another for the Intellec 800 series development systems. ### **Intellec Series II System Configurations** When used with Intellec Series II Model 220 or 230 systems, a set of cables are used to connect the serial I/O port edge connector on the iSBC 86/12 board and the SERIAL 1 output port on the Intellec system. This configuration is shown in Figure 2. How this system functions is explained in the following paragraphs. The SERIAL 1 port on the Intellec Series II Model 220 or 230 system is an RS232 port which is designed for use with a data terminal. This port may be used on the Intellec system for interfacing to RS232 devices such as CRT terminals or printers. The serial ports on the iSBC 86/12 board and the Intellec systems are connected as shown in the Figure 2. The flat ribbon cable connected to the iSBC 86/12 board has an edge connector for connecting to the board on one end and a standard RS232 connector on the other end. The second cable, the RS232 Up/Down Load cable, has an RS232 connector on each end. This cable, however, Figure 2. Intellec™ Series II Model 220, 230—iSBC™ 86 / 12 Configuration is not a standard cable with the RS232 signals bussed between identically numbered pins on each of the connectors. The schematic for the cable is shown in Figure 3. Note that the TXD (transmit data) and the RXD (receive data) and the RTS (ready to send) and the CTS (clear to send) signals have been crossed. This is done because both the Intellec system and the iSBC 86/12 board are configured to act as data sets which are communicating with data terminals. Swapping these signals permits the units to communicate directly with no modifications to the Intellec or iSBC 86/12 systems themselves. Figure 3. Intellec<sup>™</sup>—iSBC<sup>™</sup> 86 / 12 RS232 UP / DOWN LOAD Cable The software in the Intellec system accepts characters output from the iSBC 86/12 board through the Intellec SERIAL 1 port. The software then outputs these characters on the CRT monitor built into the Intellec Series II Model 220 or 230. In a similar fashion, characters input from the Intellec key- board are passed down the serial link to the iSBC 86/12 monitor program. The integrated CRT monitor and keyboard on the Intellec system then becomes the "virtual terminal" of the iSBC 86/12 monitor program. If this were the only function of the iSBC 957 package, there would be no real benefit to the user. However, when the "virtual terminal" capability is combined with the capability to download and upload program code and data files between the Intellec ISIS-II file system and the iSBC 86/12 board, a very powerful software development tool is realized. The software in the Intellec system must examine the commands which are input from the keyboard and in the case of the LOAD and TRANSFER commands (see later sections for details on monitor commands), the software must open and read or write ISIS-II disk files. Transfer rates using Intellec Series II Model 220 or 230 system are 9600 baud when transferring hexadecimal object files to or from a disk file and 600 baud when transferring commands between the iSBC 86/12 board and the CRT monitor and keyboard. With a 9600 baud transfer rate, it is possible to load 64K bytes of memory in about four minutes. ### **Intellec 800 System Configurations** The iSBC 957 package may be used with the Intellec 800 system in four different configurations. These four configurations are determined by two variables. The first variable is whether the iSBC 86/12 board is connected to the Intellec 800 TTY port or to the Intellec 800 CRT port. The second variable is whether or not a parallel cable is used for uploading and downloading hexadecimal object files. Figures 4A and 4B illustrate the four configurations. In Figure 4A, the configuration shows the TTY port of the Intellec 800 system connected to the iSBC 86/12 serial port using two cables and an iSBC 530 teletypewriter adapter. The TTY port of the Intellec 800 system is designed for using a teletypewriter as the Intellec console device. To use this port for communication with the iSBC 86/12 board, the current loop TTY signal must be converted to an RS232 compatible voltage signal. This function is performed by the iSBC 530 adapter. The cable which connects the Intellec 800 system to the iSBC 530 adapter performs a function similar to the RS232 Up/Down Load cable described above. A schematic for this cable and all other components of the iSBC 957 package are included with the delivered product. The transfer rate for both commands and data when the TTY port is connected to the iSBC 86/12 board is 110 baud. This means to download even moderately sized programs would require large amounts of time, several minutes or even hours. However, much faster times may be achieved by using the parallel ports of the iSBC 86/12 board and the Intellec system for downloading program files. This parallel port used on the Intellec 800 system is the output port labeled PROM which is normally used with the Universal Prom Pro- Figure 4A, 4B. Intellec™ 800 — iSBC™ 86 / 12 Configurations grammer. A cable is connected between the Intellec PROM port and the parallel I/O port, J1 of the iSBC 86/12 board. Parallel port B of the iSBC 86/12 board is used for the 8-bit byte transfers from the Intellec system to the iSBC 86/12 board, port A is used for the byte transfers from the iSBC 86/12 board to the Intellec system and port C is used for controlling the byte transfers. A special status adapter piggyback board must be inserted into a receiver/terminator socket of the iSBC 86/12 board. This status adapter circuit is required to provide the necessary handshaking signals from the iSBC 86/12 parallel ports to the Intellec PROM port. The transfer rate achieved when downloading and uploading hexadecimal object files with the parallel cable is approximately 1,000 bytes per second. The time required to load 64K bytes of memory is approximately $2\frac{1}{2}$ minutes. Figure 4B shows a configuration with the Intellec 800 CRT port connected to the serial port of the iSBC 86/12 board. The TTY port of the Intellec 800 system is connected to a teletypewriter or some other current loop device to act as a system console. The optional parallel load cable is also shown. The cables used for this configuration are the same as those used with the Intellec Series II Configurations. Command transfer rates require 110 baud because the TTY port of the Intellec 800 system is used for communicating with the console device. However, hexadecimal object files can be loaded at 9600 baud since this operation uses only the Intellec to iSBC 86/12 RS232 link. It is also possible to download files with the parallel cable, this mode being somewhat faster than the serial download mode (2½ minutes versus four minutes for 64K bytes of memory). Table I contains a summary of the command and memory transfer rates for each of the Intellec-iSBC 86/12 configurations. Comparing the Intellec 800 configurations shown in Table 1 and in Figures 4A and 4B it should be noted: - Using the TTY port (Figure 4A) of the Intellec 800 system for communications with the iSBC 86/12 board (essentially) requires installation of the parallel cable and jumper modifications for downloading and uploading files, and thus, prevents the use of the parallel ports for other I/O functions. - 2. Using the CRT port (Figure 4B) of the Intellec 800 system for communication with the iSBC 86/12 board provides for a fast serial download capability, thus freeing the parallel ports for other uses. However, this configuration requires a teletypewriter or a CRT capable of accepting a current loop input signal as the Intellec system console. Table 1 COMMAND AND MEMORY TRANSFER RATES FOR INTELLEC—ISBC™ 86 / 12 CONFIGURATIONS | | INTELLEC<br>SERIES II 220/230<br>SERIAL PORT<br>TO ISBC 86/12 | INTELLEC 800<br>TTY PORT<br>TO ISBC 96/12 | INTELLEC 800<br>CRT PORT<br>TO ISBC 86 / 12 | |--------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------|---------------------------------------------| | Effective<br>Command Rate | 600 Baud | 110 Baud | 110 Baud* | | Load / Transfer<br>Rate<br>Serial<br>Parallel | 9600 Baud<br>N / A | 110 Baud<br>1K bytes / sec** | 9600 Baud<br>1K bytes/sec** | | Approximate Time<br>to load 64K bytes<br>of memory<br>Serial<br>Parallel | 4 minutes<br>N / A | 5 hours<br>2.5 minutes | 4 minutes<br>2.5 minutes | <sup>\*</sup>The actual baud rate of the Intellec—iSBC 86 / 12 link is 9600 baud, but the effective command rate is determined by the slower Intellec—console serial link. # IV. THE iSBC 957—iSBC 86/12 MONITOR PROGRAM The iSBC 86/12 monitor program is an EPROM resident program which facilitates debugging of user written programs. The monitor program used in the iSBC 86/12 board with the iSBC 957 package is the same monitor program written to interface the iSBC 86/12 directly to an RS232C data terminal. When interfaced directly to a terminal, the iSBC 86/12 board functions in a stand-alone environment communicating directly with the user via the data terminal. A user may use the monitor for entering small programs in hexadecimal format, executing a program, examining registers and memory contents, etc. To use the monitor program with an Intellec system, the proper cables must be installed and the iSBC 957 Loader program must be loaded into Intellec memory and executed. The Loader program is resident on a file named SBC861, and when executed, the Loader outputs a sign-on message. Next, the iSBC 86/12 monitor program must be started and the baud rate of the iSBC 86/12 to Intellec serial communications link must be determined. This is done by pressing the RESET switch on the chassis <sup>\*\*</sup>Transmission rate over the parallel link is determined by the speed of the two processors and is approximately 1K bytes per second. Table 2 MONITOR COMMAND LIST | | MONTON COMMAND LICT | |-------------------------------|----------------------------------------------------------------------------------------------------------------------| | COMMAND | FUNCTION AND SYNTAX | | L Load Hex<br>Object File | Loads hexadecimal object file from Intellec into iSBC 86/12 memory using serial (S) or parallel (P) mode. | | | L(S P), filename>[, bias addr>] <cr></cr> | | T Transfer Hex<br>Object File | Transfers blocks of iSBC 86/12 memory to Intellec as a hex object file using serial (S) or parallel (P) mode. | | | T(X) {S P} , <start addr="">,<end addr="">,<filename><br/>[,<exec addr="">]<cr></cr></exec></filename></end></start> | | E Exit | Exits the loader program and returns to ISIS. | | | E <cr></cr> | | N Single Step | Executes one user program instruction. | | | N( <addr>),((<addr>),(*<cr></cr></addr></addr> | | G Go | Transfers control of the 8086 CPU to the user program with up to 2 optional breakpoints. | | | G[ <start addr="">][,<break 1="" addr=""></break></start> | | | (, <break 2="" addr="">) <cr></cr></break> | | S Substitute<br>Memory | Displays/modifies memory locations in byte or word format. | | | S[W] <addr>,[[new contents],]*<cr></cr></addr> | | X Examine/Modify | Displays/modifies 8086 CPU registers. | | Register | X[ <reg>][(<new contents="">],]*<cr></cr></new></reg> | | D Display Memory | Displays contents of a memory block in byte or word format. | | | D(W) <start addr="">(,<end addr="">)<cr></cr></end></start> | | M Move | Moves contents of a memory block. | | | M <start addr="">,<end addr="">,<destination addr=""><cr></cr></destination></end></start> | | C Compare | Compares two memory blocks. | | | C <start addr="">,<end addr="">,<destination addr=""><cr></cr></destination></end></start> | | F Find | Searches a memory block for a byte or word constant. | | | F(W)< start addr>,< end addr>,< data> < cr> | | H Hex Arithmetic | Performs hexadecimal addition and subtraction. | | | H <data 1="">,<data 2=""><cr></cr></data></data> | | I Port Input | Inputs and displays byte or word data from input port. | | | [W] <port addr="">,[,]*<cr></cr></port> | | O Port Output | Outputs byte or word data to output port. | | | O[W] <port addr="">,<data>[,<data>]*<cr></cr></data></data></port> | | | | Syntax conventions used in the command structure are as follows: (A) indicates that "A" is optional [A]\* indicates one or more optional iterations of "A" <B> indicates that "B" is a variable {A|B} indicates "A" or "B" <cr> indicates a carriage return is entered Numeric arguments can be expressed as a number, the contents of a register, or the sum or difference of numbers and register contents. Thus, addresses and data can be expressed as follows: $\begin{array}{lll} \textit{eddr} ::= & \{ < \exp r > : \} < \exp r \\ & = \exp r ::= & < number > \{ register > \{ expr > \{ + \mid - \} < number > \mid \\ & < \exp r > \{ + \mid - \} < register > \\ & register ::= & AX \mid BX \mid CX \mid DX \mid SP \mid BP \mid SI \mid DI \mid CS \mid DS \mid SS \mid ES \mid P \mid FL \\ & number ::= & c digit > 1 < digit > c digit > c light c$ Numeric fields within arguments are entered as hexadecimal numbers. The valid range of numerical values is from 0000-FFFF. Larger numbers may be entered, but only the last four digits (or two in the case of byte values) are significant. Leading zeros may be omitted. An address argument consists of a segment value and an offset value separated by a colon (:). If a segment value is not specified, the default segment value is the CS register value. containing the iSBC 86/12 board and typing two "U"s on the Intellec console. The ASCII uppercase character U has a binary pattern of alternating ones and zeros, the iSBC 86/12 monitor uses this pattern to determine the baud rate of the serial link. After the baud rate has been determined, the monitor program outputs a sign-on message to the console. An example of loader program execution and monitor program initialization is shown below (user entered characters are underlined). ### :F1:SBC861 ISIS-II iSBC 86/12 LOADER, Vx.x (user resets iSBC 86/12 board and types two "U"s) iSBC 86/12 MONITOR, Vy.y The monitor prompts with a period "." when it is ready for a command. The user can then enter a command file, which consists of a one- or two-character command followed by zero, one, or more arguments. The command may be separated from the first argument by an optional single space; a single comma is required as a delimiter between arguments. The command line is terminated by a carriage return or a comma depending on the command, and no action takes place until the command terminator is sensed. The user can cancel a command before entering the command terminator by pressing any illegal key (e.g., rubout or Control-X). Table 2 contains a summary of the loader and monitor commands. These commands will not be explained in detail; instead, the next section of the application note will show examples of using these loader and monitor commands. The iSBC 957 User's Guide referenced at the front of this document does, however, contain a complete description of each of the monitor and loader commands. Table 3 contains a list of the 8086 hardware registers and abbreviations used by the monitor program. Table 3 8086 CPU REGISTERS | REGISTER NAME | ABBREVIATION | |---------------------|--------------| | Accumulator | AX | | Base | BX | | Count | cx | | Data | DX | | Stack Pointer | SP | | Base Pointer | BP | | Source Index | SI | | Destination Index | DI | | Code Segment | cs | | Data Segment | DS | | Stack Segment | SS | | Extra Segment | ES | | Instruction Pointer | IP | | Flag | FL | Figure 5. Memory Map of iSBC™ 86 / 12 Memory With Monitor Program Figure 5 contains a memory map of the iSBC 86/12 memory with the monitor program. Note that the monitor uses the top 8K bytes of memory for its program code and the first 384 bytes of memory (locations Ø hex to 17F hex) for monitor and user stack, data and interrupt vectors. When the monitor program is reset, the segment registers, the IP and the flags are set to 0; and the SP is set to 01C0H allowing 64 bytes for the user's stack. If 64 bytes is not sufficient for the user's application program, the SP should be set to some other value. The monitor program sets the single-step, one-byte instruction trap and non-maskable interrupt vectors to monitor entry points. The monitor also sets the 8259A Priority Interrupt Controller to fully nested mode with level 0 at the highest priority and all interrupts unmasked. The eight interrupt vector addresses for the 8259A are also set to addresses in the monitor. User programs may change the 8259A interrupt vectors to interrupt service routine addresses within the user programs; it is not necessary for users to program the 8259A chip directly. When an interrupt occurs, control passes to either the monitor or directly to user code depending on the address stored in the vector location. When the monitor responds to an interrupt, it acknowledges the interrupt and displays the interrupt level, CS and IP register values and next instruction byte on the system console (e.g., I = 3 @ 100:230F F5). When a user requests a breakpoint with a "G" command, the monitor inserts the single byte instruction trap instructions (INT 3) in the location where the breakpoint is requested. It is also possible for the user to code an INT 3 instruction in his program. When a user coded INT 3 instruction is executed, the monitor will be re-entered and a line with the format @<CS Value>:<IP Value> <Instruction byte> will be displayed (e.g., @1200:3FO2 F5). Included on the diskette with the Loader program are two libraries containing I/O routines for the console. The library files are named SBCIOS.LIB and SBCIOL.LIB; they contain similar routines. The routines in SBCIOS.LIB are written to be called with intrasegment subroutine calls, a PL/M-86 module compiled with the "small" control generates this type of call. The routines in SBCIOL.LIB are written to be called with intersegment subroutine calls, a PL/M-86 module compiled with either the "medium" or "large" control generates this type of call. The console input output routines, CI and CO, contained in the library should be used when performing character input and output on the console. Example PL/M-86 calls to the two routines are: CI: PROCEDURE BYTE EXTERNAL; END CI; CO: PROCEDURE (X) EXTERNAL; DECLARE X BYTE; END CO; ... DECLARE INPUT\$CHAR, OUTPUT\$CHAR BYTE; ... ... INPUT\$CHAR = CI; ... ... CALL CO(OUTPUT\$CHAR); # General Comments on Use of the iSBC 957 Package - 1. If the iSBC 86/12 board is reset any time after the initial baud rate search, it is not necessary to reload the iSBC 957 Loader program or to download the program code a second time to the iSBC 86/12 board. It is only necessary to reestablish the communications link by typing two "U"s for the baud rate search. - 2. The iSBC 86/12 board should not be plugged into an available card slot in an Intellec chassis; a separate chassis should be used. There are at least three reasons for this: - a. There is only one RESET signal available on the Intellec system bus. Thus, each processor may not be reset independently. This means that the iSBC 86/12 board cannot be reset without re-booting the ISIS-II operating system and restarting the iSBC 957 Loader. - b. The Intellec system uses five of the eight available interrupts on the system bus. This severely restricts the range of interrupts available to the iSBC 86/12 board. Also, the iSBC 86/12 board cannot turn-off the interrupt lamps on the Intellec front panel. - c. The iSBC 86/12 board may address up to 1 Megabyte of memory using a 20 bit address. Many Intellec systems contain boards which generate and decode only the low order 16 address bits. For example, the iSBC 016 memory expansion board and the Intellec 800 - monitor PROMs only decode 16 address bits. Memory expansion above 64K bytes in these systems is difficult since the boards which decode only 16 bits will force "holes" in the address space above 64K. - 3. The iSBC 86/12 board is delivered with two inputs to the 8259A Priority Interrupt Controller connected. Interrupt request 2 (IR2) is connected to the counter Ø output of the 8253 Programmable Interval Timer. IR5 is connected to the INT5/signal of the MULTIBUS System Bus. If these interrupts are not desired, the wire wrap jumpers making the connections should be removed from the iSBC 86/12 board. A particular problem may exist with the counter Ø connection to IR2. If the 8253 counter Ø is not specifically initialized with software, a low frequency square wave output will exist at counter Ø's output. This may cause unwanted interrupts when interrupts are enabled by user programs. - 4. If the iSBC 86/12 board is used in a system with expansion boards, it is important that the MULTIBUS bus exchange pins be properly jumpered. For example, if the iSBC 86/12 board is used with an iSBC 032 expansion memory board in a system, the BPRN/ MULTIBUS pin for the iSBC 86/12 board should be grounded. - In addition, if any interrupts are used with the iSBC 86/12 board the BPRN/ pin must be grounded. This is true in both single and multiple board systems. - 5. Certain user systems require more than one single board computer in the system for performing the functions required by the application. The MUL-TIBUS System Bus has been specifically designed to permit multiple CPU boards to communicate and to share system resources. However, debugging systems with multiple CPUs has always posed somewhat of a problem. The iSBC 957 package provides a solution to this problem. The serial cable which connects the iSBC 86/12 board to the Intellec system may be removed after the program has been downloaded to the iSBC 86/12 board. A console CRT may then be connected directly to the iSBC 86/12 board and the monitor program may be used to debug the program running on the board. Other iSBC 86/12 boards may also be downloaded from the Intellec system and then switched to their own local terminals. An 8-bit processor board, such as the iSBC 80/30 board, may also be included in the system and ICE-85™ may be used for debugging the iSBC 80/30 program concurrently with the iSBC 86/12 programs. Using this scheme, it is possible to debug a system which has several CPU boards by setting breakpoints and using other debugging features on each of the individual CPUs. ### V. MATRIX MULTIPLICATION EXAMPLE To illustrate how the iSBC 957 package can be used to assist in the writing and debugging of 8086 programs on the iSBC 86/12 board, an example program of a matrix multiplication will be presented. The example chosen has been intentionally kept simple and straightforward. The emphasis of this section will be to document the steps required to assemble, compile, link, locate and debug software using an Intellec system, the iSBC 957 package and the iSBC 86/12 board. Part of the example will be written in 8086 assembly language and part in PL/M-86. The main program is written in PL/M-86. The main program first performs some initialization and the matrix multiplication, then the program calls an assembly language procedure (subroutine), a PL/M-86 procedure and the console output procedure CO supplied in the I/O library on the iSBC 957 diskette. A flow diagram for the example program is shown in Figure 6. ### **Explanation of the Program Code** The program code is contained in three software modules EXECUTION\$VEHICLE, FIND, and SBCCO. EXECUTION\$VEHICLE contains the main program coded in PL/M-86 and the binary to ASCII conversion procedure BIN\$DEC\$ASC also coded in PL/M-86. The module FIND contains the assembly language procedure FIND\$MX which searches a matrix for its maximum value. The module SBCCO resides in the library of console I/O routines supplied with the iSBC 957 package. The procedure CO will be used from this library. The program code for the EXECUTION\$VEHICLE and FIND modules will be explained in the following paragraphs. Appendix B contains compilation and assembly listings for the two modules; also contained in Appendix B is a memory and debug map for the linked modules. The listings contain circled reference letters (e.g., (A)) which are referred to by the code description below. The listings in the appendix have been printed on fold-out pages so that they may easily be seen when reading the text. Figure 6. Flow Diagram of Matrix Multiplication Example Much of the description given below assumes that the reader is familiar with the PL/M-86 language and compiler, the 8086 assembler, and the link and locate program QRL86. It is recommended that the reader have at least a cursory knowledge of these subjects. The Intel literature for these subjects is listed near the front of this application note. ### The EXECUTION\$VEHICLE Module - A The first section of the module includes introductory comments and then statements to declare the matrices, other variables, and procedures used in the program. Note that the matrix dimensions are declared using the literals M, N, and P which are initially set to 6, 5, and 3. Later in this note, other values for M, N, and P will be used. - B The next section of code contains the statements which initialize the two matrices that will be multiplied X\$ROW and Y\$ROW. As a result of this initialization, the two matrices will contain values as shown in Figure 7. $$\begin{bmatrix} 0 & 0 & 0 & 0 & 0 \\ 1 & 1 & 1 & 1 & 1 \\ 2 & 2 & 2 & 2 & 2 \\ 3 & 3 & 3 & 3 & 3 \\ 4 & 4 & 4 & 4 & 4 \\ 5 & 5 & 5 & 5 & 5 \end{bmatrix}$$ X\$ROW (6X5) Y\$ROW (5X3) Figure 7. X\$ROW and Y\$ROW Matrices After Initialization C The next program section performs the matrix multiplication. The algorithm required to multiply two matrices X and Y, storing the result in a third matrix Z is: $$Z_{mp} = \sum_{i=1}^{n} X_{mi} * Y_{ip}$$ Assuming X to be 6X5 matrix and Y a 5X3 matrix then $$Z_{11} = X_{11}Y_{11} + X_{12}Y_{21} + X_{13}Y_{31} + X_{14}X_{41} + X_{15}Y_{51}$$ Thus, the upper left term is equal to the sum of the products of the top row of the X matrix times the left column of the Y matrix. The result that is obtained by multiplying the two matrices X\$ROW and Y\$ROW after they are initialized as explained above, is shown in Figure 8. Z\$ROW (6X3) Figure 8. Result of Multiplying the Initialized Matrices X\$ROW and Y\$ROW D The external assembly language procedure FIND\$MX is called to determine the maximum value in the matrix. The procedure is a typed procedure and returns the maximum value to the calling program which stores it in the integer variable MAX. - (6) digit ASCII character string by the procedure BIN\$DEC\$ASC. The character string is stored in the array MAX\$ASC\$ARRAY, which contains the sign of the number and five (5) digits for the magnitude. - Finally, the characters "MAX VALUE =" are output on the system console followed by the 6 ASCII characters containing the maximum value. The PL/M-86 built-in procedure SIZE returns the number of bytes of the array TEXT as a word value. The PL/M-86 built-in procedure SIGNED changes the type of the value from WORD to INTEGER. This is required so that the type of the arguments in the DO statement agree. The console output procedure CO is used to output the characters on the system console. - (G) Also contained in the module MATRIX.PLM is the binary to ASCII conversion procedure BIN\$DEC\$ASC. The first portion of the code contains the comments explaining the parameters and the calling sequence followed by the declarations. Note that the address of the array where the characters are to be stored is passed to the procedure and that the characters will be stored in the array using based variables. The next section of the code stores either a + or sign in the first character position of the ASCII array and stores the absolute value of VALUE in the variable TEMP. Finally, the binary value is converted to ASCII using the algorithm explained in the comments. The MOD operator returns the remainder of the division by 10. The UNSIGN built-in procedure is required to change the type of the expression from INTE-GER to WORD. ### The FIND Module - H The FIND module contains the assembly language procedure FINDMX. The calling sequence and the parameters are explained in the comments at the beginning of the listing. Note that the label FINDMX has been declared PUBLIC so the link program can fill in its address in the CALL statement in the main program of module EXECUTION\$VEHICLE. - The FIND module will contain three segments: a data segment, a stack segment and a code segment. It will be both convenient and pragmatic to append these three segments to the code, data and stack segments created by the compiler for the EXECUTION\$VEHICLE module. To accomplish this, the three segments must be given the same SEGMENT and CLASS names as those given these segments by the compiler. The SEGMENT and CLASS names used by the compiler are CODE, DATA, and STACK. The GROUP statements are used to place the segments DATA and STACK in the group DGROUP and the segment CODE in the group CGROUP. These group definitions conform with the group definitions generated by the PL/M-86 compiler when the SMALL size control option is used. A group is a collection of segments which requires less than 64K bytes of memory. The ASSUME directive informs the assembler that the DS and SS registers will contain the base address of DGROUP and the CS register will contain the base address of CGROUP. This information will be used by the assembler when constructing machine instructions. - The first segment appearing in the module is the data segment. The order of the segments is arbitrary, although it is recommended that the data segment precede the code segment to minimize forward references to variables which may cause the assembler to generate longer instruction codes. The data segment is declared PUBLIC, aligned on a WORD boundary and given both a segment and class name of DATA. Then follows the contents of the segment. In this particular example, only one word of storage is required. The ENDS directive indicates the end of the segment. - (K) Next comes the stack segment which is given the segment name of STACK, the combinetype attribute of STACK and the class name of STACK. The combine-type attribute of STACK assures that the stack storage required in this module will be appended to the storage required in the PL/M-86 compiled modules. Two bytes of stack are required by the code in this module, however, the monitor uses 13 words of stack when breakpoints and interrupts are used. Therefore, 14 words are reserved for the stack. - (L) Finally comes the code segment. The code segment has been given a segment name and class name of CODE and a group name of CGROUP, and has been declared PUBLIC. The alignment attribute of BYTE is specified since it is desired that the code from this module be appended directly to the code from other modules without gaps between the code modules. The assembly language code follows next. The code for the procedure must be enclosed between a pair of PROC, ENDP statements. The PROC statement is given the label FINDMX and specified as a NEAR procedure indicating it will be called with a near (intra-segment) CALL instruction and not a far (inter-segment) CALL instruction. The comments at the beginning of the module and adjacent to the program statements explain the function being performed by the assembly language code. ### The SBCCO Module M The console output procedure CO is contained in the object module SBCCO of the library file SBCIOS.LIB. SBCIOS.LIB is part of the iSBC 957 package I/O libraries. The calling sequence and parameters for CO may be seen in the external procedure declaration in the EXE-CUTION\$VEHICLE module. # Compiling the EXECUTION\$VEHICLE Module The EXECUTION\$VEHICLE module is stored on a file named MATRIX.PLM on disk device :F1:. To compile the module, the following command line is used: ### - PLM86:F1:MATRIX.PLM DEBUG This command line will cause the module stored in the file:F1:MATRIX.PLM to be compiled. The object code generated will be stored in a file with the default name:F1:MATRIX.OBJ and the listing generated will be stored in a file with the default name:F1:MATRIX.LST. To override the default object and listing files, the NOOBJECT and NO-LIST compiler control switches can be used. File names for the listing and object files may also be specified in the command line. The DEBUG compiler control switch causes the compiler to generate extra symbol and line number information which will be used during debugging of the program. A listing of the compiled EXECUTION\$VEHICLE module is contained in Appendix B. To aid in the debugging of the program, the module was compiled a second time with the following command line: ### – PLM86 :F1:MATRIX.PLM NOOBJECT CODE DEBUG PRINT (:F1:MATRIX.XLS) This command line specified that no object file is to be created and a listing file should be stored in the file :F1:MATRIX.XLS. The CODE compiler control switch causes the compiler to list the assembly language statements which the compiler has generated for each line of PL/M code. The listing stored in the file MATRIX.XLS is contained in Appendix C. ### Assembly of the FIND Module The assembly language module FIND is stored on a file named FIND.ASM, to assemble this module the following command line is used: ### ASM86:F1:FIND.ASM DEBUG This command line will cause the FIND module to be assembled with the object code stored in the default file:F1:FIND.OBJ and the listing stored in the default file:F1:FIND.LST. The listing of the assembled FIND module is contained in Appendix B. ### Linking and Locating the Object Module To link and locate the object modules, the QRL86 program will be used. The QRL86 program performs both the linking and the locating of the object modules in a single step. QRL86 is primarily designed for the debugging stages of program development. Some applications may require the extended capabilities of the separate LINK and LOCATE programs when the final link and locate is performed. The command line used to invoke the QRL86 program is: # QRL86:F1:MATRIX.OBJ,:F1:FIND.OBJ, SBCIOS.LIB ORIGIN (1000H) This command line will cause QRL86 to link the code from the three modules and to locate the resultant absolute object module starting at location 1000 hexadecimal. The iSBC 86/12 monitor uses the first 180H bytes of memory for the monitor stack, data and interrupt vectors, 1000H was chosen as a convenient starting address for the program. The absolute object code will be stored in a default file:F1:MATRIX (note no file name extension is used). By default, the memory and debug maps which are generated are stored in the file:F1:MATRIX.MPQ and are contained in Appendix B. N The memory map contains the starting addresses and sizes of the CODE, CONST, DATA, STACK and MEMORY segments of the object module. Note that the start address for the program is specified as (\$1\$\$\text{\$0\$}H, \$\text{\$0\$}\text{\$0\$}2H) indicating a CS value of 0100H and an IP value of $\emptyset\emptyset\emptyset2H$ or an absolute value of $\emptyset1\emptyset\emptyset2H$ . The first two bytes of the code segment contain address values which the code generated by the compiler will use for setting up the DS and SS registers. The memory map shows the code segments from the three modules collected into the group CGROUP. The code segment from the EXECUTION\$VEHICLE module is given the segment and class names of CODE and is put into CGROUP by the PL/M compiler. To assure that the code segment from the FIND module is concatenated with the code segment from the EXECUTION\$VEHICLE module the identical class, segment and group names were specified in the SEGMENT and GROUP statements in the FIND module. Next, the group DGROUP is shown in the memory map. DGROUP contains 4 segments labelled CONST, DATA, STACK and MEMORY. Putting all of these segments in the same group tells the linker that they will all be in the same 64K block of memory. The SMALL size control option of the compiler, which was invoked by default, creates CGROUP, DGROUP, and the segments contained in them. The debug map contains the memory address of variables, instruction labels and the addresses of each code line of the PL/M-86 module. Notice that the variable storage labels have their addresses specified in the format (DS register value, displacement). For example, the variable TEMP has an address of DS=\$\Pi\$12AH, displacement = \$\Pi\$\$\Pi\$\$CH or an absolute address of \$\Pi\$136H. Instruction labels and line numbers use the format (CS register value, IP register value). Thus, line number six (6) in the module EXECUTION\$VEHICLE has the address CS=\$\Pi\$1\$\Pi\$\$H, IP=\$\Pi\$B5H or \$\Pi\$11B5H. ### Object to Hex Conversion Before downloading the program to the iSBC 86/12, the format of the object module must be converted from the absolute object module format which QRL86 creates to a hexadecimal/ASCII representation of the object module. This is done using the program OH86 with the following command line: ### OH86:F1:MATRIX TO:F1:MATRIX.HEX ### Downloading and Debugging the Program The hardware configuration used for debugging the matrix multiplication example program code was an Intellec Series II Model 230 development system, the iSBC 957 package, an iSBC 86/12 board, and an iSBC 660 system chassis. What follows is the system-user dialog for a typical debugging session. The first step required is to bootstrap load the ISIS-II operating system by hitting the RESET switch of the Intellec. The Intellec resident loader software is then loaded and executed. Throughout the dialog which follows operator entered characters will be underlined: ``` ISIS-II, V3.4 -<u>SBC861</u> ISIS-II ISBC 86/12 LOADER, V1.2 ``` To initialize the iSBC 86/12 monitor, the user must hit the RESET switch on the iSBC 660 chassis and type two "U"s on the system console. The monitor program will output a line on the console when it is properly initialized. ``` ISBC 86/12 MONITOR, V1.2 ``` The monitor command "X" is typed to check that the monitor is properly operating and to examine the contents of the 8086 registers. ``` X AX=0000 BX=0000 CX=0000 DX=0000 SP=01C0 BP=0000 SI=0000 DI=0000 CS=0000 DS=0000 SS=0000 ES=0000 IP=0000 FL=0000 ``` To download the hex object file to the iSBC 86/12, the "L" command is used. Because an Intellec Series II Model 230 is being used, a serial download is specified. The hex file name is MATRIX.HEX which is resident on disk device :F1:. ``` .LS,:F1:MATRIX,HEX ``` The "X" command is used again to examine the CPU registers. Note that the monitor has changed the contents of the CS and IP registers to the value of the starting address of the program. ``` .X AX=0000 BX=0000 CX=0000 DX=0000 SP=01C0 BP=0000 SI=0000 DI=0000 CS=0100 DS=0000 SS=0000 ES=0000 IP=0002 FL=0000 ``` The "D" command is next used to display the first 101 bytes of the program code. Unless another segment register is specified, the display command assumes all addresses specified are relative to the CS register. Thus, the code displayed will be from absolute addresses 1000 through 1100. The program code displayed may be compared with program code generated by the PL/M-86 compiler shown in Appendix C, code line 36. ``` 00 00 81 3E 8E 00 05 00 7E 00 00 80 81 3E 8E 00 05 00 7E 00 00 00 81 3E 90 00 04 00 3E 00 B9 0A 00 F7 00 90 96 0020 00 C7 0030 22 00 0040 E6 89 Ø6 8B 8B 36 81 06 C7 0050 00 E9 D3 FF 0060 00 00 00 81 E9 40 0070 90 0080 06 90 00 F7 D8 50 8B 90 00 D1 E6 89 C3 00 E9 CF FF 81 06 06 8E 59 89 06 00 00 B9 00 0090 36 90 00A0 01 00 88 4C D1 E6 7E 03 E9 41 00 8B 06 ``` The PL/M-86 compiler ends the main program in the EXECUTION\$VEHICLE module with a halt instruction. After execution of the program it is more desirable to return to the monitor. To accomplish this, an INT 3 instruction (code=CC) will be substituted for the halt instruction (code=F4) at the address of 1B4H relative to a CS value of 100H. First the "D" command is used to verify the address of the halt instruction, then the "S" command is used to change the instruction to an INT 3 instruction. ``` .<u>D184</u> 0184 F4 .<u>S184</u>, F4- <u>CC</u> ``` To execute the PL/M-86 main program, the "G" command is used. After the "G" is typed, the current contents of the IP are output, followed by the contents of the byte pointed to by the IP. A new value for the IP or breakpoint addresses may be specified before a carriage return <CR> is typed. In this example, only a <CR> is typed. ``` .G 0002- FA MAX VALUE = -00050 00100:01B5 55 ``` The program executes and outputs the maximum value of the matrix calculated. The INT 3 instruction is executed which causes a return to the monitor. The monitor types out an at-sign (@) followed by the CS and IP register values and the first byte of the instruction following the INT 3 instruction. The "X" command is typed to examine the CPU registers. Note that the program has set both the SS and DS registers to \$\phi12A\$. (\$\phi12A\phiH\$ is the address of the DGROUP as shown in the memory map.) ``` .X AX=0030 BX=0005 CX=000A DX=0000 SP=00D0 BP=00D0 SI=0001 DI=0006 CS=0100 DS=012A SS=012A ES=0000 IP=01B5 PL=F202 ``` The three matrices are displayed. Note that a word display has been specified by using the "DW" Command and that the addresses have been specified relative to the DS register. The addresses of X\$ROW, Y\$ROW, and Z\$ROW may be found in the debug map given by QRL86. Note that the values stored in the matrices are the same as those shown in Figures 8 and 9. The "G" Command is used to reset the IP register to the start address of the program (\$\phi 2\$) and to specify a breakpoint at address \$\phi AEH\$, which is the address of statement 57 of the main program. Statement 57 is the point in the program after the X\$ROW and Y\$ROW matrices have been initialized, but before the matrix multiplication is performed. After the <CR> is typed, the program executes until the breakpoint is encountered. At this point, the monitor outputs a line specifying the number of the breakpoint, the CS and IP values and the first byte of the next instruction to be executed. ``` .G 0185- 55 002,AE BR1 00100:00AE C7 ``` Next, the single-step capability is used with the "N" command to execute single instructions. At any time, CPU registers may be examined or changed. In this example, the "X" command is used. Execution of succeeding instructions is caused by typing a comma (,). The contents of the X\$ROW and Y\$ROW matrices are examined and changed with the "SW" (substitute word) command. If a comma (,) is typed after the contents of memory are displayed, then the contents are left unchanged and the next word of memory is displayed. If a value followed by a comma or <CR> is entered, then the contents are changed. If a <CR> is entered, the substitute sequence is terminated. ``` .SW DS:1A, 0001-, 001C 0001- 1001C 0001- 1001- 1001- 1005C FFFF-, 005C 0000- 10060 FFFF- 64 ``` After the matrices are modified, execution is resumed with the "G" command. The max value is output and the INT 3 instruction executed. Finally, the contents of the 3 matrices are displayed. # Expanding the Example Program's Memory Requirements To illustrate how the iSBC 86/12 board may be used for executing 8086 programs which require large amounts of RAM, the example program will be modified. The matrix dimensions of the example will be changed from values of 6, 5 and 3 for the literal symbols of M, N, and P to values of 100, 50, 70. The three matrices will then be of size 100X50, 50X70, and 100X70. The memory required for these matrices is 15.5K words or 31K bytes. The data, constant, stack and memory segments which are contained in the group DGROUP will now comprise almost 32K bytes of memory. The extra memory requirements will be supplied by using an iSBC 032 board with the iSBC 86/12 board in the iSBC 660 chassis. The iSBC 032 board is a 32K byte RAM board which is compatible with both 8- and 16-bit CPU boards. The base address of the board may be selected anywhere in a 0 to 1 megabyte range on any 16K byte boundary. 8- or 16-bit data transfers may be selected. The iSBC 032 board will be jumpered to respond to addresses in the 512K or 544K address space (20 bit hex address range to 80000H to 87FFFH). This will illustrate the capabilities of the 8086 to access a 20-bit, 1 megabyte address range. One other modification is required to the program. The magnitude of the numbers which would result from multiplying matrices of this size would greatly exceed the capacity of the 16-bit integer storage, even with the two matrices initialized to the small values they presently contain. To keep the example simple, the initialization values will be changed so all elements of the X\$ROW matrix are set equal to 2 and all elements of the Y\$ROW matrix are set equal to 3. The result of the multiplication should make all the elements of Z\$ROW equal to 300. The modified lines of program code are shown below. ``` /* MATRIX DIMENSIONS */ 27 1 DECLARE M LITERALLY '100'; 28 1 DECLARE M LITERALLY '100'; 29 1 DECLARE N LITERALLY '70'; 36 1 DO I = W TO (M-1); 37 2 DO J = 0 TO (N-1); 38 3 XSROW(I).COL(J) = 2; 40 2 END; 41 1 DO I = 0 TO (N-1); 42 2 DO J = 0 TO (P-1); 43 3 YSROW(I).COL(J) = 3; 44 3 END; 45 2 END; ``` The EXECUTION\$VEHICLE module must be recompiled and then the three program modules must be linked and located using the QRL86 program. Specifying the SEGMENTS option of QRL86, the origin of the CODE segment which is in the group CGROUP is set at 1000H, as in the first example. However, the origin of the CONST, DATA STACK and MEMORY segments which make up the group DGROUP is set at 80000H. ``` QRL86:F1:MATRIX.OBJ,:F1:FIND.OBJ, SBCIOS.LIB SEGMENTS (CODE(1000H), CONST (80000H), DATA STACK, MEMORY) ``` The memory map generated by QRL86 shows the CGROUP having a start address of 01000H and the DGROUP having a start address of 80000H. ``` INVOKED BY: ORL86 :F1:MATRIY.OBJ,:F1:FIND.OBJ,SBCIOS.LIB & SEGMENTS (CODE (1000H), CONST (8000UH), DATA, STACK, MEMORY) :F1:MATRIY.OBJ(EXECUTIONVEHICLE) :Fl:FIND.OBJ(FIND) SBCIOS.LIB(SBCCO) RESULT WRITTEN TO :F1:MATRIY(EXECUTIONVEHICLE) START ADDRESS IS (0100H,0002H) START LTH ALIGN NAME CLASS атааан 298H /GS / CGROUP 21DH CODE (EXECUTIONVEHICLE) Ø121DH 41 H CODE (FIND) CODE CODE (SBCCO) Ø125EH CODE 3AH W /GE/ CGROUP /GS/ DGROUP 86000H 7970H CONST (EXECUTIONVEHICLE) CONST 8000CH ЯΗ CONST (SECCO) CONST DATA (EXECUTIONVEHICLE) 87936H 2H DATA (FIND) DATA 87938H DATA (SBCCO) SW W 8794ØH 3 Ø H STACK 87970H MEMORY MEMORY ØН /GE / DGROUP ??SEG(FIND) 8797ØH ØH (NULL) ``` The object code is then converted to hex format and downloaded to the iSBC 86/12 board. When the program is executed, the maximum value is calculated and output on the console. ``` -53C861 ISIS-II ISBC 86/12 LOADER, V1.2 ISBC 86/12 MONITOR, V1.2 .Ls,:F1:MATRIY.HEX .S1AC, F4- CC .G 002- FA MAX VALUE = +80300 e0100:01AD 55 ``` ### VI. CONCLUSION This application note has described the iSBC 957 Intellec-iSBC 86/12 Interface and Execution Package, and how this package may be used to develop and debug programs for the 8086 processor. First, the iSBC 86/12 single board computer was described, followed by a detailed description of the iSBC 957 package and the iSBC 86/12 system monitor commands. The power and versatility of the iSBC 957 package and monitor commands for developing and debugging programs for the 8086 were illustrated by a program example. In the example a program which consisted of PL/M-86 and assembly language routines was presented. The program code was explained, and the steps required to compile, assemble, link, locate, and debug the program were illustrated. Finally, a typical debugging session using the iSBC 86/12 system monitor which illustrates the powerful capabilities of the monitor was presented. A-229 ### APPENDIX B ### PROGRAM LISTINGS FOR EXECUTION\$VEHICLE AND FIND MODULES ``` EXECUTIONVEHICLE PL/M-86 COMPILER ISIS-II PL/M-86 V1.8 COMPILATION OF MODULE EXECUTIONVEHICLE OBJECT MODULE PLACED IN :F1:MATRIX.OBJ COMPILER INVOKED BY: PLM86 :F1:MATRIX.PLM DEBUG MATRIX MULTIPLICATION EXAMPLE PROGRAM PL/M-86 MAIN PROGRAM WHICH: A) INITIALIZES TWO INTEGER MATRICES B) MULTIPLIES THE TWO MATRICES AND STORES THE RESULT IN A THIRD MATRIX C) CALLS AN ASSEMBLY LANGUAGE PROCEDURE WHICH SEARCHES THE THIRD MATRIX FOR THE MAXIMUM VALUE D) CALLS A PL/M PROCEDURE WHICH CONVERTS THE MAXIMUM VALUE FROM INTEGER TO ASCII E) CALLS A PROCEDURE WHICH OUTPUTS THE ASCII CHARACTERS ON THE SYSTEM CONSOLE 1 EXECUTIONS VEHICLE: DO; /* FINDSMX - EXTERNAL ASSEMBLY LANGUAGE PROCEDURE WHICH SEARCHES A MATRIX FOR THE LARGEST ABSOLUTE MAGNITUDE. PARAMETERS: METERS: MATRIXSADR - ADDRESS OF THE MATRIX TO BE SEARCHED ROWS - NUMBER OF ROWS IN THE MATRIX COLS - NUMBER OF COLUMNS IN THE MATRIX FINDSMX: PROCEDURE (MATRIXSPTR, ROWS, COLS) INTEGER EXTERNAL; DECLARE (ROWS, COLS) INTEGER; DECLARE MATRIXSPTR POINTER; END FINDSMX; BINSDECSASC - BINARY TO DECIMAL ASCIT CONVERSION PROCEDURE PARAMETERS: VALUE - INTEGER VALUE TO BE CONVERTED TO ASCII CHARSARRAYSADR - ADDRESS OF 6 BYTE ARRAY WHERE ASCII STRING CONTAINING THE VALUE WILL BE STORED 1 BINSDECSASC: PROCEDURE (VALUE, CHARSARRAYSADR); DECLARE (VALUE, TEMP, I) INTEGER; DECLARE CHARSARRAYSADR POINTER; DECLARE (CHARSARRAY BASED CHARSARRAYSADR) (6) BYTE; (A) 9 2 11 2 DO; CHARSARRAY(0) = '-'; /* SIGN CHARACTER */ (G) TEMP = -VALUE; 13 3 END; ELSE 2 15 DO: CHARSARRAY(0) = '+'; TEMP = VALUE; END; DO 1 = 5 TO 1 BY -1; CHARSARRAY(1) = UNSIGN(TEMP MOD 10) + 39H; 18 TEMP = TEMP/10; /* ASCII CHARACTERS 30 THRU 39 HEX REPRESENT THE DIGITS 0 THRU 9. THE TO CONVERT AN INTEGER TO ASCII REPEATED DIVISIONS BY 10 AND ADDING THE REMAINDER TO 30 HEX WILL ACCOMPLISH THE CONVERSION */ 21 22 2.3 2 END BINSDECSASC: CO - EXTERNAL PROCEDURE TO OUTPUT A CHARACTER TO THE SYSTEM CONSOLE. THIS PROCEDURE IS PART OF THE ISBC 957 LIBRARY FOR CONSOLE I/O PARAMETER: (M) CHAR - ASCII CHARACTER TO BE OUTPUT ON THE CONSOLE CO: PROCEDURE (CHAR) EXTERNAL; 24 DECLARE CHAR BYTE; END CO; /* MATRIX DIMENSIONS */ DECLARE M LITERALLY '6'; DECLARE N LITERALLY '5'; DECLARE P LITERALLY '3'; /* THE THREE MATRICES ARE DECLARED AS ARRAYS OF STRUCTURES. XSROW IS COMPOSED OF M STRUCTURES EACH OF WHICH IS COMPOSED OF N INTEGER ELEMENTS. THUS XSROW MAY BE THOUGHT OF AS A M X N MATRIX. THE MATRIX WILL BE STORED AS A ROW-ORDER MATRIX WITH THE ELEMENTS OF EACH ROW STORED IN ADJACENT MEMORY. A ROW-ORDER MATRIX WITH THE ELEMENTS OF EACH ROW STORED IN ADJACENT MEMORY LOCATIONS. YSROW IS DECLARED AS A N X P MATRIX AND ZSROW AS A N X P MATRIX */ DECLARE XSROW (M) STRUCTURE (COL(P) INTEGER); DECLARE XSROW (M) STRUCTURE (COL(P) INTEGER); DECLARE ZSROW (M) STRUCTURE (COL(P) INTEGER); DECLARE (T,J,K,MAX) INTEGER; DECLARE MAXSASCSARRAY(6) BYTE; DECLARE MAXSASCSARRAY(6) BYTE; DECLARE TEXT(*) BYTE DATA ('MAX VALUE = '); 32 33 ``` ``` /* INITIALIZE XSROW SUCH THAT THE FIRST ROW IS SET EQUAL TO 0, THE SECOND ROW EQUAL TO 1, THE THIRD ROW EQUAL TO 2, ETC. */ DO I = 0 TO (M-1); XSROW(I).COL(J) = I; 36 37 38 39 END; 10 B /* INITIALIZE Y$ROW SUCH THAT THE FIRST COLUMN IS SET EQUAL TO 0, THE SECOND COLUMN EQUAL TO -1, AND THE THIRD COLUMN EQUAL TO -2. */ DO I = 0 TO (N-1); DO J = 0 TO (P-1); Y$ROW(I).COL(J) = -J; 41 1 42 END; END; /* PERFORM MATRIX MULTIPLICATION */ 45 2 DO K = 2 TO (P-1); DO I = 0 TO (M-1); Z$ROW(I).COL(K) = 0; /* SET Z$ROW ELEMENT TO 0 */ DO J = 0 TO (N-1); /* SUN THE PRODUCT OF X$ROW ROW TERMS AND Y$ROW COLUMN TERMS */ DO J = 0 TO (N-1); /* SUN THE PRODUCT OF X$ROW ROW TERMS AND Y$ROW COLUMN TERMS */ DO J = 0 TO (N-1); /* SUN THE PRODUCT OF X$ROW(I).COL(J) * Y$ROW(J).COL(K) ); 46 C END; END; END; 1 MAX = FINDSMX (@ZSROW, M, P); /* FIND MAX VALUE OF ZSROW */ CALL BINSDECSASC (MAX, @MAX$ASC$ARRAY); /* CONVERT TO DECIMAL ASCII */ 56 DO I = \emptyset TO (SIGNED(SIZÈ(TEXT)) - 1); /* OUTPUT HEADER TEXT */ CALL CO(TEXT(I)); END; DO I = @ TO 5; /* OUTPUT ASCII MAX VALUE */ 60 CALL CO(MAXSASCSARRAY(I)); 62 1 END EXECUTIONS VEHICLE: MODULE INFORMATION: CODE AREA SIZE = 0225H CONSTANT AREA SIZE = 000CH VARIABLE AREA SIZE = 0008H MAXIMUM STACK SIZE = 0008H 549D 1 20 137 LINES READ Ø PROGRAM ERROR(S) END OF PL/M-86 COMPILATION ISIS-II MCS-86 ASSEMBLER ASSEMBLY OF MODULE FIND OBJECT MODULE PLACED IN :F1:FIND.OBJ ASSEMBLER INVOKED BY: ASM86 :F1:FIND.ASM DEBUG SOURCE LINE NAME PUBLIC FINDMX 2 ASSEMBLY LANGUAGE PROCEDURE TO FIND THE ELEMENT OF AN INTEGER MATRIX WITH THE LARGEST ABSOLUTE MAGNITUDE. THE VALUE OF THE ELEMENT IS RETURNED IN THE AX REGISTER. 9 10 11 PL/M CALLING SEQUENCE: MAXSVALUE = FINDSMX(ADRSOFSMATRIX, #SOFSROWS, #SOFSCOLS); PARAMETERS: ADRSOFSMATRIX - ADDRESS OF THE MATRIX WHICH WILL BE SEARCHED #SOFSROWS - NUMBER OF ROWS IN THE MATRIX #SOFSCOLS - NUMBER OF COLUMNS IN THE MATRIX 15 16 17 (H PL/M WILL PASS THE THREE PARAMETERS IN THE CALL TO THIS PROCEDURE ON THE STACK. ON EMTRY TO THE PROCEDURE SP+6 WILL POINT TO THE FIRST PARAMETER (ADRSOFSMATRIX) AND SP+4 AND SP+2 WILL POINT TO THE SECOND AND THIRD PARAMETERS. 19 20 21 23 THE PROCEDURE IS A TYPED PROCEDURE WHICH ASSIGNS THE MAXIMUM VALUE IN THE MATRIX TO A VARIABLE (IN THIS CASE MAXSVALUE) IN A PL/M ASSIGNMENT STATEMENT. TO ACCOMPLISH THIS ASSIGNMENT THE VALUE IS RETURNED IN THE AX REGISTER. 24 26 28 29 THE ALGORITHM USED IS SIMILAR TO THE FOLLOWING PL/M CODE: FOR I = 0 TO ($SOFSROWS - 1); FOR J = 0 TO ($SOFSCOLS - 1); IF IABS(MATRIX(1).Y(J)) > IABS(MAX) THEN MAX = MATRIX(I).Y(J); 30 31 32 33 34 35 36 37 WHERE IABS(XYZ) REPRESENTS THE ABSOLUTE VALUE OF THE INTEGER XYZ ``` ### APPENDIX B # PROGRAM LISTINGS FOR EXECUTION\$VEHICLE AND FIND MODULES ``` LOC OBJ LINE 41 DEFINE GROUPS TO CONFORM WITH PL/M-86 CONVENTIONS. DATA, STACK, AND CODE SEGMENTS WILL BE APPENDED TO THEIR RESPECTIVE SEGMENTS IN THE PL/M-86 MODULES. GROUP DATA, STACK GROUP CODE (I) DOROUR 45 46 47 CODE CGROUP INSTRUCT THE ASSEMBLER THAT THE DS, SS, AND CS REGISTERS WILL CONTAIN THE BASE ADDRESS VALUES FOR THE DGROUP, DGROUP AND CGROUP GROUPS. ASSUME DS:DGROUP,SS:DGROUP,DS:CGROUP 51 52 53 54 55 ;************DATA SEGMENT (1) DATA SEGMENT WORD PUBLIC 'DATA' 0000 0000 56 57 58 MAX DATA ENDS *********STACK SEGMENT STACK SEGMENT STACK 'STACK' DW 14 DUP (0) 51 0000 (14 0000 RESERVE 13 WORDS OF STACK FOR MONITOR (K) ;AND 1 WORD FOR FINDMX PROCEDURE 64 65 66 67 STACK ENDS 68 CODE SEGMENT BYTE PUBLIC 'CODE' 69 70 ; PARAMETERS ON STACK, DISPLACEMENT FROM TOS INCREASED BY TWO DUE TO INITIAL PUSH NO OF ROWS EQU WORD PTR (BP+4) ADR_OF_MATRIX EQU WORD PTR (BP+8) 71 72 73 74 75 76 77 00041 0000 FINDMX PROC NEAR BP BP,SP ;PROCEDURE DECLARATION ;SAVE BP REGISTER ;BP POINTS TO PARAMETERS ON STACK ;SET DX = ABS OF CURRENT MAX = 0 ;DI = 1 (ROW INDEX) = 0 ;SI = J(COLUMN INDEX) = 0 ;MAX = CURRENT MAX = 0 0000 55 0001 8BEC PUSH 0003 33D2 0005 8BFA 0007 8BF2 0009 89160000 78 79 XOR DX,DX DI,DX MOV 80 81 82 SI,DX MAX,DX CX,NO_OF_COLS MOV 000D 884E04 SHL 83 CX,1 ;CX = (\$\$0F\$COLS) * 2 84 0012 PB5E08 ;TERMINATION FOR J(SI) INDEX MOV BX, ADR OF MATRIX ;ADRSOFSMATRIX PARAMETER ;BX POINTS TO FIRST ELEMENT OF A GIVEN ROW 86 0015 8B00 ABC: (L) MOV AX,[BX][SI] AX,AX DEF 0017 0BC0 P019 7902 GET ELEMENT OF MATRIX 8.8 OR JNS SET FLAGS JUMP IF SIGN = 8 ;NEGATE TO FOR POSITIVE NUMBER ;COMPARE TO CURRENT MAX ;JUMP IF LESS THAN CURRENT MAX ;MOVE TO ABS OF CURRENT MAX ;MOVE TO ABS OF CURRENT MAX 89 001B F7D8 001D 3BC2 001F 7C07 0021 8BD0 NEG CMP JL 9 A 9 I ΑX DEF: AX,DX 92 MOV MOV 0023 8B00 0025 A30000 AX,[BX][SI] MAX,AX 94 MOV 0028 83C602 002B 3BF1 96 97 X V 7 · ADD CMP SI,2 SI,CX ;INCREMENT J INDEX BY TWO ;END OF THIS ROW ?? ;IF NO, LOOP BACK FOR NEXT ELEMENT OF THIS ROW ;BX = BX + (2 * $SOF$COLS), BX POINTS TO NEXT ROW ;J = \theta 002D 72E6 002F 8D18 98 JR. 99 BX,[BX+SI] 0031 BE0000 0034 47 100 MOV DI 0035 3B7E06 102 CMP DI.NO OF ROWS ; LAST ROW ?? 0038 72DB 103 JB MOV ; IF NO, DO THE NEXT ROW ; RETURN MAX VALUE IN AX REGISTER ; RESTORE BP REGISTER ABC 003A A10000 003D 5D 104 AX,MAX POP 883E C28688 106 ; INCREMENT SP BY 6 AND RETURN TO CALLER RET 108 FINDMX ENDP CODE 110 ENDS END SYMBOL TABLE LISTING TYPE VALUE ATTRIBUTES SEGMENT L NEAR SIZE=0000H PARA PUBLIC 0015H CODE [BP] V WORD GROUP CODE SIZE=0041H BYTÉ PUBLIC 'CODE' CODE. . . . . DATA. . . . SEGMENT SEGMENT SIZE=0002H WORD PUBLIC 'DATA' DEF . . . DGROUP. . L NEAR GROUP L NEAR ØØIDH CODE DATA STACK CODE PUBLIC FINDMX... MAX... NO OF COLS. NO OF ROWS. ееввн V WORD V WORD V WORD 0000H 0004H DATA (BP) 0006H ÎRPÎ STACK . . . SEGMENT L NEAR SIZE=001CH PARA STACK 'STACK' 0028H CODE ASSEMBLY COMPLETE, NO ERRORS FOUND ``` ``` ISIS-II QRL-86, VI.1 INVOKED BY: QRL86 :F):MATRIX.OBJ,:F1:FIND.OBJ,SBCIOS.LIB ORIGIN(1000H) INPUT MODULES INCLUDED: :F1:MATRIX.OBJ(FXFCUTIONVEHICLE) :F1:FIND.OBJ(FIND) SBCIOS.LIB(SBCCO) RESULT WRITTEN TO :F1:MATRIX(EXECUTIONVEHICLE) START ADDRESS IS (0100H,0002H) START LTH ALIGN NAME CLASS /GS/ CGROUP CODE (EXECUTIONVEHICLE) CODE CODE 01000H 01000H 2A@H 225H G W CODE (EXECUTIONVEHICLE) CODE CODE (SID) CODE CODE (SBCCO) CODE (GS/ DGROUP CONST (EXECUTIONVEHICLE) CONST CONST (EXECUTIONVEHICLE) DATA (EXECUTIONVEHICLE) DATA 41H 3AH B W 012AFH DØH Ø12AØH P12ACH CH ØH 012ACH 0133CH 0133EH 01340H W W SW 968 2H ØH DATA (FIND) DATA (SBCCO) DATA STACK MEMORY /GE/ DGROUP ??SEG(FIND) STACK 01370H ØН W @137ØH øн G (NULL) ``` | 1 | | | | | 10 | e1eem,e139H | LINE #: | 5.2 | |----------|--------------|---------------------|-------------------|---------|-----|--------------|---------|--------| | | | MODULE: EXECUTIONVE | HICLE 0100H,01E1H | LINE #: | 19 | | | | | | 012AH, 00D0H | SYMBOL: MEMORY | @l@@H,@lfBH | LINE #: | 20 | 0100H,0142H | LINE #: | | | - 1 | 0100H.01B5H | SYMBOL: BINDECASC | 0100H,0213H | LINE #: | 21 | 0100H,014BH | LINE #: | | | l | @12AH, @@@CH | SYMBOL: TEMP | 0100H,021EH | LINE #: | 22 | 0100H,015EH | LINE #: | | | | 012AH,000EH | SYMBOL: I | 0100H.0221H | LINE #: | 2.3 | рірен, рікэн | LINE #: | | | | 012AH,0010H | SYMBOL: XROW | 0100H,0002H | LINE #: | 36 | 0100H,017AH | LINE #: | 57 | | | 012AH,004CH | SYMBOL: YROW | 0100H,0021H | LINE #: | 37 | c100H,0185H | LINE #: | | | | @12AH, @@6AH | SYMBOL: ZROW | C100H.0032H | LINE #: | 38 | Ø100H,018EH | LINE #: | | | $\sim 1$ | 012AH,008EH | SYMBOL: I | 0100H,004BH | LINE #: | 3.9 | 0100H,0)9FH | LINE #: | 60 | | (P)( | 012AH,0090H | SYMBOL: J | 0100H.0054H | LINE #: | 40 | 0100H,01AAH | LINE #: | | | ひハ | @12AH,@@92H | SYMBOL: K | 0100H.005DH | LINE #: | 41 | 0100H,01B3H | LINE #: | 62 | | _ | 012AH,0094H | SYMBOL: MAX | 0100H,006EH | LINE #: | | | MODULE: | | | | 012AH,0096H | SYMBOL: MAXASCARRAY | 0100H.007FH | LINE #: | 43 | Ø1Ø0H,023AH | SYMBOL: | | | | 012AH, 0000H | SYMBOL: TEXT | 0100H,009CH | LINE #: | 04 | 0100H,0242H | SYMBOL: | | | | 0100H,01B5H | LINE #: 6 | 0100H,00A5H | LINE #: | 45 | 0100H,0225H | SYMBOL: | FINDMX | | | 0100H,01B8H | LINE #: 10 | 0100H.00AEH | LINE #: | 46 | 012AH,009CH | SYMBOL: | MAX | | | 0100H.01C2H | LINE #: 12 | Ø1@0H.Ø@BFH | LINE #: | 47 | 0100H,024DH | SYMBOL: | XYZ | | | 0100H,01C8H | LINE #: 13 | 0100H,00DeH | LINE #: | | Ø100H,0225H | PUBLIC: | FINDMX | | | glagh, glojh | LINE #: 14 | P100H.P0E7H | LINE #: | | | MODULE: | SBCCO | | | 0100H,01D4H | LINE #: 16 | 0100H.00F8H | LINE #: | | @100H.0266H | PUBLIC: | co | | | #100H, #1DAH | LINE #: 17 | 0100H.0130H | LINE #: | | | | | ### APPENDIX C ### PROGRAM LISTING FOR EXECUTION\$VEHICLE MODULE WITH CODE EXPANSION ``` DI /M-86 COMPILER EXECUTIONVEHICLE ISIS-II PL/M-86 V1.0 COMPILATION OF MODULE EXECUTIONVEHICLE NO OBJECT MODULE REQUESTED COMPILER INVOKED BY: PLM86 :F]:MATRIX.PLM DEBUG CODE NOOBJECT PRINT(:F]:MATRIX.XLS) MATRIX MULTIPLICATION EXAMPLE PROGRAM PL/M-86 MAIN PROGRAM WHICH: A) INITIALIZES TWO INTEGER MATRICES B) MULTIPLIES THE TWO MATRICES AND STORES THE RESULT IN A THIRD MATRIX C) CALLS AN ASSEMBLY LANGUAGE PROCEDURE WHICH SEARCHES THE THIRD MATRIX FOR THE MAXIMUM VALUE 1) CALLS A PL/M PROCEDURE WHICH CONVERTS THE MAXIMUM VALUE FROM INTEGER TO A SCII E) CALLS A PROCEDURE WHICH OUTPUTS THE ASCII CHARACTERS ON THE SYSTEM CONSOLE 1 EXECUTIONS VEHICLE: /* FINDSMX - EXTERNAL ASSEMBLY LANGUAGE PROCEDURE WHICH SEARCHES A MATRIX FOR THE LARGEST ABSOLUTE MAGNITUDE. PARAMETERS: METERS: MATRIXSADR - ADDRESS OF THE MATRIX TO BE SEARCHED ROWS - NUMBER OF ROWS IN THE MATRIX COLS - NUMBER OF COLUMNS IN THE MATRIX FINDSMX: PROCEDURE (MATRIXSPTR, ROWS, COLS) INTEGER EXTERNAL; DECLARE (ROWS, COLS) INTEGER; DECLARE MATRIXSPTR POINTER; END FINDSMX: /* BINSDECSASC - BINARY TO DECIMAL ASCII CONVERSION PROCEDURE PARAMETERS: VALUE - INTEGER VALUE TO BE CONVERTED TO ASCII CHARSARRAYSADR - ADDRESS OF 6 BYTE ARRAY WHERE ASCII STRING CONTAINING THE VALUE WILL BE STORED */ BINSDECSASC: PROCEDURE (VALUE, CHARSARRAYSADR); ; STATEMENT $ 5 BINDECASC PROC NEAR 1 PUSH BP BP,SP Ø1B5 55 Ø1B6 8BEC DECLARE (VALUE, TEMP, I) INTEGER; DECLARE CHARSARRAYSADR POINTER; DECLARE (CHARSARRAY BASED CHARSARRAYSADR) (6) BYTE; 9 2 IF VALUE < Ø THEN ; STATEMENT # 10 [BP].VALUE,0H Ø1B8 817E060000 CMP 01BD 7C03 01BF E91200 JL JMP $+5H @1 DO; CHARSARRAY(0) = '-'; /* SIGN CHARACTER */ ; STATEMENT # 12 BX, [BP]. CHARARRAYADR CHARARRAY[BX], 2DH 01C2 8B5E04 01C5 C6072D TEMP = -VALUE; MOV MOV 13 ; STATEMENT # 13 AX,[BP].VALUE 01C8 8B4506 MOV 01CB F7D8 NEG TEMP, AX CICD 89666666 MOV 14 END: ; STATEMENT # 14 01D1 E90D00 JMP a2 ELSE DO; CHAR$ARRAY(P) = '+'; ; STATEMENT # 16 BX, [BP] . CHARARRAYADR CHARARRAY [BX], 2BH MOV @1D4 8B5E#4 @1D7 C6@72B TEMP = VALUE; ; STATEMENT # 17 AX,[8P].VALUE 01DA 884506 21DD 89060000 MOV MCV TEMP, AX END: 18 3 DO I = 5 TO 1 BY -1; 19 ; STATEMENT # 19 I,5H 05 C70602000500 MOV JMP @1E7 E99669 ``` ADD 01EA 81860288FFFF I.ØFFFFH ``` P1F0 813E02000100 e1F6 7D03 01F8 E92600 I,)H $+5H JGE JMP 94 UNSIGN(TEMP MOD 10) + 30H; CHARSARRAY(I) = ; STATEMENT # 20 ØlfB 88660000 MOV AX, TEMP 01FF 0202 0204 B90A00 31D2 F7F9 MOV CX, ØAH IDIV ADD CX DX,30H 0206 020A 8B5E84 MOV MOV BX, [BP]. CHARARRAYADR 8B360200 020D 0211 MOV [BX].CHARARRAY[SI],DL 21 TEMP = TEMP/10; ; STATEMENT $ 21 /* ASCII CHARACTERS 30 THRU 39 HEX REPRESENT THE DIGITS 0 THRU 9. THUS TO CONVERT AN INTEGER TO ASCII REPEATED DIVISIONS BY 10 AND ADDING THE REMAINDER TO 30 HEX WILL ACCOMPLISH THE CONVERSION */ F213 8B060000 0217 99 0218 F7F9 MOV AX, TEMP TOTV MOV TEMP, AX 021A 89060000 22 END: 3 ; STATEMENT # 22 @3 #21F F9C9FF JM P . . 23 END BINSDECSASC; ; STATEMENT # 23 POP ВР BINDECASC RET 0222 C2040C 4 H ENDP CO - EXTERNAL PROCEDURE TO OUTPUT A CHARACTER TO THE SYSTEM CONSOLE. THIS PROCEDURE IS PART OF THE ISBC 957 LIBRARY FOR CONSOLE I/O PARAMETER: CHAR - ASCII CHARACTER TO BE OUTPUT ON THE CONSOLE CO: PROCEDURE (CHAR) EXTERNAL; DECLARE CHAR BYTE; END CO: /* MATRIX DIMENSIONS */ DECLARE M LITERALLY '6'; DECLARE N LITERALLY '5'; DECLARE P LITERALLY '3'; 27 ı 28 29 /* THE THREE MATRICES ARE DECLARED AS ARRAYS OF STRUCTURES. X$ROW IS COMPOSED OF M STRUCTURES EACH OF WHICH IS COMPOSED OF N INTEGER ELEMENTS. THUS X$ROW MAY BE THOUGHT OF AS A M X N MATRIX. THE MATRIX WILL BE STORED AS A ROW-ORDER MATRIX WITH THE ELEMENTS OF EACH ROW STORED IN ADJACENT MEMORY LOCATIONS. Y$ROW IS DECLARED AS A N X P MATRIX AND Z$ROW AS A N X P MATRIX */DECLARE X$ROW(M) STRUCTURE (COL(M) INTEGER); DECLARE X$ROW(M) STRUCTURE (COL(P) INTEGER); 31 32 DECLARE (I,J,K,MAX) INTEGER; DECLARE MAXSASCSARRAY(6) BYTE; DECLARE TEXT(*) BYTE DATA ('MAX VALUE = '); 34 /* INITIALIZE XSROW SUCH THAT THE FIRST ROW IS SET EQUAL TO 0, THE SECOND ROW EQUAL TO 1, THE THIRD ROW EQUAL TO 2, ETC. */ DO I = 0 TO (M-1); 36 1 STATEMENT # 36 0002 0003 FA 2E8F160000 CLI SS.CS: @@STACK$FRAME MOV SP, @@STACKSOFFSET 0008 всивий aaab 8BEC MOV BP,SP 000D PUSH 1F POP DS 000F STI FB C70682000000 T. 0H MOV 0016 813682000500 CMP T. 5H aaic 7603 JLE $+5H E93CP4 001E .TM P 87 37 2 DO J = \emptyset TO (N-1); ; STATEMENT # 37 0021 C70684000000 MOV J,ØH 0027 813E840004P0 CMP J,4H 002D 7E#3 JLE $+5H E92206 002F JMP 99 38 X$ROW(I).COL(J) = I; ; STATEMENT # 38 PØ32 PØ36 88068200 MOV AX,Ι CX,βAH BOPAGE MOV Ø#39 F7E9 IMUL CX 003B 003F 8B368400 D1E6 MOV SI,J SHL 0041 89C3 MOV BX,AX 0043 8B@E82@@ CX,I [BX].XROW[SI],CX MOV 89888488 MOV END; ``` ``` ; STATEMENT # 39 004B 810684000100 0051 E9D3FF J,]H ₽8 ADD JMP END; 40 2 ; STATEMENT # 40 ADD JMP 816682000100 I,]H E9B9FF /* INITIALIZE YSROW SUCH THAT THE FIRST COLUMN IS SET EQUAL TO 0, THE SECOND COLUMN EQUAL TO -1, AND THE THIRD COLUMN EQUAL TO -2. */ DO I = 0 TO (N-1); 4.1 1 ; STATEMENT # 41 005D C7068200000 MOV I.0H 0063 813E8200040P CMP I.4H 7E03 E94000 JLE JMP $+5H 006B 42 DO J = 0 TO (P-1); ; STATEMENT # 42 096E C70684009999 MOV J. OH 0074 813E84000200 CMD J,2H S+5H 007A 7EØ3 E92600 ØØ7C JMP @13 Y$ROW(I).COL(J) = -J; 43 3 ; STATEMENT # 43 MOV AX,J 997F 88868488 0083 F7D8 NEG AX AX ; 1 0085 PUSH 50 0086 88068200 MOV AX,I CX,6H A800 B90600 008D 008F F7E9 8B368400 IMUL CX SI,J MOV 0093 D1E6 SHL SI,1 0095 89C3 0097 59 MOV BX,AX POP [BX].YROW[SI],CX 9998 89884000 MOV END; ; STATEMENT # 44 009C 810684000100 00A2 E9CFFF ADD JMP R12 45 END; ; STATEMENT # 45 00A5 810682000100 ADD I.1H MMAB E985FF JM P 010 011. /* PERFORM MATRIX MULTIPLICATION 46 DO K = @ TO (P-1); ; STATEMENT # 46 елав стябвеляляля MOV K, PH CMP K.2H 20B4 813E86000200 PEBA $+5H @15 7EØ3 JLE E98CFØ DO I = Ø TO (M-1 ; STATEMENT # 47 ØCBF C70682000000 MOV 1,28 #16: PAC5 813E82AAA5AA CMP I,58 S+5H NØCB NØCD 7E03 E97200 JLE JMP 017 48 /* SET ZSROW ELEMENT TO # */ ; STATEMENT # 48 88868288 898688 ØØDØ MOV AX,I CX, SH COD4 MOV 00D7 00D9 IMUL F7E9 8B368600 PPDD DIES SHL SI,1 MOV MOV BX,AX [BX].ZROW'SI],CH SUM THE PRODUCT OF XSROW ROW TERMS AND YSROW COLUMN TERMS */ ØØDF 89C3 PREI C7805E000000 DO J = @ TO (N-1); /* 49 ; STATEMENT # 49 00E7 C70584000000 MOV J,0H PRED 813684000400 CMP J,4H $+5H JLE 7E03 E94100 819 00F5 Z$ROW(I).COL(K) + ( X$ROW(I).COL(J) * Y$ROW(J).COL(K) ); ; STATEMENT # 50 50 Z$ROW(I).COL(K) = øøF8 MOV 88068200 00FC 00FF B9PAPP F7E9 MOV IMUL CX, CAH CX SI,J MOV 0101 88368499 0105 0107 D1E6 SI,1 ; 1 PUSH 50 MOV MOV IMUL MOV 0108 8BØ684ØØ AX,J CX,6H 010C 010F 0111 B90600 F7E9 8B3E8600 CX DI,K Ø115 Ø117 D1E7 89C3 SHL DI,1 BX,AX 0119 88814000 MOV AX, [BX]. YROW [DI] 5B F7A80400 POP IMUL PUSH BX ; 1 [BX].XROW[SI] Ø11D 011E 0122 50 AX ; 1 MOV AX,I 0123 88068200 0127 F7E9 89C3 BX,AX 0129 MOV ``` ``` 58 01815600 POP ADD AX ; 1 [BX].ZROW[DI],AX END; ; STATEMENT # 51 0130 810684000100 0136 E9B4FF ADD J.1H JMP 618 019: END; ; STATEMENT # 52 0139 810582000100 013F E983FF ADD JMP I,1H 616 53 2 END; ; STATEMENT # 53 0142 810686000100 0148 E959FF K,1H 214 ADD JMP e)5: MAX = FINDSMX (@ZSROW, M, P); /* FIND MAX VALUE OF ZSROW */; STATEMENT # 54 014B B85E00 014E 50 AX,OFFSET(ZROW) AX;1 AX,6H MCV PUSH MOV 914E 914F ВВРБРР AX AX,3H AX 0152 0153 0156 50 888386 PUSH MOV 50 PUSH 0155 50 PUSH 0157 E82000 CALL 015A 89068800 MOV CALL BINSDECSASC (MAX, 0 FINDMX MAX, AX 55 MAX$ASC$ARRAY); /* CONVERT TO DECIMAL ASCII */ ; STATEMENT # 55 015E FF368800 0162 B88A00 0165 50 0166 E84C00 PUSH AX,OFFSET(MAXASCARRAY) AX ; 2 BINDECASC MOV PUSH DO I = 0 TO (SIGNED(SIZE(TEXT)) - 1); /* OUTPUT HEADER TEXT */ ; STATEMENT # 56 56 8169 C70682800088 MOV # 200: # 200: # 213E82000B00 # 213E82000B00 # 213E82000B00 # 213E82000B00 CMP I,ØBH $+5H JMP @21 57 CALL CO(TEXT(I)); ; STATEMENT # 57 017A 881E8200 017E FFB70000 0182 E80000 MOV PUSH TEXT[BX]; 1 END; 58 ; STATEMENT # 58 Ø185 810682000100 I,1H 0185 810662. 018B E9E1FF 021: A DD JMP DO I = @ TO 5; /* OUTPUT ASCII MAX VALUE */ ; STATEMENT # 59 P18E C70682000000 0194 813E82000500 019A 7EP3 JLE $+ 019C E91400 JMP 02 CALL CO(MAX$ASC$ARRAY(I)); $+5H @23 60 ; STATEMENT # 60 019F 8B1E8200 01A3 FFB78A00 01A7 E80000 MOV PUSH BX, I MAXASCARRAY(BX); ] CALL CO END; ; STATEMENT # 61 I,1H 01B0 E9E1FF JMP 022 62 END EXECUTIONSVEHICLE: ; STATEMENT # 62 MODULE INFORMATION: CODE AREA SIZE = 0225H CONSTANT AREA SIZE = 000CH VARIABLE AREA SIZE = 0008H MAXIMUM STACK SIZE = 0008H 549D 12D 144D 137 LINES READ Ø PROGRAM ERROR(S) END OF PL/M-86 COMPILATION ```