iSBC 86/12A™
SINGLE BOARD COMPUTER
HARDWARE
REFERENCE MANUAL

Order Number: 9803074-02
iSBC 86/12A™
SINGLE BOARD COMPUTER
HARDWARE
REFERENCE MANUAL

Order Number: 9803074-02
### Revision History

<table>
<thead>
<tr>
<th>REV.</th>
<th>REVISION HISTORY</th>
<th>PRINT DATE</th>
</tr>
</thead>
<tbody>
<tr>
<td>-01</td>
<td>Original Issue</td>
<td>8/79</td>
</tr>
<tr>
<td>-02</td>
<td>Product Revision: Section 3-4 and Table 2-12</td>
<td>3/81</td>
</tr>
<tr>
<td></td>
<td>Manual Revisions: Table 2-2; Table 2-4; Table 2-8; Table 2-14; Table 5-1.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Figure 2-1; Figure 5-1; Figure 5-2.</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Appendix B, C. New Appendix D.</td>
<td></td>
</tr>
</tbody>
</table>

Additional copies of this manual or other Intel literature may be obtained from:

Literature Department  
Intel Corporation  
3065 Bowers Avenue  
Santa Clara, CA 95051

The information in this document is subject to change without notice.

Intel Corporation makes no warranty of any kind with regard to this material, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. Intel Corporation assumes no responsibility for any errors that may appear in this document. Intel Corporation makes no commitment to update nor to keep current the information contained in this document.

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied.

Intel software products are copyrighted by and shall remain the property of Intel Corporation. Use, duplication or disclosure is subject to restrictions stated in Intel’s software license, or as defined in ASPR 7-104.9(a)(9).

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of Intel Corporation.

The following are trademarks of Intel Corporation and its affiliates and may be used only to identify Intel products:

- BXP  
- CREDIT  
- i  
- ICE  
- iCS  
- im  
- Intel  
- Intel  
- Internalizzazione  
- Intelice  
- iRMX  
- iSBC  
- iSBX  
- Library Manager  
- MCS  
- Megachassis  
- Micromap  
- Multibus  
- Multimodule  
- PROMPT  
- Promware  
- RX/80  
- System 2000  
- UP  
- MScope

and the combination of ICE, iCS, iRMX, iSBC, iSBX, MCS, or RMX and a numerical suffix.
This manual provides general information, installation, programming information, principles of operation, and service information for the Intel iSBC 86/12A Single Board Computer and the optional iSBC 300 Multimodule RAM and iSBC 340 Multimodule EPROM. Additional information is available in the following documents:

- *Intel MULTIBUS Interfacing*, Application Note AP-28A
# CONTENTS

## CHAPTER 1
### GENERAL INFORMATION
#### PAGE
- Introduction ........................................... 1-1
- Description ........................................... 1-1
- Optional RAM and ROM/EPROM Expansion ........ 1-3
- System Software Development ....................... 1-4
- Equipment Supplied ................................... 1-4
- Equipment Required ................................... 1-4
- Specifications ......................................... 1-4

## CHAPTER 2
### PREPARATION FOR USE
#### PAGE
- Introduction ........................................... 2-1
- Unpacking and Inspection ................................ 2-1
- Installation Considerations .............................. 2-1
- User-Furnished Components .............................. 2-1
- Power Requirement ..................................... 2-1
- Cooling Requirement .................................... 2-1
- Physical Dimensions .................................... 2-1
- Component Installation .................................. 2-1
- ROM/EPROM Chips ...................................... 2-2
- No Wait Option ......................................... 2-2
- Line Drivers and I/O Terminators ...................... 2-2
- Jumper/ Switch Configuration ........................... 2-2
- RAM Addresses (Multibus Interface) .................... 2-7
- Interface Access ....................................... 2-7
- Priority Interrupts ..................................... 2-7
- Serial I/O Port Configuration .......................... 2-7
- Parallel I/O Port Configuration ........................ 2-11
- Multibus Interface Configuration ....................... 2-11
- Signal Characteristics .................................. 2-11
- Multibus Interface Arbitration ......................... 2-22
- Common Bus Request .................................... 2-22
- Any Request ............................................ 2-22
- Jumper Configurations .................................. 2-23
- Serial Priority Resolution ............................... 2-23
- Parallel Priority Resolution ............................ 2-23
- Power Fail/ Memory Protect Configuration .......... 2-24
- Parallel I/O Cabling ................................... 2-25
- Serial I/O Cabling ...................................... 2-26
- Board Installation ...................................... 2-27

## CHAPTER 3
### PROGRAMMING INFORMATION
#### PAGE
- Introduction ........................................... 3-1
- Failsafe Timer ......................................... 3-1
- Memory Addressing ..................................... 3-1
- CPU Access ............................................. 3-2
- Multibus Interface Access ............................... 3-2
- I/O Addressing ......................................... 3-3
- System Initialization .................................... 3-4
- 8251A USART Programming ............................. 3-5
- Mode Instruction Format ................................ 3-5
- Sync Characters ........................................ 3-5
- Command Instruction Format ......................... 3-6
- Reset .................................................... 3-6
- Addressing ............................................. 3-6
- Initialization .......................................... 3-7
- Operation ............................................... 3-8
- Data Input/ Output ...................................... 3-8
- Status Read ............................................. 3-9
- 8253 PIT Programming .................................... 3-9
- Mode Control Word and Count ......................... 3-9
- Addressing ............................................. 3-13
- Initialization .......................................... 3-13
- Operation ............................................... 3-13
- Counter Read .......................................... 3-13
- Clock Frequency/ Divide Ratio Selection ............. 3-14
- Rate Generator/ Interval Timer ......................... 3-15
- Interrupt Timer ........................................ 3-16
- 8255A PPI Programming .................................. 3-16
- Control Word Format .................................... 3-17
- Addressing ............................................. 3-17
- Initialization .......................................... 3-17
- Operation ............................................... 3-17
- Read Operation ........................................ 3-17
- Write Operation ........................................ 3-17
- 8259A PIC Programming .................................. 3-17
- Interrupt Priority Modes ............................... 3-18
- Nested Mode ............................................ 3-18
- Fully Nested Mode ..................................... 3-19
- Automatic Rotating Mode ............................... 3-19
- Specific Rotating Mode ................................ 3-19
- Special Mask Mode ..................................... 3-19
- Poll Mode .............................................. 3-19
- Status Read ............................................. 3-19
- Initialization Command Words ......................... 3-19
- Operation Command Words ............................... 3-21
- Addressing ............................................. 3-21
- Initialization .......................................... 3-21
- Operation ............................................... 3-21
- Hardware Interrupts ..................................... 3-26
- Non- Maskable Interrupt (NMI) ......................... 3-26
- Maskable Interrupt (INTR) .............................. 3-27
- Master PIC Byte Identifier ............................. 3-27
- Slave PIC Byte Identifier .............................. 3-27

## CHAPTER 4
### PRINCIPLES OF OPERATION
#### PAGE
- Introduction ........................................... 4-1
- Functional Description .................................. 4-1
- Clock Circuits .......................................... 4-1
- Central Processor Unit .................................. 4-1
<table>
<thead>
<tr>
<th>Section</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>Interval Timer</td>
<td>4-1</td>
</tr>
<tr>
<td>Serial I/O</td>
<td>4-2</td>
</tr>
<tr>
<td>Parallel I/O</td>
<td>4-2</td>
</tr>
<tr>
<td>Interrupt Controller</td>
<td>4-2</td>
</tr>
<tr>
<td>ROM/EPROM Configuration</td>
<td>4-2</td>
</tr>
<tr>
<td>RAM Configuration</td>
<td>4-2</td>
</tr>
<tr>
<td>Bus Structure</td>
<td>4-3</td>
</tr>
<tr>
<td>Multibus Interface</td>
<td>4-4</td>
</tr>
<tr>
<td>Circuit Analysis</td>
<td>4-4</td>
</tr>
<tr>
<td>Initialization</td>
<td>4-4</td>
</tr>
<tr>
<td>Clock Circuits</td>
<td>4-4</td>
</tr>
<tr>
<td>8086 CPU Timing</td>
<td>4-4</td>
</tr>
<tr>
<td>Basic Timing</td>
<td>4-4</td>
</tr>
<tr>
<td>Bus Timing</td>
<td>4-5</td>
</tr>
<tr>
<td>Address Bus</td>
<td>4-8</td>
</tr>
<tr>
<td>Data Bus</td>
<td>4-8</td>
</tr>
<tr>
<td>Bus Time Out</td>
<td>4-8</td>
</tr>
<tr>
<td>Internal Control Signals</td>
<td>4-8</td>
</tr>
<tr>
<td>Dual Port Control Logic</td>
<td>4-8</td>
</tr>
<tr>
<td>Multibus Interface Access Timing</td>
<td>4-8</td>
</tr>
<tr>
<td>CPU Access Timing</td>
<td>4-10</td>
</tr>
<tr>
<td>Multibus Interface Arbitration</td>
<td>4-10</td>
</tr>
<tr>
<td>I/O Operation</td>
<td>4-12</td>
</tr>
<tr>
<td>On-Board I/O Operation</td>
<td>4-12</td>
</tr>
<tr>
<td>System I/O Operation</td>
<td>4-12</td>
</tr>
<tr>
<td>ROM/EPROM Operation</td>
<td>4-12</td>
</tr>
<tr>
<td>ROM/EPROM Operation with iSBC 340 Multimodule EPROM</td>
<td>4-13</td>
</tr>
<tr>
<td>RAM Operation</td>
<td>4-13</td>
</tr>
<tr>
<td>RAM Controller</td>
<td>4-13</td>
</tr>
<tr>
<td>RAM Chips</td>
<td>4-14</td>
</tr>
<tr>
<td>RAM Controller with iSBC 300</td>
<td>4-14</td>
</tr>
<tr>
<td>Multimodule RAM</td>
<td>4-14</td>
</tr>
<tr>
<td>RAM Chips with iSBC 300</td>
<td>4-14</td>
</tr>
<tr>
<td>Multimodule RAM</td>
<td>4-14</td>
</tr>
<tr>
<td>On-Board Read/Write Operation</td>
<td>4-14</td>
</tr>
<tr>
<td>Bus Read/Write Operation</td>
<td>4-15</td>
</tr>
<tr>
<td>Byte Operation</td>
<td>4-15</td>
</tr>
<tr>
<td>Interrupt Operation</td>
<td>4-15</td>
</tr>
<tr>
<td>NBV Interrupt</td>
<td>4-15</td>
</tr>
<tr>
<td>BV Interrupt</td>
<td>4-16</td>
</tr>
</tbody>
</table>

**CHAPTER 5**

**SERVICE INFORMATION**

- Introduction ........................................... 5-1
- Replaceable Parts .................................... 5-1
- Service Diagrams ..................................... 5-1
- Service and Repair Assistance .................... 5-1

**APPENDIX A**

**TELETYPEWRITER MODIFICATIONS**

**APPENDIX B**

iSBC 300 MULTIMODULE RAM AND iSBC 340 MULTIMODULE EPROM

**APPENDIX C**

CUSTOM PROGRAMMED PROMS

**APPENDIX D**

iSBC 303 PARITY GENERATOR BOARD
<table>
<thead>
<tr>
<th>TABLE</th>
<th>TITLE</th>
<th>PAGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-1</td>
<td>Specifications ..................</td>
<td>1-4</td>
</tr>
<tr>
<td>2-1</td>
<td>User-Furnished and Installed Components</td>
<td>2-2</td>
</tr>
<tr>
<td>2-2</td>
<td>User-Furnished Connector Details</td>
<td>2-4</td>
</tr>
<tr>
<td>2-3</td>
<td>Line Driver and I/O Terminator Locations</td>
<td>2-5</td>
</tr>
<tr>
<td>2-4</td>
<td>Jumper and Switch Selectable Options</td>
<td>2-5</td>
</tr>
<tr>
<td>2-5</td>
<td>Priority Interrupt Jumper Matrix</td>
<td>2-10</td>
</tr>
<tr>
<td>2-6</td>
<td>Serial I/O Connector J2 Pin Assignments Vs Configuration Jumpers</td>
<td>2-11</td>
</tr>
<tr>
<td>2-7</td>
<td>Parallel I/O Port Configuration Jumpers</td>
<td>2-12</td>
</tr>
<tr>
<td>2-8</td>
<td>Multibus Interface Connector P1 Pin Assignments</td>
<td>2-15</td>
</tr>
<tr>
<td>2-9</td>
<td>Multibus Interface Signal Functions</td>
<td>2-16</td>
</tr>
<tr>
<td>2-10</td>
<td>iSBC 86/12A Board DC Characteristics</td>
<td>2-17</td>
</tr>
<tr>
<td>2-11</td>
<td>iSBC 86/12A Board AC Characteristics (Master Mode)</td>
<td>2-19</td>
</tr>
<tr>
<td>2-12</td>
<td>iSBC 86/12A Board AC Characteristics (Slave Mode)</td>
<td>2-19</td>
</tr>
<tr>
<td>2-13</td>
<td>8289 Bus Arbiter Jumper Configurations</td>
<td>2-22</td>
</tr>
<tr>
<td>2-14</td>
<td>Auxiliary Connector P2 Pin Assignments</td>
<td>2-25</td>
</tr>
<tr>
<td>2-15</td>
<td>Auxiliary Signal (Connector P2) DC Characteristics</td>
<td>2-26</td>
</tr>
<tr>
<td>2-16</td>
<td>Parallel I/O Connector J1 Pin Assignments</td>
<td>2-26</td>
</tr>
<tr>
<td>2-17</td>
<td>Parallel I/O Signal (Connector J1) DC Characteristics</td>
<td>2-27</td>
</tr>
<tr>
<td>2-18</td>
<td>Connector J2 Vs RS232C Pin Correspondence</td>
<td>2-27</td>
</tr>
<tr>
<td>3-1</td>
<td>Typical Dual Port Access Subroutine</td>
<td>3-2</td>
</tr>
<tr>
<td>3-2</td>
<td>On-Board Memory Addresses (CPU Access)</td>
<td>3-3</td>
</tr>
<tr>
<td>3-3</td>
<td>I/O Address Assignments</td>
<td>3-4</td>
</tr>
<tr>
<td>3-4</td>
<td>Typical USART Mode or Command Instruction Subroutine</td>
<td>3-8</td>
</tr>
<tr>
<td>3-5</td>
<td>Typical USART Data Character Read Subroutine</td>
<td>3-9</td>
</tr>
<tr>
<td>3-6</td>
<td>Typical USART Data Character Write Subroutine</td>
<td>3-9</td>
</tr>
<tr>
<td>3-7</td>
<td>Typical USART Status Read Subroutine</td>
<td>3-10</td>
</tr>
<tr>
<td>3-8</td>
<td>PIT Counter Operation Vs Gate Inputs</td>
<td>3-13</td>
</tr>
<tr>
<td>3-9</td>
<td>Typical PIT Control Word Subroutine</td>
<td>3-14</td>
</tr>
<tr>
<td>3-10</td>
<td>Typical PIT Count Value Load Subroutine</td>
<td>3-14</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>TABLE</th>
<th>TITLE</th>
<th>PAGE</th>
</tr>
</thead>
<tbody>
<tr>
<td>3-11</td>
<td>Typical PIT Counter Read Subroutine</td>
<td>3-15</td>
</tr>
<tr>
<td>3-12</td>
<td>PIT Count Value Vs Rate Multiplier for Each Baud Rate</td>
<td>3-16</td>
</tr>
<tr>
<td>3-13</td>
<td>PIT Rate Generator Frequencies and Timer Intervals</td>
<td>3-16</td>
</tr>
<tr>
<td>3-14</td>
<td>PIT Time Intervals Vs Timer Counts</td>
<td>3-16</td>
</tr>
<tr>
<td>3-15</td>
<td>Typical PPI Initialization Subroutine</td>
<td>3-18</td>
</tr>
<tr>
<td>3-16</td>
<td>Typical PPI Port Read Subroutine</td>
<td>3-18</td>
</tr>
<tr>
<td>3-17</td>
<td>Typical PPI Port Write Subroutine</td>
<td>3-18</td>
</tr>
<tr>
<td>3-18</td>
<td>Interrupt Vector Byte</td>
<td>3-20</td>
</tr>
<tr>
<td>3-19</td>
<td>Typical PIC Initialization Subroutine (NBV Mode)</td>
<td>3-23</td>
</tr>
<tr>
<td>3-20</td>
<td>Typical Master PIC Initialization Subroutine (BV Mode)</td>
<td>3-23</td>
</tr>
<tr>
<td>3-21</td>
<td>Typical Slave PIC Initialization Subroutine (BV Mode)</td>
<td>3-23</td>
</tr>
<tr>
<td>3-22</td>
<td>PIC Operation Procedures</td>
<td>3-24</td>
</tr>
<tr>
<td>3-23</td>
<td>Typical PIC Interrupt Request Register Read Subroutine</td>
<td>3-26</td>
</tr>
<tr>
<td>3-24</td>
<td>Typical PIC In-Service Register Read Subroutine</td>
<td>3-26</td>
</tr>
<tr>
<td>3-25</td>
<td>Typical PIC Set Mask Register Subroutine</td>
<td>3-26</td>
</tr>
<tr>
<td>3-26</td>
<td>Typical PIC Mask Register Read Subroutine</td>
<td>3-27</td>
</tr>
<tr>
<td>3-27</td>
<td>Typical PIC End-Of-Interrupt Command Subroutine</td>
<td>3-27</td>
</tr>
<tr>
<td>4-1</td>
<td>ROM/EPROM Chip Selection</td>
<td>4-14</td>
</tr>
<tr>
<td>4-1</td>
<td>Replaceable Parts</td>
<td>5-1</td>
</tr>
<tr>
<td>5-1</td>
<td>List of Manufacturer’s Codes</td>
<td>5-3</td>
</tr>
<tr>
<td>C-1</td>
<td>RAM Base Address</td>
<td>C-1</td>
</tr>
<tr>
<td>C-2</td>
<td>RAM Size</td>
<td>C-2</td>
</tr>
<tr>
<td>C-3</td>
<td>RAM Size - PROM Page</td>
<td>C-2</td>
</tr>
<tr>
<td>C-4</td>
<td>Translator PROM Contents for Intel Part Number 9100134</td>
<td>C-3</td>
</tr>
<tr>
<td>C-5</td>
<td>Translator PROM Contents for Intel Part Number 9100212</td>
<td>C-4</td>
</tr>
<tr>
<td>C-6</td>
<td>Memory Chip Select PROM Outputs</td>
<td>C-6</td>
</tr>
<tr>
<td>C-7</td>
<td>EPROM Select Coding</td>
<td>C-6</td>
</tr>
<tr>
<td>C-8</td>
<td>Chip Select PROM Contents for Intel Part Number 9100129</td>
<td>C-7</td>
</tr>
<tr>
<td>C-9</td>
<td>Chip Select PROM Contents for Intel Part Number 9100123</td>
<td>C-8</td>
</tr>
<tr>
<td>C-10</td>
<td>User Coded Chip Select PROM Contents</td>
<td>C-9</td>
</tr>
<tr>
<td>FIGURE</td>
<td>TITLE</td>
<td>PAGE</td>
</tr>
<tr>
<td>--------</td>
<td>-------------------------------------------</td>
<td>------</td>
</tr>
<tr>
<td>1-1</td>
<td>iSBC 86/12A Single Board</td>
<td>1-1</td>
</tr>
<tr>
<td></td>
<td>Computer</td>
<td></td>
</tr>
<tr>
<td>2-1</td>
<td>Dual Port RAM Address Configuration</td>
<td>2-8</td>
</tr>
<tr>
<td></td>
<td>(Multibus Interface Access)</td>
<td></td>
</tr>
<tr>
<td>2-2</td>
<td>Simplified Master/Slave PIC</td>
<td>2-10</td>
</tr>
<tr>
<td></td>
<td>Interconnect Example</td>
<td></td>
</tr>
<tr>
<td>2-3</td>
<td>Bus Exchange Timing (Master Mode)</td>
<td>2-20</td>
</tr>
<tr>
<td>2-4</td>
<td>Bus Exchange Timing (Slave Mode)</td>
<td>2-21</td>
</tr>
<tr>
<td>2-5</td>
<td>Serial Priority Resolution Scheme</td>
<td>2-23</td>
</tr>
<tr>
<td>2-6</td>
<td>Parallel Priority Resolution Scheme</td>
<td>2-24</td>
</tr>
<tr>
<td>3-1</td>
<td>Dual Port RAM Addressing (Multibus</td>
<td>3-3</td>
</tr>
<tr>
<td></td>
<td>Interface Access)</td>
<td></td>
</tr>
<tr>
<td>3-2</td>
<td>USART Synchronous Mode Instruction</td>
<td>3-5</td>
</tr>
<tr>
<td></td>
<td>Word Format</td>
<td></td>
</tr>
<tr>
<td>3-3</td>
<td>USART Synchronous Mode</td>
<td>3-5</td>
</tr>
<tr>
<td></td>
<td>Transmission Format</td>
<td></td>
</tr>
<tr>
<td>3-4</td>
<td>USART Asynchronous Mode Instruction</td>
<td>3-6</td>
</tr>
<tr>
<td></td>
<td>Word Format</td>
<td></td>
</tr>
<tr>
<td>3-5</td>
<td>USART Asynchronous Mode</td>
<td>3-6</td>
</tr>
<tr>
<td></td>
<td>Transmission Format</td>
<td></td>
</tr>
<tr>
<td>3-6</td>
<td>USART Command Instruction Word</td>
<td>3-6</td>
</tr>
<tr>
<td></td>
<td>Format</td>
<td></td>
</tr>
<tr>
<td>3-7</td>
<td>Typical USART Initialization and</td>
<td>3-7</td>
</tr>
<tr>
<td></td>
<td>I/O Data Sequence</td>
<td></td>
</tr>
<tr>
<td>3-8</td>
<td>USART Status Read Format</td>
<td>3-10</td>
</tr>
<tr>
<td>3-9</td>
<td>PIT Mode Control Word Format</td>
<td>3-11</td>
</tr>
<tr>
<td>3-10</td>
<td>PIT Programming Sequence Examples</td>
<td>3-12</td>
</tr>
<tr>
<td>3-11</td>
<td>PIT Counter Register Latch Control Word</td>
<td>3-15</td>
</tr>
<tr>
<td></td>
<td>Format</td>
<td></td>
</tr>
<tr>
<td>3-12</td>
<td>PPI Control Word Format</td>
<td>3-17</td>
</tr>
<tr>
<td>3-13</td>
<td>PPI Port C Bit Set/Reset Control Word</td>
<td>3-18</td>
</tr>
<tr>
<td>3-14</td>
<td>PIC Initialization Command</td>
<td>3-20</td>
</tr>
<tr>
<td></td>
<td>Word Formats</td>
<td></td>
</tr>
<tr>
<td>3-15</td>
<td>PIC Operation Control Word</td>
<td>3-22</td>
</tr>
<tr>
<td></td>
<td>Formats</td>
<td></td>
</tr>
<tr>
<td>4-1</td>
<td>iSBC 86/12A Input/Output and Interrupt</td>
<td>4-17</td>
</tr>
<tr>
<td></td>
<td>Simplified Logic Diagram</td>
<td></td>
</tr>
<tr>
<td>4-2</td>
<td>iSBC 86/12A ROM/EPROM and Dual Port</td>
<td>4-19</td>
</tr>
<tr>
<td></td>
<td>RAM Simplified Logic Diagram</td>
<td></td>
</tr>
<tr>
<td>4-3</td>
<td>Internal Bus Structure</td>
<td>4-3</td>
</tr>
<tr>
<td>4-4</td>
<td>CPU Read Timing</td>
<td>4-5</td>
</tr>
<tr>
<td>4-5</td>
<td>CPU Write Timing</td>
<td>4-6</td>
</tr>
<tr>
<td>4-6</td>
<td>CPU Interrupt Acknowledge Cycle</td>
<td>4-7</td>
</tr>
<tr>
<td></td>
<td>Timing</td>
<td></td>
</tr>
<tr>
<td>4-7</td>
<td>Dual Port Control Multibus Interface</td>
<td>4-9</td>
</tr>
<tr>
<td></td>
<td>Access</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Timing with CPU Lockout</td>
<td></td>
</tr>
<tr>
<td>4-8</td>
<td>Dual Port Control CPU Access Timing</td>
<td>4-11</td>
</tr>
<tr>
<td></td>
<td>with Multibus Interface Lockout</td>
<td></td>
</tr>
<tr>
<td>5-1</td>
<td>iSBC 86/12A Parts Location Diagram</td>
<td>5-5</td>
</tr>
<tr>
<td>5-2</td>
<td>iSBC 86/12A Schematic Diagram</td>
<td>5-7</td>
</tr>
<tr>
<td>A-1</td>
<td>Teletype Component Layout</td>
<td>A-2</td>
</tr>
<tr>
<td>A-2</td>
<td>Current Source Resistor</td>
<td>A-2</td>
</tr>
<tr>
<td>A-3</td>
<td>Terminal Block</td>
<td>A-2</td>
</tr>
<tr>
<td>A-4</td>
<td>Teletypewriter Modifications</td>
<td>A-3</td>
</tr>
<tr>
<td>A-5</td>
<td>Relay Circuit</td>
<td>A-3</td>
</tr>
<tr>
<td>A-6</td>
<td>Mode Switch</td>
<td>A-3</td>
</tr>
<tr>
<td>A-7</td>
<td>Distributor Trip Magnet</td>
<td>A-4</td>
</tr>
<tr>
<td>A-8</td>
<td>TTY Adapter Cabling</td>
<td>A-4</td>
</tr>
<tr>
<td>B-1</td>
<td>iSBC 300 Multimodule RAM Orientation</td>
<td>B-1</td>
</tr>
<tr>
<td>B-2</td>
<td>iSBC 340 Multimodule EPROM</td>
<td>B-2</td>
</tr>
<tr>
<td></td>
<td>Orientation</td>
<td>B-3</td>
</tr>
<tr>
<td>B-3</td>
<td>iSBC 300 Multimodule RAM Parts Location</td>
<td>B-5</td>
</tr>
<tr>
<td>B-4</td>
<td>iSBC Multimodule RAM Schematic</td>
<td>B-7</td>
</tr>
<tr>
<td>B-5</td>
<td>iSBC 340 Multimodule EPROM Parts Location</td>
<td>B-9</td>
</tr>
<tr>
<td>B-6</td>
<td>iSBC 340 Multimodule EPROM Schematic</td>
<td>B-11</td>
</tr>
</tbody>
</table>
1-1. INTRODUCTION

The iSBC 86/12A Single Board Computer, which is a member of Intel's complete line of 8- and 16-bit single board computer products, is a complete computer system on a single printed-circuit assembly. The iSBC 86/12A 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 interface control logic, and bus expansion drivers for interface with other Multibus interface-compatible expansion boards. Also included is dual port control logic to allow the iSBC 86/12A board to act as a slave RAM device to other Multibus interface masters in the system. Provision is made for user installation of up to 16K bytes of read only memory.

1-2. DESCRIPTION

The iSBC 86/12A Single Board Computer (figure 1-1) is controlled by an Intel 8086 16-Bit Microprocessor (CPU). The 8086 CPU includes four 16-bit general purpose registers that may also be addressed as eight 8-bit registers. In addition, the CPU contains two 16-bit pointer registers and two 16-bit index registers. Four 16-bit segment registers allow extended addressing to a full megabyte of memory. The CPU instruction set supports a wide range of addressing modes and data transfer operations, signed and unsigned 8-bit and 16-bit arithmetic including hardware multiply and divide, and logical and string operations. The CPU architecture features dynamic code relocation, reentrant code, and instruction lookahead.

The iSBC 86/12A board has an internal bus for all on-board memory and I/O operations and accesses the system bus (Multibus interface) for all external memory and I/O operations. Hence, local (on-board) operations do not involve the Multibus interface making the Multibus interface available for true parallel processing when several bus masters (e.g., DMA devices and other single board computers) are used in a multimaster scheme.

Figure 1-1. iSBC 86/12A™ Single Board Computer
Dual port control logic is included to interface the dynamic RAM with the Multibus interface so that the iSBC 86/12A board can function as a slave RAM device when not in control of the Multibus interface. The CPU has priority when accessing on-board RAM. After the CPU completes its read or write operation, the controlling bus master is allowed to access RAM and complete its operation. Where both the CPU and the controlling bus master have the need to write or read several bytes or words to or from on-board RAM, their operations are interleaved. For CPU access, the on-board RAM addresses are assigned from the bottom up of the 1-megabyte address space; i.e., 00000-07FFF. The slave RAM address decode logic includes jumpers and switches to allow positioning the on-board RAM into any 128K segment of the 1-megabyte system address space.

The slave RAM can be configured to allow either 8K, 16K, 24K, or 32K access by another bus master. If the iSBC 300 Multimodule RAM option is installed the memory increments are 16K, 32K, 48K, or 64K. Thus, the RAM can be configured to allow other bus masters to access a segment of the on-board RAM and still reserve another segment strictly for on-board use. The addressing scheme accommodates both 16-bit and 20-bit addressing.

Four IC sockets are included to accommodate up to 16K bytes of user-installed read only memory. Configuration jumpers allow read only memory to be installed in 2K, 4K, or 8K increments.

The iSBC 86/12A board includes 24 programmable parallel I/O lines implemented by means of an Intel 8255A Programmable Peripheral Interface (PPI). The system software is used to configure the I/O lines in any combination of unidirectional input/output and bidirectional ports. The I/O interface may be customized to meet specific peripheral requirements and, in order to take full advantage of the large number of possible I/O configurations, IC sockets are provided for interchangeable I/O line drivers and terminators. Hence, the flexibility of the parallel 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 (J2) that mates with flat or round cable.

The RS232C compatible serial I/O port is controlled and interfaced by an Intel 8251A USART (Universal Synchronous/Asynchronous Receiver/Transmitter) chip. The USART is individually programmable for operation in most synchronous or asynchronous serial data transmission formats (including IBM Bi-Sync).

In the synchronous mode the following are programmable:

a. Character length,
b. Sync character (or characters), and
c. Parity.

In the asynchronous mode the following are programmable:

a. Character length,
b. Baud rate factor (clock divide ratios of 1, 16, or 64),
c. Stop bits, and
d. Parity.

In both the synchronous and asynchronous modes, the serial I/O port features half- or full-duplex, double buffered transmit and receive capability. In addition, USART error detection circuits can check for parity, overrun, and framing errors. The USART transmit and receive clock rates are supplied by a programmable baud rate/time generator. These clocks may optionally be supplied from an external source. The RS232C command lines, serial data lines, and signal ground lines are brought out to a 50-pin edge connector (J2) that mates with flat or round cable.

Three independent, fully programmable 16-bit interval timer/event counters are provided by an Intel 8253 Programmable Interval Timer (PIT). Each counter is capable of operating in either BCD or binary modes; two of these 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 may be independently routed to the 8259A Programmable Interrupt Controller (PIC). The gate/trigger inputs of the two counters may be routed to I/O terminators associated with the 8255A PPI or as input connections from the 8255A PPI. The third counter is used as a programmable baud rate generator for the serial I/O port. In utilizing the iSBC 86/12A board, the systems designer simply configures, via software, each counter independently to meet system requirements. Whenever a given time delay or count is needed, software commands to the 8253 PIT select the desired function. The contents of each counter may be read at any time during system operation with simple operations for event counting applications, and special commands are included so that the contents of each counter can be read "on the fly".

The iSBC 86/12A board provides vectoring for bus vectored (BV) and non-bus vectored (NBV) inter-
rupts. An on-board Intel 8259A Programmable Interrupt Controller (PIC) handles up to eight NBV interrupts. By using external PIC's slaved to the on-board PIC (master), the interrupt structure can be expanded to handle and resolve the priority of up to 64 BV sources.

The PIC, which can be programmed to respond to edge-sensitive or level-sensitive inputs, treats each true input signal condition as an interrupt request. After resolving the interrupt priority, the PIC issues a single interrupt request to the CPU. Interrupt priorities are independently programmable under software control. The programmable interrupt priority modes are:

a. Nested Priority. Each interrupt request has a fixed priority: input 0 is highest, input 7 is lowest.

b. Fully Nested Priority. This mode is the same as nested mode, except that when a slave PIC is being serviced, it is not locked out from the master PIC priority logic and when exiting from the interrupt service routine, the software must check for pending interrupts from the slave PIC just serviced.

c. Auto-Rotating Priority. Each interrupt request has equal priority. Each level, after receiving service, becomes the lowest priority level until the next interrupt occurs.

d. Specific priority. Software assigns lowest priority. Priority of all other levels is in numerical sequence based on lowest priority.

e. Special Mask. Interrupts at the level being serviced are inhibited, but all other levels of interrupts (higher and lower) are enabled.

f. Poll. The CPU internal interrupt enable is disabled. Interrupt service is achieved by programmer initiative using a Poll command.

The CPU includes a non-maskable interrupt (NMI) and a maskable interrupt (INTR). The NMI interrupt is intended to be used for catastrophic events such as power outages that require immediate action of the CPU. The INTR interrupt is driven by the 8259A PIC which, on demand, provides an 8-bit identifier of the interrupting source. The CPU multiplies the 8-bit identifier by four to derive a pointer to the service routine for the interrupting device.

Interrupt requests may originate from 18 sources without the necessity of external hardware. Two jumper-selectable interrupt requests can be automatically generated by the Programmable Peripheral Interface (PPI) when a byte of information is ready to be transferred to the 8086 CPU (i.e., input buffer is full) or a byte of information has been transferred to a peripheral device (i.e., output buffer is empty). Two jumper-selectable interrupt requests can be automatically generated by the USART when a character is ready to be transferred to the 8086 CPU (i.e., receive channel buffer is full) or when a character is ready to be transmitted (i.e., transmit channel data buffer is empty). A jumper-selectable interrupt request can be generated by two of the programmable counters and eight additional interrupt request lines are available to the user for direct interfaces to user-designated peripheral devices via the Multibus interface. One interrupt request line may be jumper routed directly from a peripheral via the parallel I/O driver/terminator section and one power fail interrupt may be input via auxiliary connector P2.

The iSBC 86/12A board includes the resources for supporting a variety of OEM system requirements. For those applications requiring additional processing capacity and the benefits of multiprocessing (i.e., several CPU's and/or controllers logically sharing systems tasks with communication over the Multibus interface), the iSBC 86/12A board provides full bus arbitration control logic. This control logic allows up to three bus masters (e.g., combination of iSBC 86/12A board, DMA controller, diskette controller, etc.) to share the Multibus interface in serial (daisy-chain) fashion or up to 16 bus masters to share the Multibus interface using an external parallel priority resolving network.

The Multibus interface arbitration logic operates synchronously with the bus clock, which is derived either from the iSBC 86/12A board or can be optionally generated by some other bus master. Data, however, is transferred via a handshake between the controlling master and the addressed slave module. This arrangement allows different speed controllers to share resources on the same bus, and transfers via the bus proceed asynchronously. Thus, the transfer speed is dependent on transmitting and receiving devices only. This design prevents slower 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.

1-3. OPTIONAL RAM AND ROM/EPROM EXPANSION

Adding the optional iSBC 300 Multimodule RAM to the iSBC 86/12A board, allows the on-board RAM to be expanded by 32K (for an on-board total of 64K). If the optional iSBC 340 Multimodule EPROM is installed on the iSBC 86/12A board, the amount of
on-board ROM/EPROM can be expanded by 16k (for an on-board total of 32k). See appendix C for other EPROM expansion options. Appendix C also lists the PROM maps for the custom programmed PROMs.

1-4. SYSTEM SOFTWARE DEVELOPMENT

The development cycle of isBC 86/12A Single Board Computer based products may be significantly reduced using an Intel Intellec Microcomputer Development System with the optional MDS-311 8086 Software Development package.

The MDS-311 8086 Software Development package includes Intel’s high level programming language, PL/M 86. PL/M 86 provides the capability to program in a natural, algorithmic language and eliminates the need to manage register usage or allocate memory. PL/M 86 programs can be written in a much shorter time than assembly language programs for a given application.

1-5. EQUIPMENT SUPPLIED

The following are supplied with the isBC 86/12A Single Board Computer:

a. Schematic diagram, dwg. no. 143237
b. Assembly drawing, dwg no. 1003052

1-6. EQUIPMENT REQUIRED

Because the isBC 86/12A board is designed to satisfy a variety of applications, the user must purchase and install only those components required to satisfy his particular needs. A list of components required to configure all the intended applications of the isBC 86/12A board is provided in table 2-1.

1-7. SPECIFICATIONS

Specifications of the isBC 86/12A Single Board Computer are listed in table 1-1.

<table>
<thead>
<tr>
<th>Table 1-1. Specifications</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>WORD SIZE</strong></td>
</tr>
<tr>
<td>Instruction:</td>
</tr>
<tr>
<td>Data:</td>
</tr>
<tr>
<td><strong>INSTRUCTION CYCLE TIME:</strong></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td><strong>MEMORY CAPACITY</strong></td>
</tr>
<tr>
<td>On-board ROM/EPROM:</td>
</tr>
<tr>
<td>On-board Dynamic RAM:</td>
</tr>
<tr>
<td>Off-board Expansion:</td>
</tr>
<tr>
<td><strong>MEMORY ADDRESSING</strong></td>
</tr>
<tr>
<td>On-board ROM/EPROM:</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td>On-board RAM:</td>
</tr>
<tr>
<td>(CPU Access)</td>
</tr>
</tbody>
</table>
Table 1-1. Specifications (Continued)

On-Board RAM:  
(Multibus Interface Access)  
Jumpers and switches allow board to act as slave RAM device for access by another bus master. Addresses may be set within any 8K boundary of any 128K segment of the 1-megabyte system address space. Access is selectable for 8K, 16K, 24K, or 32K bytes.

Slave RAM Access:  
Average; 1.5 microseconds

SERIAL COMMUNICATIONS  
Synchronous:  
5-, 6-, 7-, or 8-bit characters.  
Internal; 1 or 2 sync characters.  
Automatic sync insertion.

Asynchronous:  
5-, 6-, 7-, or 8-bit characters.  
Break character generation.  
1, 1/8, or 2 stop bits.  
False start bit detection.

Sample Baud Rate:  

<table>
<thead>
<tr>
<th>Frequency¹ (kHz, Software Selectable)</th>
<th>Baud Rate (Hz)² Synchronous</th>
<th>Asynchronous</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>+16</td>
<td>+64</td>
</tr>
<tr>
<td>153.6</td>
<td>—</td>
<td>9600 2400</td>
</tr>
<tr>
<td>76.8</td>
<td>—</td>
<td>4800 1200</td>
</tr>
<tr>
<td>38.4</td>
<td>38400 2400</td>
<td>600 150</td>
</tr>
<tr>
<td>19.2</td>
<td>19200 1200</td>
<td>300</td>
</tr>
<tr>
<td>9.6</td>
<td>9600 600</td>
<td>150</td>
</tr>
<tr>
<td>4.8</td>
<td>4800 300</td>
<td>75</td>
</tr>
<tr>
<td>2.4</td>
<td>2400 150</td>
<td>—</td>
</tr>
<tr>
<td>1.76</td>
<td>1760 110</td>
<td>—</td>
</tr>
</tbody>
</table>

Notes:

1. Frequency selected by I/O writes of appropriate 16-bit frequency factor to Baud Rate Register.

2. Baud rates shown here are only a sample subset of possible software-programmable rates available. Any frequency from 18.75 Hz to 613.5 kHz may be generated utilizing on-board crystal oscillator and 16-bit Programmable Interval Timer (used here as frequency divider).

INTERVAL TIMER AND  
BAUD RATE GENERATOR  
Input Frequency (selectable):  
2.46 MHz ±0.1% (0.41 µsec period nominal),  
1.23 MHz ±0.1% (0.82 µsec period nominal), and  
153.6 kHz ±0.1% (6.5 µsec period nominal).

Output Frequencies:

<table>
<thead>
<tr>
<th>Function</th>
<th>Single Timer</th>
<th>Dual Timers (Two Timers Cascaded)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min.</td>
<td>Max.</td>
</tr>
<tr>
<td>Real-Time Interrupt Interval</td>
<td>1.63 µsec</td>
<td>427.1 msec</td>
</tr>
<tr>
<td>Rate Generator (Frequency)</td>
<td>2.342 Hz</td>
<td>613.5 kHz</td>
</tr>
</tbody>
</table>
### Table 1-1. Specifications (Continued)

<table>
<thead>
<tr>
<th><strong>8086 CPU CLOCK</strong></th>
<th>5.0 MHz ±0.1%.</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>I/O ADDRESSING:</strong></td>
<td>All communication to Parallel I/O and Serial I/O Ports, Timer, and Interrupt Controller is via read and write commands from on-board 8086 CPU. Refer to table 3–2.</td>
</tr>
<tr>
<td><strong>INTERFACE COMPATIBILITY</strong></td>
<td><strong>Serial I/O:</strong> EIA Standard RS232C signals provided and supported: Clear to Send Receive Data Data Set Ready Secondary Receive Data* Data Terminal Ready Secondary CTS* Request to Send Transmit Clock* Receive Clock Transmit Data *Can support only one</td>
</tr>
<tr>
<td><strong>Parallel I/O:</strong></td>
<td>24 programmable lines (8 lines per port); one port includes bidirectional bus driver. IC sockets included for user installation of line drivers and/or I/O terminators as required for interface ports. Refer to table 2-1.</td>
</tr>
<tr>
<td><strong>INTERRUPTS:</strong></td>
<td>8086 CPU includes non-maskable interrupt (NMI) and maskable interrupt (INTR). NMI interrupt is provided for catastrophic event such as power failure; NMI vector address is 00008. INTR interrupt is driven by on-board 8259A PIC, which provides 8-bit identifier of interrupting device to CPU. CPU multiplies identifier by four to derive vector address. Jumpers select interrupts from 18 sources without necessity of external hardware. PIC may be programmed to accommodate edge-sensitive or level-sensitive inputs.</td>
</tr>
<tr>
<td><strong>COMPATIBLE CONNECTORS/CABLES:</strong></td>
<td>Refer to table 2-2 for compatible connector details. Refer to paragraphs 2-26 and 2-27 recommended types and lengths of I/O cables.</td>
</tr>
<tr>
<td><strong>ENVIRONMENTAL REQUIREMENTS</strong></td>
<td></td>
</tr>
<tr>
<td>Operating Temperature:</td>
<td>0° to 55°C (32° to 131°F).</td>
</tr>
<tr>
<td>Relative Humidity:</td>
<td>To 90% without condensation.</td>
</tr>
<tr>
<td><strong>PHYSICAL CHARACTERISTICS</strong></td>
<td></td>
</tr>
<tr>
<td>Width:</td>
<td>30.48 cm (12.00 inches).</td>
</tr>
<tr>
<td>Height:</td>
<td>17.15 cm (6.75 inches).</td>
</tr>
<tr>
<td>Thickness:</td>
<td>1.78 cm (0.7 inch).</td>
</tr>
<tr>
<td>Weight:</td>
<td>539 gm (19 ounces).</td>
</tr>
</tbody>
</table>
Table 1-1. Specifications (Continued)

<table>
<thead>
<tr>
<th>CONFIGURATION</th>
<th>$V_{CC} = \pm 5V \pm 5%$</th>
<th>$V_{DD} = \pm 12V \pm 5%$</th>
<th>$V_{BB} = \pm 5V \pm 5%$</th>
<th>$V_{AA} = \pm 12V \pm 5%$</th>
</tr>
</thead>
<tbody>
<tr>
<td>Without EPROM¹</td>
<td>5.2A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>RAM Only²</td>
<td>390 mA</td>
<td>40 mA</td>
<td>1.0 mA</td>
<td>—</td>
</tr>
<tr>
<td>With iSBC 530²</td>
<td>5.2A</td>
<td>450 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>With 4K EPROM⁴ (Using 2758)</td>
<td>5.5A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>With 8K ROM⁴ (Using 2316E)</td>
<td>6.1A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>With 8K EPROM⁴ (Using 2716)</td>
<td>5.5A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>With 16K ROM⁴ (Using 2332A)</td>
<td>5.4A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>With 16K EPROM⁴ (Using 2732)</td>
<td>5.4A</td>
<td>350 mA</td>
<td>—</td>
<td>40 mA</td>
</tr>
<tr>
<td>iSBC 300 Multimodule RAM</td>
<td>1 mA</td>
<td>24 mA</td>
<td>—</td>
<td>1 mA</td>
</tr>
<tr>
<td>iSBC 340 Multimodule PROM</td>
<td>120 mA</td>
<td>—</td>
<td>—</td>
<td>—</td>
</tr>
</tbody>
</table>

Notes:
1. Does not include power required for optional ROM/EPROM, I/O drivers, and I/O terminators.
2. RAM chips powered via auxiliary power bus.
3. Does not include power for optional ROM/EPROM, I/O drivers, and I/O terminators. Power for the iSBC 530 TTY Adapter is supplied via serial port connector.
4. Includes power required for four ROM/EPROM chips, and I/O terminators installed for 16 I/O lines; all terminator inputs low.
2-1. INTRODUCTION

This chapter provides instructions for preparing the iSBC 86/12A Single Board Computer for use in the user-defined environment. It is advisable that the contents of Chapters 1 and 3 be fully understood before beginning the configuration and installation procedures provided in this chapter.

2-2. UNPACKING AND INSPECTION

Inspect the shipping carton immediately upon receipt for evidence of mishandling during transit. If the shipping carton is severely damaged or waterstained, request that the carrier's agent be present when the carton is opened. If the carrier's agent is not present when the carton is opened and the contents of the carton are damaged, keep the carton and packing material for the agent's inspection.

For repairs to a product damaged in shipment, contact the Intel MCSD Technical Support Center (see paragraph 5-4) to obtain a Return Authorization Number and further instructions. A purchase order will be required to complete the repair. A copy of the purchase order should be submitted to the carrier with your claim.

It is suggested that salvageable shipping cartons and packing material be saved for future use in the event the product must be reshipped.

2-3. INSTALLATION CONSIDERATIONS

The iSBC 86/12A board is designed for use in one of the following configurations:

a. Standalone (single-board) system.
b. Bus master in a single bus master system.
c. Bus master in a multiple bus master system.

Important criteria for installing and interfacing the iSBC 86/12A board in these configurations are presented in the following paragraphs.

2-4. USER-FURNISHED COMPONENTS

The user-furnished components required to configure the iSBC 86/12A board for a particular application are listed in table 2-1. Various types and vendors of the connectors specified in table 2-1 are listed in table 2-2.

2-5. POWER REQUIREMENT

The iSBC 86/12A board requires +5V, -5V, +12V, and -12V power. The -5V power, which is required for the dual port RAM and the iSBC 300 Multimodule RAM, can be supplied by the system -5V supply, an auxiliary battery, or by the on-board -5V regulator. (The -5V regulator operates from the system -12V supply.)

2-6. COOLING REQUIREMENT

The iSBC 86/12A board dissipates 451 gram-calories/minute (1.83 Btu/minute) and adequate circulation of air must be provided to prevent a temperature rise above 55°C (131°F). The System 80 enclosures and the Intel Soc System include fans to provide adequate intake and exhaust of ventilating air.

2-7. PHYSICAL DIMENSIONS

Physical dimensions of the iSBC 86/12A board are as follows:

a. Width: 30.48 cm (12.00 inches).
b. Height: 17.15 cm (6.75 inches).
c. Thickness: 1.50 cm (0.59 inch).

2-8. COMPONENT INSTALLATION

Instructions for installing the user supplied ROM/EPROM, parallel I/O port line drivers and/or line terminators are given in the following paragraphs. When installing these chip components, be sure to orient pin 1 of the chip adjacent to the white dot located near pin 1 of the associated IC socket. The grid zone location on figure 5-1 (parts location diagram) is specified for each component chip to be installed.

Instructions for installing the optional iSBC 300 Multimodule RAM and the optional iSBC 340 Multimodule PROM are given in Appendix B.
2-9. ROM/EPROM CHIPS

IC sockets A28, A29, A46, and A47 (figure 5-1 zone C3) accommodate 24-pin ROM/EPROM chips. Because the CPU jumps to location FFFF0 on a power up or reset, the ROM/EPROM address space resides in the topmost portion of the 1-megabyte address space and must be loaded from the top down. IC sockets A29 and A47 accommodate the top of the ROM/EPROM address space and must always be loaded; IC sockets A28 and A46 accommodate the ROM/EPROM space directly below that installed in A29 and A47.

The low-order byte (bits 0-7) of ROM/EPROM must be installed in sockets A29 and A28; the high-order byte (bits 8-15) must be installed in sockets A47 and A46. Assuming that 2K bytes of EPROM are to be installed using two Intel 2758 chips, the chip containing the low-order byte must be installed in IC socket A29 and the chip containing the high-order byte must be installed in IC socket A47. In this configuration, the usable ROM/EPROM address space is FF800-FFFF. Two additional Intel 2758 chips may be installed later in IC sockets A28 and A46 and occupy the address space FF000-FF7FF. (Even addresses read the low-order bytes and odd addresses read the high-order bytes.)

The default (factory connected) jumpers and switch S1 are configured for 2K by 8-bit ROM/EPROM chips (e.g., two or four Intel 2716's). If different type chips are installed, reconfigure the jumpers and switch S1 as listed in table 2-4.

2-10. NO WAIT OPTION. When 2716-1, EPROMs or 2332 ROMs are installed, the jumper between posts E3-E4 can be installed. This eliminates the wait state for ROM/PROM read. If any other type of ROM or PROM is installed, the jumper must be removed (one wait state), which is the factory default wiring.

2-11. LINE DRIVERS AND I/O TERMINATORS

Table 2-3 lists the I/O ports and the location of associated 14-pin sockets for installing either line drivers or I/O terminators. (Refer to table 2-1 items 10 and 11.) Port C8 is factory equipped with Intel 8226 Bidirectional Bus Drivers and requires no additional components.

2-12. JUMPER/SWITCH CONFIGURATION

The iSBC 86/12A board includes a variety of jumper- and switch-selectable options to allow the user to configure the board for his particular application. Table 2-4 summarizes these options and lists the grid reference locations of the jumpers and switches as shown in figure 5-1 (parts location diagram) and figure 5-2 (schematic diagram). Because the schematic diagram consists of 11 sheets, grid references to figure 5-2 may be either four or five alphanumeric characters. For example, grid reference 3ZB7 signifies sheet 3 zone B7.

---

**Table 2-1. User-Furnished and Installed Components**

<table>
<thead>
<tr>
<th>Item No.</th>
<th>Item</th>
<th>Description</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>iSBC 604 Backplane</td>
<td>Modular Backplane and Cardcage. Includes four slots with bus terminators.</td>
<td>Provides power input pins and Multi-bus interface signal interface between iSBC 86/12A board and three additional boards in a multiple board system.</td>
</tr>
<tr>
<td>2</td>
<td>iSBC 614 Backplane</td>
<td>Modular Backplane and Cardcage. Includes four slots without bus terminators.</td>
<td>Provides four-slot extension of iSBC 604 backplane.</td>
</tr>
<tr>
<td>3</td>
<td>iSBC 300 Multimodule RAM</td>
<td>32K Multimodule RAM Board.</td>
<td>Provides the capability to expand the on-board RAM to 64K bytes using 2117's.</td>
</tr>
</tbody>
</table>
### Table 2-1. User-Furnished and Installed Components (Continued)

<table>
<thead>
<tr>
<th>Item No.</th>
<th>Item</th>
<th>Description</th>
<th>Use</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>ISBC 340 Multimodule PROM</td>
<td>16K Multimodule EPROM Board.</td>
<td>Provides the capability to expand the on-board EPROM to 32K bytes using 2332A's or 2732's. See Appendix C for information on using 2716's or 2758's in place of the 2732's.</td>
</tr>
<tr>
<td>5</td>
<td>Connector (mates with P1)</td>
<td>See Multibus interface Connector details in table 2-2.</td>
<td>Power inputs and Multibus interface signal interface. Not required if ISBC 86/12A board is installed in an ISBC 604/614 backplane.</td>
</tr>
<tr>
<td>6</td>
<td>Connector (mates with P2)</td>
<td>See Auxiliary Connector details in table 2-2</td>
<td>Auxiliary backup battery and associated memory protect functions.</td>
</tr>
<tr>
<td>7</td>
<td>Connector (mates with J1)</td>
<td>See Parallel I/O Connector details in table 2-2.</td>
<td>Interfaces parallel I/O port with Intel 8255A PPI.</td>
</tr>
<tr>
<td>8</td>
<td>Connector (mates with J2)</td>
<td>See Serial I/O connector details in table 2-2.</td>
<td>Interfaces serial I/O port with Intel 8251A USART.</td>
</tr>
<tr>
<td>9</td>
<td>ROM/EPROM Chips</td>
<td>Two or four each of the following types:</td>
<td>Ultraviolet Erasable PROM (EPROM) for development. Masked ROM for dedicated program.</td>
</tr>
<tr>
<td></td>
<td>ROM</td>
<td>EPROM</td>
<td></td>
</tr>
<tr>
<td></td>
<td>—</td>
<td>2758</td>
<td></td>
</tr>
<tr>
<td></td>
<td>2316E</td>
<td>2716</td>
<td></td>
</tr>
<tr>
<td></td>
<td>2332</td>
<td>2732</td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>Line Drivers</td>
<td>Type</td>
<td>Current</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SN7403 I, OC</td>
<td>16 mA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SN7400 I</td>
<td>16 mA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SN7408 NI</td>
<td>16 mA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>SN7409 NI, OC</td>
<td>16 mA</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Types selected as typical; I = inverting, NI = noninverting, and OC = open collector.</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>Line Terminators</td>
<td>Intel ISBC 901 Divider or ISBC 902 Pull-Up:</td>
<td>Interface parallel I/O ports CA and CC with Intel 8255A PPI. Requires two line driver IC's for each 8-bit parallel output port.</td>
</tr>
<tr>
<td></td>
<td></td>
<td><img src="image" alt="Diagram of ISBC 901 Divider or ISBC 902 Pull-Up" /></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td><img src="image" alt="Diagram of ISBC 902 Pull-Up" /></td>
<td>Interface parallel I/O ports CA and CC with Intel 8255A PPI. Requires two ISBC 901 Dividers or two ISBC 902 Pull-Ups for each 8-bit parallel input port.</td>
</tr>
<tr>
<td>Function</td>
<td>Pins</td>
<td>Centers (inches)</td>
<td>Connector Type</td>
</tr>
<tr>
<td>-----------------------</td>
<td>------</td>
<td>-----------------</td>
<td>---------------------------</td>
</tr>
<tr>
<td>Multibus Connector P1</td>
<td>43/86</td>
<td>0.156</td>
<td>Solder PCB</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Wire Wrap (no ears)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Wire Wrap (with 0.128</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>mounting holes)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Auxiliary Connector P2</td>
<td>30/60</td>
<td>0.100</td>
<td>Wire Wrap</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>With 0.128 mounting holes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Parallel Port</td>
<td>25/50</td>
<td>0.100</td>
<td>Flat Crimp</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Serial Port</td>
<td>13/26</td>
<td>0.100</td>
<td>PCB Soldered mounting holes</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Flat Crimp</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Soldered, pierced tail</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Wire Wrap</td>
</tr>
</tbody>
</table>

**Notes:**
1. Connector heights are not guaranteed to conform to OEM equipment.
2. Wire wrap pin lengths are not guaranteed to conform to OEM equipment.
3. Connector numbering convention may not agree with board connector.
### Table 2-3. Line Driver and I/O Terminator Locations

<table>
<thead>
<tr>
<th>I/O Port</th>
<th>Bits</th>
<th>Driver/Terminator</th>
<th>Fig. 5-1 Grid Ref.</th>
<th>Fig. 5-2* Grid Ref.</th>
</tr>
</thead>
<tbody>
<tr>
<td>8255A PPI Interface</td>
<td>C8</td>
<td>0-7</td>
<td>None Required</td>
<td>—</td>
</tr>
<tr>
<td></td>
<td>CA</td>
<td>0-3</td>
<td>A12</td>
<td>ZD4</td>
</tr>
<tr>
<td></td>
<td></td>
<td>4-7</td>
<td>A13</td>
<td>ZD4</td>
</tr>
<tr>
<td></td>
<td>CC</td>
<td>0-3</td>
<td>A11</td>
<td>ZD5</td>
</tr>
<tr>
<td></td>
<td></td>
<td>4-7</td>
<td>A10</td>
<td>ZD5</td>
</tr>
</tbody>
</table>

*Figure 5-2 is the schematic diagram. Grid reference 9ZA4, for example, denotes sheet 9 zone A4.

### Table 2-4. Jumper and Switch Selectable Options

<table>
<thead>
<tr>
<th>Function</th>
<th>Fig. 5-1 Grid Ref.</th>
<th>Fig. 5-2 Grid Ref.</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROM/EPROM Configuration</td>
<td>ZC2, ZC3, ZB6</td>
<td>6ZB3, 6ZC3, 6ZC7</td>
<td>Jumpers E94 through E99 and switch S1 may be configured to accommodate the following ROM/EPROM chips:</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ROM/EPROM Type</th>
<th>Jumpers</th>
<th>Switch S1 8 7</th>
</tr>
</thead>
<tbody>
<tr>
<td>2758</td>
<td>E94-E95, E97-E98</td>
<td>ON  ON</td>
</tr>
<tr>
<td>2316E/2716</td>
<td>*E94-E96, *E97-E98</td>
<td>*ON *OFF</td>
</tr>
<tr>
<td>2332A/2732</td>
<td>E94-E96, E97-E99</td>
<td>OFF  ON</td>
</tr>
<tr>
<td>ISBC 340</td>
<td>E94-E96, E97-E99</td>
<td>OFF  OFF</td>
</tr>
</tbody>
</table>

Default jumpers and switch settings accommodate Intel 2316E/2716 chips. Disconnect existing configuration jumpers (if necessary) and reset switch S1 if reconfiguration is required.

| No Wait Option | ZD6 | 2ZB6 | Removing jumper* E3-E4 creates a wait state after ROM/PROM reads. If 2716-1,2 PROMs or 2332 ROMs are installed, the jumper can be added, eliminating the wait state. |

| Dual Port RAM (Multibus Interface Access) | ZB6 | 3ZB5, 3ZB7 | The dual port RAM permits access by the local (on-board) CPU and any system bus master via the Multibus interface. For local CPU access, the dual port RAM address space is fixed beginning at location 00000. For access via the Multibus interface, one jumper and one switch can configure the dual port RAM on any 8K boundary within the 1-megabyte address space. Refer to paragraph 2-13 for configuration details. |

| Bus Clock | ZB7 | 10ZB2 | Default jumper *E105-E106 routes Bus Clock signal BCLK/ to the Multibus interface. (Refer to table 2-9.) Remove this jumper only if another bus master supplies this signal. |

| Constant Clock | ZB7 | 10ZA2 | Default jumper *E103-E104 routes Constant Clock signal CCLK/ to the Multibus interface. (Refer to table 2-9.) Remove this jumper only if another bus master supplies this signal. |

| Bus Priority Out | ZB7 | 3ZD3 | Default jumper *E151-E152 routes Bus Priority Out signal BPRO/ to the Multibus interface. (Refer to table 2-9.) Remove this jumper only in those systems employing a parallel priority bus resolution scheme. (Refer to paragraph 2-24.) |

| Bus Arbitration | ZB7, ZB8 | 3ZD3, 3ZC4 | Different combinations of CBRO and ANYRQT control the operation of the 8289 Bus Arbiter. Table 2-13 lists the various configurations. |

* = default jumper

(Continued)
<table>
<thead>
<tr>
<th>Function</th>
<th>Fig. 5-1 Grid Ref.</th>
<th>Fig. 5-2 Grid Ref.</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Auxiliary Backup Batteries</td>
<td>ZD3, ZB6, ZB5</td>
<td>1ZC7, 1ZC6</td>
<td>If auxiliary backup batteries are used to sustain the dual port RAM contents during ac power outages, remove default jumpers *W4(A-B), *W5(A-B), and *W6(A-B).</td>
</tr>
<tr>
<td>On-Board -5V Regulator</td>
<td>ZB6</td>
<td>1ZC6</td>
<td>The dual port RAM requires a -5V AUX input, which can be supplied by the system -5V supply, and auxiliary backup battery, or by the on-board -5V regulator. (The -5V regulator operates from the system -12V supply.) If a system -5V supply is available and auxiliary backup batteries are not used, disconnect default jumper *W5(A-B) and connect jumper W5 (B-C). If auxiliary backup batteries are used, disconnect default jumper *W5(A-B); do not connect W5(B-C).</td>
</tr>
<tr>
<td>Failsafe Timer</td>
<td>ZD6</td>
<td>2ZB6</td>
<td>If the on-board CPU addresses either a system or an on-board memory or I/O device and that device does not return an acknowledge signal, the CPU will hang up in a wait state. A failsafe timer is triggered during T1 of every machine cycle and, if not retriggered within 6.2 milliseconds, the resultant time-out pulse can be used to allow the CPU to exit the wait state. If this feature is desired, connect jumper E5-E6.</td>
</tr>
<tr>
<td>Timer Input Frequency</td>
<td></td>
<td></td>
<td>Input frequencies to the 8253 Programmable Interval Timer are jumper selectable as follows:</td>
</tr>
<tr>
<td></td>
<td>ZD3</td>
<td>7ZB4</td>
<td>Counter 0 (TMR0 INTR)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E57-E58: 153.6 kHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E57-E56: 1.23 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E57-E53: 2.46 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E57-E62: External Clock to/from Port CC terminator/driver.</td>
</tr>
<tr>
<td></td>
<td>ZD3</td>
<td>7ZB4</td>
<td>Counter 1 (TMR1 INTR)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E59-E60: 153.6 kHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E59-E56: 1.23 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E59-E53: 2.46 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E59-E62: External Clock to/from Port CC terminator/driver.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E59-E81: Counter 0 output.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Jumper E59-E61 effectively connects Counter 0 and Counter 1 in series in which the output of Counter 0 serves as the input clock to Counter 1. This permits programming the clock rates to Counter 1 and thus provides longer TMR1 INTR intervals.</td>
</tr>
<tr>
<td></td>
<td>ZD3</td>
<td>7ZB4</td>
<td>Counter 2 (8251A Baud Rate Clock)</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E55-E58: 153.6 kHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E55-E54: 1.23 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E55-E53: 2.46 MHz.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>E55-E62: External Clock to/from Port CC terminator/driver.</td>
</tr>
<tr>
<td>Priority Interrupts</td>
<td>—</td>
<td>Sheet 8</td>
<td>A jumper matrix provides a wide selection of interrupts to be interfaced to the 8086 CPU and the Multibus interface. Refer to paragraph 2-14 for configuration.</td>
</tr>
<tr>
<td>Serial I/O Port Configuration</td>
<td>—</td>
<td>Sheet 7</td>
<td>Jumper posts E38 through E52 are used to configure the 8251A USART as described in paragraph 2-15.</td>
</tr>
<tr>
<td>Parallel I/O Port Configuration</td>
<td>—</td>
<td>Sheet 9</td>
<td>Jumper posts E7 through E37 are used to configure the 8255A PPI as described in paragraph 2-16.</td>
</tr>
<tr>
<td>TEST/ Signal</td>
<td>ZD5</td>
<td>9ZB5</td>
<td>Imposes idle state on 8086 when high. Normal processing when low. Connect jumper post E12 to desired parallel port output bit.</td>
</tr>
</tbody>
</table>

*Default jumper connected at the factory.
Study table 2-4 carefully while making reference to figures 5-1 and 5-2. If the default (factory configured) jumpers and switch settings are appropriate for a particular function, no further action is required for that function. If, however, a different configuration is required, reconfigure the switch settings and/or remove the default jumper(s) and install an optional jumper(s) as specified. For most options, the information in table 2-4 is sufficient for proper configuration. Additional information, where necessary for clarity, is described in subsequent paragraphs.

2-13. RAM ADDRESSES (MULTIBUS INTERFACE ACCESS)

The dual port RAM can be shared with other bus masters via the Multibus interface. One jumper wire connected between a selected pair of jumper posts (E113 through E128) places the dual port RAM in one of eight 128K byte segments of the 1-megabyte address space. Switch S1 is a dual-inline package (DIP) composed of eight individual single-pole, single-throw switches. (Two of these individual switches are used for ROM/EPROM configuration.) Two switches on S1 (6-11 and 5-12) are configured to allow 8K, 16K, 24K, or 32K bytes of dual port RAM to be accessed. Four switches on S1 (1-16, 2-15, 3-14, and 4-13) are configured to displace the addresses from the top of the selected 128K byte segment of memory.

Figure 2-1 provides an example of 8K bytes of dual port RAM being made accessible from the Multibus interface and how the addresses are established. Note in figure 2-1 that the Multibus interface accesses the dual port RAM from the top down. Thus, as shown for 8K byte access via the Multibus interface, the bottom 24K bytes of the iSBC 86/12A board on-board RAM is reserved strictly for on-board CPU access.

Figure 2-1A shows the access with the iSBC 300 RAM module installed. Dual port RAM must be configured on 16K boundaries when the iSBC 300 board is installed. Always observe the IMPORTANT note in figure 2-1 in that the address space intended for Multibus interface access of the dual port RAM must not cross as 128K boundary.

If it is desired to reserve all the dual port RAM strictly for local CPU access, connect jumper E112-E114.

2-14. PRIORITY INTERRUPTS

Table 2-5 lists the source (from) and destination (to) of the priority interrupt jumper matrix shown in figure 5-2 sheet 8. The INTR output of the on-board Intel 8259A Programmable Interrupt Controller (PIC) is applied directly to the INTR input of the 8086 CPU. The on-board PIC, which handles up to eight vectored priority interrupts, provides the capability to expand the number of priority interrupts by cascading each interrupt line with another 8259A PIC. Figure 2-2 shows, as an example, the on-board PIC (master) with two slave PIC's interfaced by the Multibus interface. This arrangement leaves the master PIC with six inputs (IR2 through IR7) that can be used to handle the various on-board interrupt functions.

The master/slave PIC arrangement illustrated in figure 2-2 is implemented by programming the master PIC to handle IR0 and IR1 as bus vectored interrupt inputs. For example, if the Multibus interface INT3/ line is driven low by slave PIC 1, the master PIC will let slave PIC 1 send the vector address to the 8086 CPU.

Each interrupt input (IR0 through IR7) to the master PIC can be individually programmed to be a non-bus vectored (NVB) interrupt (the master PIC generates the restart address) or bus vectored (BV) interrupt (the slave PIC generates the restart address). Thus, the master PIC can handle eight on-board or single Multibus interface interrupt lines (an interrupt line that is not driven by a slave PIC) or up to 64 interrupts with the implementation of slave PIC's.

The iSBC 86/12A board can also generate an interrupt to another interrupt handler via the Multibus interface. This is accomplished by using one of the bits of the 8255A PPI to drive the BUS INTR OUT signal. (The BUS INTR OUT signal is ground-true at jumper post E142 as footnoted in table 2-5.)

Default jumper E87-E89 grounds the NMI (non-maskable interrupt) input to the CPU to prevent the possibility of false interrupts being generated by noise spikes. Since the NMI is not maskable, cannot be disabled by the program, and has the highest priority, it should only be used to detect a power failure. For this purpose, disconnect default jumper E87-E89 and connect E86-E89. The Power Fail Interrupt (PFIN/) is an externally generated signal that is input via auxiliary connector P2. (Refer to paragraph 2-25.)

2-15. SERIAL I/O PORT CONFIGURATION

Table 2-6 lists the signals, signal functions, and the jumpers required (if necessary) to input or output a particular signal to or from the serial I/O port (Intel 8251A USART).
Figure 2-1. Dual Port RAM Address Configuration (Multibus™ Interface Access)
Figure 2-1A. Dual Port RAM Address Configuration With iSBC 300 RAM Module Installed
### Table 2-5. Priority Interrupt Jumper Matrix

<table>
<thead>
<tr>
<th>Source</th>
<th>Signal</th>
<th>Post</th>
<th>Device</th>
<th>Signal</th>
<th>Post</th>
</tr>
</thead>
<tbody>
<tr>
<td>Multibus Interface (2)</td>
<td>INTO/</td>
<td>E73</td>
<td>Multibus Interface (2)</td>
<td>INTO/</td>
<td>E141</td>
</tr>
<tr>
<td></td>
<td>INT1/</td>
<td>E72</td>
<td></td>
<td>INT1/</td>
<td>E140</td>
</tr>
<tr>
<td></td>
<td>INT2/</td>
<td>E71</td>
<td></td>
<td>INT2/</td>
<td>E139</td>
</tr>
<tr>
<td></td>
<td>INT3/</td>
<td>E70</td>
<td></td>
<td>INT3/</td>
<td>E138</td>
</tr>
<tr>
<td></td>
<td>INT4/</td>
<td>E69</td>
<td></td>
<td>INT4/</td>
<td>E137</td>
</tr>
<tr>
<td></td>
<td>INT5/</td>
<td>E68</td>
<td></td>
<td>INT5/</td>
<td>E136</td>
</tr>
<tr>
<td></td>
<td>INT6/</td>
<td>E66</td>
<td></td>
<td>INT6/</td>
<td>E135</td>
</tr>
<tr>
<td></td>
<td>INT7/</td>
<td>E65</td>
<td></td>
<td>INT7/</td>
<td>E134</td>
</tr>
<tr>
<td>External Via J1-50 Power</td>
<td>J1 INT0/</td>
<td>E67</td>
<td>8259A PIC (6)</td>
<td>IR0</td>
<td>E81</td>
</tr>
<tr>
<td>Fail Safe Logic</td>
<td>PFIN/</td>
<td>E86</td>
<td></td>
<td>IR1</td>
<td>E80</td>
</tr>
<tr>
<td>Via P2-19</td>
<td>TIME OUT INTR</td>
<td>E88</td>
<td></td>
<td>IR2</td>
<td>E79</td>
</tr>
<tr>
<td>Safesafe Timer</td>
<td></td>
<td></td>
<td></td>
<td>IR3</td>
<td>E78</td>
</tr>
<tr>
<td>8255A PPI</td>
<td>PA INTR</td>
<td>E84</td>
<td></td>
<td>IR4</td>
<td>E77</td>
</tr>
<tr>
<td>Port A (Port C8)</td>
<td>PB INTR</td>
<td>E85</td>
<td></td>
<td>IR5</td>
<td>E76</td>
</tr>
<tr>
<td>Port B (Port CA)</td>
<td>BUS INTR OUT (3)</td>
<td>E142</td>
<td></td>
<td>IR6</td>
<td>E75</td>
</tr>
<tr>
<td>Any Unused Bit</td>
<td></td>
<td></td>
<td></td>
<td>IR7</td>
<td>E74</td>
</tr>
<tr>
<td>8251A USART</td>
<td>51TX INTR</td>
<td>E90</td>
<td>8086 CPU</td>
<td>NMI INTR</td>
<td>E89</td>
</tr>
<tr>
<td>Trans Buffer Empty</td>
<td>51RX INTR</td>
<td>E82</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Rec Buffer Empty</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8253 PIT</td>
<td>TMR0 INTR</td>
<td>E83</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Timer 0 Out</td>
<td>TMR1 INTR</td>
<td>E91</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTES:**
1. Signal is positive-true at associated jumper post. (Must use 8259A in edge triggered mode.)
2. INTO/ is highest priority; INT7/ is lowest priority.
3. Signal is ground-true at associated jumper post.
4. Requires ground-true signal at associated jumper post.
5. Requires positive-true signal at associated jumper post.
6. IR0 is highest priority; IR7 is lowest priority.
7. Default jumper E87-E89 disables (grounds) input. The NMI input is highest priority, non-maskable, and is both level and edge sensitive.
8. INTR is connected directly to output of 8259A PIC.
9. Used to generate an interrupt on Multibus interface.

---

**Figure 2-2. Simplified Master/Slave PIC Interconnect Example**
Table 2-6. Serial I/O Connector J2 Pin Assignments Vs Configuration Jumpers

<table>
<thead>
<tr>
<th>Pin1-2</th>
<th>Signal</th>
<th>Function</th>
<th>Jumper In</th>
<th>Jumper Out</th>
</tr>
</thead>
<tbody>
<tr>
<td>2</td>
<td>CHASSIS GND</td>
<td>Protective ground</td>
<td>E63-E64</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>TRANSMITTER DATA</td>
<td>8251A RXD in</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>SEC REC SIG2</td>
<td>Same as 8251A TXC in or</td>
<td>E48-E49, E45-E46</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>8255A STXD out (Note 3)</td>
<td>E49-E50, E45-E46</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>RECEIVER DATA</td>
<td>8251A TXD out</td>
<td></td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>REC SIG ELE TIMING</td>
<td>8251A RXC in (Note 4)</td>
<td>*E39-E40</td>
<td>E38-E39</td>
</tr>
<tr>
<td></td>
<td></td>
<td>8251A TXC in (Note 4)</td>
<td>*E42-E43</td>
<td>E41-E42</td>
</tr>
<tr>
<td>8</td>
<td>RQT TO SEND</td>
<td>8251A CTS in (Note 5)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>10</td>
<td>CLEAR TO SEND</td>
<td>8251A RTS out (Note 5)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>DATA SET RDY</td>
<td>8251A DTR out</td>
<td></td>
<td></td>
</tr>
<tr>
<td>13</td>
<td>DATA TERMINAL RDY</td>
<td>8251A DSR in</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>GND</td>
<td>Ground</td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>-12V</td>
<td>-12V out</td>
<td></td>
<td>W3A-B</td>
</tr>
<tr>
<td>21</td>
<td>TRANS SIG ELE TIMING2</td>
<td>Same as 8251A TXC in or</td>
<td>E48-E49, E44-E45</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>8255A STXD out (Note 3)</td>
<td>E49-E50, E44-E45</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>+12V</td>
<td>+12V out</td>
<td>W2A-B</td>
<td>W1A-B</td>
</tr>
<tr>
<td>23</td>
<td>+5V</td>
<td>+5V out</td>
<td></td>
<td></td>
</tr>
<tr>
<td>25</td>
<td>GND</td>
<td>Ground</td>
<td></td>
<td></td>
</tr>
<tr>
<td>26</td>
<td>SEC CTS2</td>
<td>Same as 8251A TXC in or</td>
<td>E48-E49, E45-E47</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>8255A STXD out (Note 3)</td>
<td>E49-E50, E45-E47</td>
<td></td>
</tr>
</tbody>
</table>

NOTES:
1. All odd-numbered pins (*1, 3, 5, . . . , 25) are on component side of the board. Pin 1 is the right-most pin when viewed from the component side of the board with the extractors at the top.
2. Only one of these signal outputs (pin 5, 21, or 26) may be selected.
3. Optional jumper selected output of 8255A PPI. Refer to figure 5-2 sheet 9.
4. Default jumpers *E39-E40 and *E42-E43 connect 8253 CTR2 output to 8251A RXC and TXC inputs, respectively. See Timer Input Frequency (Counter 2) in table 2-4.
5. For those applications without CTS capability, connect jumper E51-E52. This routes 8251A RTS output to 8251A CTS input.
6. Cable connector numbering convention may not agree with board connector numbering convention.
* Default jumpers connected at the factory.

2-16. PARALLEL I/O PORT CONFIGURATION

Table 2-7 lists the jumper configuration for three parallel I/O ports. Note that each of the three ports (C8, CA, and CC) can be configured in a variety of ways to suit the individual requirement.

2-17. MULTIBUS INTERFACE CONFIGURATION

For systems applications, the iSBC 86/12A board is designed for installation in a standard Intel iSBC 604/614 Modular Backplane and Cardcage. (Refer to table 2-1 items 1 and 2.) Alternatively, the iSBC 86/12A board can be interfaced to a user-designed system backplane by means of an 86-pin connector. (Refer to table 2-1 item 5.) Multibus interface signal characteristics and methods of implementing a serial or parallel priority resolution scheme for resolving bus contention in a multiple bus master system are described in the following paragraphs.

2-18. SIGNAL CHARACTERISTICS

As shown in figure 1-1, connector P1 interfaces the iSBC 86/12A board to the Multibus interface. Connector P1 pin assignments are listed in table 2-8 and descriptions of the signal functions are provided in table 2-9.

The dc characteristics of the iSBC 86/12A board bus interface signals are provided in table 2-10. The ac characteristics of the iSBC 86/12A board when operating in the master mode and slave mode are provided in tables 2-11 and 2-12, respectively. Bus exchange timing diagrams are provided in figures 2-3 and 2-4.
<table>
<thead>
<tr>
<th>Port</th>
<th>Mode</th>
<th>Driver (D)/Terminator (T)</th>
<th>Jumper Configuration</th>
<th>Restrictions</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Delete</td>
<td>Add</td>
</tr>
<tr>
<td>C8</td>
<td>0 Input</td>
<td>8226: A8, A9</td>
<td>*E21-E25</td>
<td>E24-E25</td>
</tr>
<tr>
<td>C8</td>
<td>0 Output</td>
<td>8226: A8, A9</td>
<td>*E21-E25</td>
<td></td>
</tr>
<tr>
<td></td>
<td>(latched)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C8</td>
<td>1 Input</td>
<td>8226: A8, A9 T: A10 D: A11</td>
<td>*E21-E25</td>
<td>E24-E25</td>
</tr>
<tr>
<td></td>
<td>(strobed)</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E15-E16</td>
<td>E19-E33</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E19-E20 and *E32-E33</td>
<td>E22-E32</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E17-E18</td>
<td>E13-E33</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>*E32-E33 and *E13-E14</td>
<td>E22-E32</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Default jumper connected at the factory.*
## Table 2-7. Parallel I/O Port Configuration Jumpers (Continued)

<table>
<thead>
<tr>
<th>Port</th>
<th>Mode</th>
<th>Driver (D)/ Terminator (T)</th>
<th>Jumper Configuration</th>
<th>Restrictions</th>
<th>Restrictions</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>2 (bidirectional)</td>
<td>8226: A8, A9 T: A10 D: A11</td>
<td>Jumper Configuration</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td>Delete</td>
<td>Add</td>
<td>Effect</td>
</tr>
<tr>
<td>C8</td>
<td>2</td>
<td>E21-E25</td>
<td>E17-E25</td>
<td>*E15-E16</td>
<td>Connects J1-26 to STB/ input.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>*E19-E20 and *E26-E27</td>
<td>Connects IBF to J1-24.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>*E17-E18</td>
<td>Connects J1-30 to ACK/ input.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>*E13-E14 and *E32-E33</td>
<td>Connects OBF output to J1-18.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>E13-E33</td>
<td>Connects OBF to interrupt matrix.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>E22-E32</td>
<td>Connects INT output to interrupt matrix.</td>
</tr>
<tr>
<td>CA</td>
<td>0 Input</td>
<td>T: A12, A13</td>
<td>None</td>
<td>None</td>
<td>C8 None.</td>
</tr>
<tr>
<td>CA</td>
<td>0 Output</td>
<td>D: A12, A13</td>
<td>None</td>
<td>None</td>
<td>C8 None.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>E14-E30</td>
<td>Connects INT output interrupt matrix.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>E26-E34</td>
<td>Connects INT output interrupt matrix.</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Default jumper connected at the factory.
Table 2-7. Parallel I/O Port Configuration Jumpers (Continued)

<table>
<thead>
<tr>
<th>Port</th>
<th>Mode</th>
<th>Driver (D) Terminator (T)</th>
<th>Jumper Configuration</th>
<th>Restrictions</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>Delete</td>
<td>Add</td>
</tr>
<tr>
<td>CA</td>
<td>1 Output (latched)</td>
<td>T: A10, D: A11, A12, A13</td>
<td>*E13-E14 and *E30-E31</td>
<td>*E26-E27</td>
</tr>
<tr>
<td>CC</td>
<td>0 Input (latched)</td>
<td>T: A10</td>
<td>None</td>
<td></td>
</tr>
<tr>
<td>CC</td>
<td>0 Input (latched)</td>
<td>T: A11</td>
<td>None</td>
<td></td>
</tr>
<tr>
<td>CC</td>
<td>0 Output (latched)</td>
<td>D: A10</td>
<td>None</td>
<td></td>
</tr>
<tr>
<td>CC</td>
<td>0 Output (latched)</td>
<td>D: A11</td>
<td>None</td>
<td></td>
</tr>
</tbody>
</table>

*Default jumper connected at the factory.
## Table 2-8. Multibus™ Interface Connector P1 Pin Assignments

<table>
<thead>
<tr>
<th>Pin</th>
<th>Component Side</th>
<th>Circuit Side</th>
</tr>
</thead>
<tbody>
<tr>
<td>PIN</td>
<td>MNEMONIC</td>
<td>DESCRIPTION</td>
</tr>
<tr>
<td>1</td>
<td>GND</td>
<td>Signal GND</td>
</tr>
<tr>
<td>3</td>
<td>+5V</td>
<td>+5Vdc</td>
</tr>
<tr>
<td>5</td>
<td>+5V</td>
<td>+5Vdc</td>
</tr>
<tr>
<td>7</td>
<td>+12V</td>
<td>+12Vdc</td>
</tr>
<tr>
<td>9</td>
<td>-5V</td>
<td>-5Vdc</td>
</tr>
<tr>
<td>11</td>
<td>GND</td>
<td>Signal GND</td>
</tr>
<tr>
<td>13</td>
<td>BCLK/</td>
<td>Bus Clock</td>
</tr>
<tr>
<td>15</td>
<td>BPRN/</td>
<td>Bus Priority In</td>
</tr>
<tr>
<td>17</td>
<td>BUSY/</td>
<td>Bus Busy</td>
</tr>
<tr>
<td>19</td>
<td>MRDC/</td>
<td>Mem Read Cmd</td>
</tr>
<tr>
<td>21</td>
<td>IORC/</td>
<td>I/O Read Cmd</td>
</tr>
<tr>
<td>23</td>
<td>XACK/</td>
<td>XFER Acknowledge</td>
</tr>
<tr>
<td>25</td>
<td>LOCK/</td>
<td>Dual Port Lock</td>
</tr>
<tr>
<td>27</td>
<td>BHEN/</td>
<td>Byte High Enable</td>
</tr>
<tr>
<td>29</td>
<td>CBRQ/</td>
<td>Common Bus Request</td>
</tr>
<tr>
<td>31</td>
<td>CCLK/</td>
<td>Constant Ck</td>
</tr>
<tr>
<td>33</td>
<td>INTA/</td>
<td>Interrupt Acknowledge</td>
</tr>
<tr>
<td>35</td>
<td>INT6/</td>
<td>Parallel</td>
</tr>
<tr>
<td>37</td>
<td>INT4/</td>
<td>Interrupt</td>
</tr>
<tr>
<td>39</td>
<td>INT2/</td>
<td>Requests</td>
</tr>
<tr>
<td>41</td>
<td>INT0/</td>
<td></td>
</tr>
<tr>
<td>43</td>
<td>ADRE/</td>
<td></td>
</tr>
<tr>
<td>45</td>
<td>ADRC/</td>
<td></td>
</tr>
<tr>
<td>47</td>
<td>ADRA/</td>
<td>Address</td>
</tr>
<tr>
<td>49</td>
<td>ADR8/</td>
<td>Bus</td>
</tr>
<tr>
<td>51</td>
<td>ADR6/</td>
<td></td>
</tr>
<tr>
<td>53</td>
<td>ADR4/</td>
<td></td>
</tr>
<tr>
<td>55</td>
<td>ADR2/</td>
<td></td>
</tr>
<tr>
<td>57</td>
<td>ADR0/</td>
<td></td>
</tr>
<tr>
<td>59</td>
<td>DATE/</td>
<td>Data</td>
</tr>
<tr>
<td>61</td>
<td>DATC/</td>
<td></td>
</tr>
<tr>
<td>63</td>
<td>DATA/</td>
<td></td>
</tr>
<tr>
<td>65</td>
<td>DAT8/</td>
<td>Data</td>
</tr>
<tr>
<td>67</td>
<td>DAT6/</td>
<td>Bus</td>
</tr>
<tr>
<td>69</td>
<td>DAT4/</td>
<td></td>
</tr>
<tr>
<td>71</td>
<td>DAT2/</td>
<td></td>
</tr>
<tr>
<td>73</td>
<td>DAT0/</td>
<td></td>
</tr>
<tr>
<td>75</td>
<td>GND</td>
<td>Signal GND</td>
</tr>
<tr>
<td>77</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>79</td>
<td>-12V</td>
<td>-12Vdc</td>
</tr>
<tr>
<td>81</td>
<td>+5V</td>
<td>+5Vdc</td>
</tr>
<tr>
<td>83</td>
<td>+5V</td>
<td>+5Vdc</td>
</tr>
<tr>
<td>85</td>
<td>GND</td>
<td>Signal GND</td>
</tr>
</tbody>
</table>

1. All odd-numbered pins (1, 3, 5...85) are on component side of the board. Pin 1 is the left-most pin when viewed from the component side of the board with the extractors at the top. All unassigned pins are reserved.
<table>
<thead>
<tr>
<th>Signal</th>
<th>Functional Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADR0/-ADRF/</td>
<td>Address. These 20 lines transmit the address of the memory location or I/O port to be accessed. For memory access, ADR0/ (when active low) enables the even byte (DAT0/- DAT7/) on the Multibus interface; i.e., ADR0/ is active low for all even addresses. ADR13/ is the most significant address bit.</td>
</tr>
<tr>
<td>ADR10/-ADR13/</td>
<td></td>
</tr>
<tr>
<td>BCLK/</td>
<td>Bus Clock. Used to synchronize the bus contention logic on all bus masters. When generated by the ISBC 86/12A board, BCLK/ has a period of 108.5 nanoseconds (9.22 MHz) with a 35-65 percent duty cycle.</td>
</tr>
<tr>
<td>BHEN/</td>
<td>Byte High Enable. When active low, enables the odd byte (DAT8/-DATF/) onto the Multibus interface.</td>
</tr>
<tr>
<td>BPRN/</td>
<td>Bus Priority In. Indicates to a particular bus master that no higher priority bus master is requesting use of the bus. BPRN/ is synchronized with BCLK/.</td>
</tr>
<tr>
<td>BPRO/</td>
<td>Bus Priority Out. In serial (daisy chain) priority resolution schemes, BPRO/ must be connected to the BPRN/ input of the bus master with the next lower bus priority.</td>
</tr>
<tr>
<td>BREQ/</td>
<td>Bus Request. In parallel priority resolution schemes, BREQ/ indicates that a particular bus master requires control of the bus for one or more data transfers. BREQ/ is synchronized with BCLK/.</td>
</tr>
<tr>
<td>BUSY/</td>
<td>Bus Busy. Indicates that the bus is in use and prevents all other bus masters from gaining control of the bus. BUSY/ is synchronized with BCLK/.</td>
</tr>
<tr>
<td>CBRQ/</td>
<td>Common Bus Request. Indicates that a bus master wishes control of the bus but does not presently have control. As soon as control of the bus is obtained, the requesting bus controller raises the CBRQ/ signal.</td>
</tr>
<tr>
<td>CCLK/</td>
<td>Constant Clock. Provides a clock signal of constant frequency for use by other system modules. When generated by the ISBC 86/12A board, CCLK/ has a period of 108.5 nanoseconds (9.22 MHz) with a 35-65 percent duty cycle.</td>
</tr>
<tr>
<td>DAT0/-DATF/</td>
<td>Data. These 16 bidirectional data lines transmit and receive data to and from the addressed memory location or I/O port. DATF/ is the most-significant bit. For data word operations, DAT0/-DAT7/ is the lower byte and DAT8/-DATF/ is the upper byte.</td>
</tr>
<tr>
<td>INH1/</td>
<td>Inhibit RAM. For system applications, allows ISBC 86/12A board dual port RAM addresses to be overlayed by ROM/PROM or memory mapped I/O devices. This signal has no effect on local CPU access of its dual port RAM.</td>
</tr>
<tr>
<td>INIT/</td>
<td>Initialize. Resets the entire system to a known internal state.</td>
</tr>
<tr>
<td>INTA/</td>
<td>Interrupt Acknowledge. This signal is issued in response to an interrupt request.</td>
</tr>
<tr>
<td>INT0/-INT7/</td>
<td>Interrupt Request. These eight lines transmit Interrupt Requests to the appropriate interrupt handler. INT0 has the highest priority.</td>
</tr>
<tr>
<td>IORC/</td>
<td>I/O Read Command. Indicates that the address of an I/O port is on the Multibus interface address lines and that the output of that port is to be read (placed) onto the Multibus interface data lines.</td>
</tr>
<tr>
<td>IOWC/</td>
<td>I/O Write Command. Indicates that the address of an I/O port is on the Multibus interface address lines and that the contents on the Multibus interface data lines are to be accepted by the addressed port.</td>
</tr>
<tr>
<td>MRDC/</td>
<td>Memory Read Command. Indicates that the address of a memory location is on the Multibus interface address lines and that the contents of that location are to be read (placed) on the Multibus interface data lines.</td>
</tr>
<tr>
<td>MWTC/</td>
<td>Memory Write Command. Indicates that the address of a memory location is on the Multibus interface address lines and that the contents on the Multibus interface data lines are to be written into that location.</td>
</tr>
<tr>
<td>XACK/</td>
<td>Transfer Acknowledge. Indicates that the addressed memory location has completed the specified read or write operation. That is, data has been placed onto or accepted from the Multibus interface data lines.</td>
</tr>
<tr>
<td>Signals</td>
<td>Symbol</td>
</tr>
<tr>
<td>-----------------------------</td>
<td>--------</td>
</tr>
<tr>
<td>AACK/, XACK/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>ADR0/-ADR1/ ADR10/-ADR13/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BCLK/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BHEN/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BPRN/</td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BPRO/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BREQ/</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VOH</td>
</tr>
<tr>
<td></td>
<td>*CL</td>
</tr>
<tr>
<td>BUSY/, CBRQ/, INTROUT/ (OPEN COLLECTOR)</td>
<td>VOL</td>
</tr>
<tr>
<td></td>
<td>VIL</td>
</tr>
<tr>
<td></td>
<td>VIH</td>
</tr>
<tr>
<td></td>
<td>IL&lt;sub&gt;L&lt;/sub&gt;</td>
</tr>
<tr>
<td></td>
<td>IH&lt;sub&gt;H&lt;/sub&gt;</td>
</tr>
<tr>
<td>Signals</td>
<td>Symbol</td>
</tr>
<tr>
<td>-----------------------------</td>
<td>--------</td>
</tr>
<tr>
<td>CCLK(^i)</td>
<td>V(_{OL})</td>
</tr>
<tr>
<td></td>
<td>V(_{OH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>DAT(0) - DAT(F)</td>
<td>V(_{OL})</td>
</tr>
<tr>
<td></td>
<td>V(_{OH})</td>
</tr>
<tr>
<td></td>
<td>V(_{IL})</td>
</tr>
<tr>
<td></td>
<td>V(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>INH(1)</td>
<td>V(_{IL})</td>
</tr>
<tr>
<td></td>
<td>V(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>INIT() (SYSTEM RESET)</td>
<td>V(_{OL})</td>
</tr>
<tr>
<td></td>
<td>V(_{OH})</td>
</tr>
<tr>
<td></td>
<td>V(_{IL})</td>
</tr>
<tr>
<td></td>
<td>V(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>INT(0) - INT(7)</td>
<td>V(_{IL})</td>
</tr>
<tr>
<td></td>
<td>V(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>IORC() , IOWC()</td>
<td>V(_{OL})</td>
</tr>
<tr>
<td></td>
<td>V(_{OH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
<tr>
<td>INTA() , MRDC() , MWTC()</td>
<td>V(_{OL})</td>
</tr>
<tr>
<td></td>
<td>V(_{OH})</td>
</tr>
<tr>
<td></td>
<td>V(_{IL})</td>
</tr>
<tr>
<td></td>
<td>V(_{IH})</td>
</tr>
<tr>
<td></td>
<td>I(_{IL})</td>
</tr>
<tr>
<td></td>
<td>I(_{IH})</td>
</tr>
<tr>
<td></td>
<td>*C(_{L})</td>
</tr>
</tbody>
</table>

*Capacitive load values are approximations.
### Table 2-11. iSBC 86/12A™ Board AC Characteristics (Master Mode)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Minimum (ns)</th>
<th>Maximum (ns)</th>
<th>Description</th>
<th>Remarks</th>
</tr>
</thead>
<tbody>
<tr>
<td>tAS</td>
<td>50</td>
<td></td>
<td>Address setup time to command</td>
<td></td>
</tr>
<tr>
<td>tAH</td>
<td>50</td>
<td></td>
<td>Address hold time from command</td>
<td></td>
</tr>
<tr>
<td>tDS</td>
<td>50</td>
<td></td>
<td>Data setup to write CMD</td>
<td></td>
</tr>
<tr>
<td>tCY</td>
<td>198</td>
<td>202</td>
<td>CPU cycle time</td>
<td>No wait states</td>
</tr>
<tr>
<td>tCMDR</td>
<td>430</td>
<td></td>
<td>Read command width</td>
<td>With 1 wait state</td>
</tr>
<tr>
<td>tCMDW</td>
<td>430</td>
<td></td>
<td>Write command width</td>
<td></td>
</tr>
<tr>
<td>tCSWR</td>
<td>380</td>
<td></td>
<td>Read-to-write command separation</td>
<td>In override mode</td>
</tr>
<tr>
<td>tCSRR</td>
<td>380</td>
<td></td>
<td>Read-to-write command separation</td>
<td>In override mode</td>
</tr>
<tr>
<td>tCSWW</td>
<td>580</td>
<td></td>
<td>Write-to-write command separation</td>
<td>In override mode</td>
</tr>
<tr>
<td>tCSRW</td>
<td>580</td>
<td></td>
<td>Write-to-read command separation</td>
<td>In override mode</td>
</tr>
<tr>
<td>tXACKI</td>
<td>-208</td>
<td></td>
<td>Command to XACK first sample point</td>
<td>In override mode</td>
</tr>
<tr>
<td>tSAM</td>
<td>202</td>
<td>210</td>
<td>Time between XACK samples</td>
<td>In override mode</td>
</tr>
<tr>
<td>tACKRD</td>
<td>115</td>
<td></td>
<td>AACK to valid read data</td>
<td>When AACK is used</td>
</tr>
<tr>
<td>tACKWT</td>
<td>205</td>
<td></td>
<td>AACK to write command inactive</td>
<td>When AACK is used</td>
</tr>
<tr>
<td>tOH</td>
<td>0</td>
<td></td>
<td>Read data hold time</td>
<td></td>
</tr>
<tr>
<td>tDXL</td>
<td>-115</td>
<td></td>
<td>Read data setup to XACK</td>
<td></td>
</tr>
<tr>
<td>tXKH</td>
<td>0</td>
<td></td>
<td>XACK hold time</td>
<td></td>
</tr>
<tr>
<td>tXKD</td>
<td>0</td>
<td></td>
<td>AACK or XACK turn off delay</td>
<td></td>
</tr>
<tr>
<td>tBWS</td>
<td>35</td>
<td>∞</td>
<td>Bus clock low or high intervals</td>
<td>Supplied by system</td>
</tr>
<tr>
<td>tBS</td>
<td>23</td>
<td></td>
<td>BPRN to BCLK setup time</td>
<td></td>
</tr>
<tr>
<td>tOBY</td>
<td>0</td>
<td>55</td>
<td>BCLK to BUSY delay</td>
<td></td>
</tr>
<tr>
<td>tCBRQ</td>
<td>0</td>
<td>60</td>
<td>BCLK to CBRO</td>
<td></td>
</tr>
<tr>
<td>tCBROS</td>
<td>35</td>
<td>60</td>
<td>CBRO to BCLK setup time</td>
<td></td>
</tr>
<tr>
<td>tMOD</td>
<td>35</td>
<td>30</td>
<td>BPRN to BPRO delay</td>
<td></td>
</tr>
<tr>
<td>tDBD</td>
<td>35</td>
<td>40</td>
<td>BCLK/ to bus request</td>
<td></td>
</tr>
<tr>
<td>tDBO</td>
<td>108</td>
<td>109</td>
<td>BCLK/ to bus priority out</td>
<td>From iSBC 86/12A board when terminated</td>
</tr>
<tr>
<td>tBCY</td>
<td>35</td>
<td>74</td>
<td>Bus clock low or high interval</td>
<td>From iSBC 86/12A board when terminated</td>
</tr>
<tr>
<td>tBWI</td>
<td>3000</td>
<td></td>
<td>Initialization width</td>
<td>After all voltages have stabilized</td>
</tr>
</tbody>
</table>

### Table 2-12. iSBC 86/12A™ Board AC Characteristics (Slave Mode)

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Minimum (ns)</th>
<th>Maximum (ns)</th>
<th>Description</th>
<th>Remarks</th>
</tr>
</thead>
<tbody>
<tr>
<td>tAS</td>
<td>50</td>
<td></td>
<td>Address setup to command</td>
<td>From address to command</td>
</tr>
<tr>
<td>tDS</td>
<td>-200</td>
<td></td>
<td>Write data setup to command</td>
<td>Note 1</td>
</tr>
<tr>
<td>tOBBD</td>
<td>993</td>
<td>733</td>
<td>On-board memory cycle delay</td>
<td>No refresh</td>
</tr>
<tr>
<td>tACK</td>
<td>758</td>
<td></td>
<td>Command to XACK</td>
<td>Notes 1 and 2</td>
</tr>
<tr>
<td>tCMD</td>
<td>0</td>
<td></td>
<td>Command width</td>
<td>Note 1</td>
</tr>
<tr>
<td>tAH</td>
<td>0</td>
<td></td>
<td>Address hold time</td>
<td>Acknowledge turnoff delay</td>
</tr>
<tr>
<td>tOHW</td>
<td>0</td>
<td></td>
<td>Write data hold time</td>
<td>Note 3</td>
</tr>
<tr>
<td>tOH</td>
<td>0</td>
<td></td>
<td>Read data hold time</td>
<td>Blocks AACK if tIS &gt; tIS min.</td>
</tr>
<tr>
<td>tXKH</td>
<td>0</td>
<td>65</td>
<td>Acknowledge hold time</td>
<td>Note 4</td>
</tr>
<tr>
<td>tACC</td>
<td>0</td>
<td>653</td>
<td>Read to data valid</td>
<td></td>
</tr>
<tr>
<td>tH</td>
<td>50</td>
<td></td>
<td>Inhibit hold time</td>
<td></td>
</tr>
<tr>
<td>tPW</td>
<td>100</td>
<td></td>
<td>Inhibit pulse width</td>
<td></td>
</tr>
<tr>
<td>tCY</td>
<td>933</td>
<td>555</td>
<td>Cycle time of board</td>
<td></td>
</tr>
<tr>
<td>tRD</td>
<td>30</td>
<td></td>
<td>Refresh delay time</td>
<td></td>
</tr>
<tr>
<td>tDXL</td>
<td>200</td>
<td></td>
<td>Read data setup to XACK</td>
<td></td>
</tr>
<tr>
<td>tIS</td>
<td>50</td>
<td></td>
<td>Command separation</td>
<td></td>
</tr>
<tr>
<td>tID</td>
<td>200</td>
<td></td>
<td>Inhibit setup time</td>
<td></td>
</tr>
</tbody>
</table>

**NOTES:**
1. No refresh, dual port RAM not busy.
2. Maximum = tRD + tOBBD + tACK.
3. Maximum access = tACC + tOBBD + tRD.
4. Maximum cycle = tCY + tOBBD + tRD.
* CBRQ/ timing not shown relative to other bus signals other than BCLK/.

Figure 2-3. Bus Exchange Timing (Master Mode)
Figure 2-4. Bus Exchange Timing (Slave Mode)
2-19. MULTIBUS INTERFACE ARBITRATION

The 8289 Bus Arbiter operates in conjunction with the 8288 Bus controller to interface the 8086 processor to the Multibus interface. The 8289 Bus Arbiter can operate in several modes, depending on how it is jumper wired and the status of Common Bus Request (CBRQ/).

2-20. COMMON BUS REQUEST. Common Bus Request (CBRQ/), a bidirectional Multibus interface signal, allows a bus master to retain control of the system bus without contending for it each transfer cycle, as long as no other master is requesting control of the bus. A bus master requesting control of the bus, but not currently controlling it, asserts CBRQ/. This causes the controlling bus master to relinquish control of the bus when the proper surrender conditions exist. (See table 2-13 for surrender conditions).

The CBRQ/ pins of all the bus master devices that support CBRQ/ are connected together on the ISBC 604/614 modular backplane. When a bus master needs a bus resource, it informs the other bus masters that it is requesting the bus by activating CBRQ/, BREQ/, and/or BPRO/. When the controlling master releases the bus, the bus exchange operates the same as described in paragraph 4-26.

CBRQ/ improves bus access time by allowing a bus master to retain control without contending for it each transfer cycle, as long as no other master is requesting control of the bus.

There are typically two priority resolution schemes used on the system bus: Serial and parallel. When common bus request is used, it operates identically in parallel and serial priority resolution schemes.

2-21. ANY REQUEST. The 8289 Bus Arbiter has a jumper option (ANYRQST) that controls, in conjunction with BPRN/ and CBRQ/, under what conditions the Multibus interface will be surrendered. The following paragraphs describe this option.

When ANYRQST is jumpered to a low level (E130-E131), the bus arbiter that was in control of the Multibus interface will retain control unless one of the following conditions exist.

1. A higher priority bus master requests the Multibus interface (as indicated by the BPRN/ signal going high).

2. The next transfer cycle of the ISBC 86/12A board does not require the use of the Multibus interface, and CBRQ/ is low.

<table>
<thead>
<tr>
<th>Configuration Number</th>
<th>Jumper Conn</th>
<th>CBRQ/</th>
<th>ANYRQST</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>E144-E145</td>
<td>Low</td>
<td>Low</td>
<td>The Bus Arbiter that has control of the Multibus interface will retain control unless a higher priority master activates CBRQ/ or if the next machine cycle does not require the use of the Multibus interface it will be relinquished to a lower priority device.</td>
</tr>
<tr>
<td></td>
<td>E130-E131</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>High</td>
<td>Low</td>
<td></td>
<td>The Bus Arbiter that has control of the Multibus interface, retains control until another Bus Arbiter pulls CBRQ/ low. When CBRQ/ goes low, the conditions are as described above.</td>
</tr>
<tr>
<td>2</td>
<td>E144-E145</td>
<td>Low</td>
<td>High</td>
<td>The Bus Arbiter that has control of the Multibus interface will surrender control to the Bus Arbiter that is pulling CBRQ/ low, regardless of its priority, upon completion of the current bus cycle.</td>
</tr>
<tr>
<td></td>
<td>E129-E130</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>High</td>
<td>High</td>
<td></td>
<td>The Bus Arbiter that has control of the Multibus interface, retains control until another Bus Arbiter pulls CBRQ/ low. When CBRQ/ goes low, the conditions are as described above.</td>
</tr>
<tr>
<td>3</td>
<td>E143-E144*</td>
<td>Low</td>
<td>High</td>
<td>The Bus Arbiter that has control of the Multibus interface will surrender the use of the Multibus interface after each transfer cycle.</td>
</tr>
<tr>
<td></td>
<td>E129-E130*</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Factory default wiring.
When ANYRQST is jumpered to a high level (E129-E130), it permits the Multibus interface to be surrendered to a higher or lower priority bus master as though it were a bus master of higher priority. A lower priority master indicates it is requesting the Multibus interface by activating CBRQ/. When this option is used, the bus master that is in control will surrender the bus as soon as possible.

If the CBRQ/ pin on the 8289 Bus Arbiter is jumpered to ground (E144-E143), removing it from the Multibus interface, and ANYRQST is jumpered to a high level (E129-E130), the Multibus interface is surrendered after each transfer cycle (this is the factory default option).

2-22. JUMPER CONFIGURATIONS. Table 2-13 lists the various jumper configurations for the 8289 Bus Arbiter.

2-23. SERIAL PRIORITY RESOLUTION

In a multiple bus master system, bus contention can be resolved in an iSBC 604 Modular Backplane and Cardcage by implementing a serial priority resolution scheme as shown in figure 2-5. Due to the propagation delay of the BPRO/ signal path, this scheme is limited to a maximum of three bus masters capable of acquiring and controlling the Multibus interface. In the configuration shown in figure 2-5, the bus master installed in slot J2 has the highest priority and is able to acquire control of the Multibus interface at any time because its BPRN/ input is always enabled (tied to ground) through jumpers B and N on the backplane.

If the bus master in slot J2 desires control of the Multibus interface, it drives its BPRO/ output high and inhibits the BPRN/ input to all lower-priority bus masters. When finished using the Multibus interface, the J2 bus master pulls its BPRO/ output low and gives the J3 bus master the opportunity to take control of the Multibus interface. If the J3 bus master does not desire to control the Multibus interface at this time, it pulls its BPRO/ output low and gives the lowest priority bus master in slot J4 the opportunity to assume control of the Multibus interface.

The serial priority scheme can be implemented in a user-designed system bus if the chaining of BPRO/ and BPRN/ signals are wired as shown in figure 2-5.

2-24. PARALLEL PRIORITY RESOLUTION

A parallel priority resolution scheme, using external logic, allows up to 16 bus masters to acquire and control the Multibus interface. Figure 2-6 illustrates

![Figure 2-5. Serial Priority Resolution Scheme](image)

*Pull-up resistor is supplied by the customer.

NOTE: All non CBRQ/ devices must have higher priority. If a non CBRQ/ device is placed at a lower priority, it will not be able to gain control of the Multibus interface.
one method of implementing such a scheme for resolving bus contention in a system containing eight bus masters installed in an iSBC 604/614 Modular Backplane and Cardcage. Notice that the two highest and two lowest priority bus masters are shown installed in the iSBC 604 Modular Backplane and Cardcage.

In the scheme shown in figure 2-6, the priority encoder is a 74148 and the priority decoder is an Intel 8205. Input connections to the priority encoder determine the bus priority, with input 7 having the highest priority and input 0 having the lowest priority. Here, the J3 bus master has the highest priority and the J5 bus master has the lowest priority.

IMPORTANT: In a parallel priority resolution scheme, the BPRO/ output must be disabled on all bus masters. On the iSBC 6/12A board disable the BPRO/ output signal by removing jumper E151-E152. If a similar jumper cannot be removed on the other bus masters, either clip the IC pin that supplies the BPRO/ output signal to the Multibus interface or cut the signal trace.

2-25. POWER FAIL/MEMORY PROTECT CONFIGURATION

A mating connector must be installed in the iSBC 604/614 Modular Cardcage and Backplane to accommodate auxiliary connector P2. (Refer to

---

**Figure 2-6. Parallel Priority Resolution Scheme**

---

NOTES:
1. Refer to paragraph 2-24 regarding the disabling of BPRO/ output.
2. Supplied by customer.
Figure 1-1.) Table 2-2 lists some 60-pin connectors that can be used for this purpose; solder and wirewrap connector types are listed. Table 2-14 correlates the signals and pin numbers on the connector.

Procure the appropriate mating connector for P2 and secure it in place as follows:

a. Position holes in P2 mating connector over mounting holes that are in line with corresponding P1 mating connector.

b. From top of connector, insert two 0.5-inch #4-40 pan head screws down through connector and mounting holes.

c. Install a flat washer and star-type nut on each screw; then tighten the nuts.

When the mating connector for P2 is in place, wire the power fail signals to the appropriate pins of the connector as listed in table 2-14. (The dc characteristics of the signals interfaced via P2 are given in table 2-15.) In a typical system, these signals would be wired as follows:

a. Connect auxiliary signal common and returns for +5V, +5V, and +12V backup batteries to P2 pins 1, 2, 21, and 22.

b. Connect +5V battery input to P2 pins 3 and 4, -5V battery input to P2 pins 7 and 8, and +12V battery input to P2 pins 11 and 12. Remove jumpers W4, W5, and W6.

c. Connect MPRO / input to P2 pin 20.

d. Connect PFIN / input to P2 pin 19; this signal is inverted and applied to the priority jumper matrix. To assign the PFIN / input the highest priority (8086 NMI input), remove jumper E87-E89 and connect jumper E86-E89.

e. Connect AUX RESET / input to P2 pin 38. This signal is usually supplied by a momentary-closure switch mounted on the system enclosure.

f. Connect ALE output signal to P2 pin 32.

2-26. PARALLEL I/O CABLE

Parallel I/O ports C8, CA, and CC, controlled by the Intel 8255A Programmable Peripheral Interface (PPI), are interfaced via edge connector J1. (Refer to figure 1-1.) Pin assignments for connector J1 are listed in table 2-16; dc characteristics of the parallel I/O signals are given in table 2-17. Table 2-2 lists

Table 2-14. Auxiliary Connector P2 Pin Assignments

<table>
<thead>
<tr>
<th>Pin ¹,²</th>
<th>Signal</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>GND</td>
<td>Auxiliary common</td>
</tr>
<tr>
<td>2</td>
<td>GND</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>+5V AUX</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>+5V AUX</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>-5V AUX</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>-5V AUX</td>
<td></td>
</tr>
<tr>
<td>11</td>
<td>+12V AUX</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>+12V AUX</td>
<td></td>
</tr>
<tr>
<td>19</td>
<td>PFIN /</td>
<td>Power Fail Interrupt. This externally generated signal, which is input to the priority interrupt jumper matrix, should normally be connected to the 8086 CPU NMI input.</td>
</tr>
<tr>
<td>20</td>
<td>MPRO /</td>
<td>Memory Protect. This externally generated signal prevents access to RAM during a power failure.</td>
</tr>
<tr>
<td>21</td>
<td>GND</td>
<td>Auxiliary common</td>
</tr>
<tr>
<td>22</td>
<td>GND</td>
<td></td>
</tr>
<tr>
<td>32</td>
<td>ALE</td>
<td>Address Latch Enable. This iSBC 86/12A board activates ALE during T1 of every CPU/ machine cycle. This signal may be used as an auxiliary address latch.</td>
</tr>
<tr>
<td>38</td>
<td>AUX RESET /</td>
<td>Reset. The externally generated signal initiates a power-up sequence; i.e., initializes the iSBC 86/12A board and resets the entire system to a known internal state.</td>
</tr>
</tbody>
</table>

1. All odd-numbered pins (1, 3, 5 . . . 59) are on component side of the board. Pin 1 is the left-most pin when viewed from the component side of the board with the extractors at the top.

2. Cable connector numbering convention may not agree with board connector numbering convention.
Table 2-15. Auxiliary Signal (Connector P2) DC Characteristics

<table>
<thead>
<tr>
<th>Signals</th>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Test Conditions</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALE</td>
<td>V&lt;sub&gt;OL&lt;/sub&gt;</td>
<td>Output Low Voltage</td>
<td>I&lt;sub&gt;OL&lt;/sub&gt; = 8 mA</td>
<td>2.4</td>
<td>0.45</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;OH&lt;/sub&gt;</td>
<td>Output High Voltage</td>
<td>I&lt;sub&gt;OH&lt;/sub&gt; = -1.0 mA</td>
<td>20</td>
<td></td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>*C&lt;sub&gt;L&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td></td>
<td></td>
<td>pF</td>
</tr>
<tr>
<td>PFIN/</td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Low Voltage</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.4V</td>
<td>2.4</td>
<td>0.8</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input High Voltage</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 2.4V</td>
<td></td>
<td>-0.4</td>
<td>mA</td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Current at Low V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.45V</td>
<td>2.0</td>
<td>0.80</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input Current at High V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 5.25V</td>
<td></td>
<td>-6.0</td>
<td>mA</td>
</tr>
<tr>
<td></td>
<td>*C&lt;sub&gt;L&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td>250</td>
<td></td>
<td>µA</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>15</td>
<td></td>
<td>pF</td>
</tr>
<tr>
<td>MPRO/</td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Low Voltage</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.45V</td>
<td>2.0</td>
<td>0.80</td>
<td>V</td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input High Voltage</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 5.25V</td>
<td></td>
<td>-0.25</td>
<td>mA</td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Current at Low V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.45V</td>
<td></td>
<td>10</td>
<td>µA</td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input Current at High V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 5.25V</td>
<td></td>
<td></td>
<td>µF</td>
</tr>
<tr>
<td></td>
<td>*C&lt;sub&gt;L&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td>10</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*Capacitance load values are approximations.

some 50-pin edge connectors that can be used for interface to J1 and J2; flat crimp, solder, and wirewrap connector types are listed.

The transmission path from the I/O source to the iSBC 86/12A board should be limited to 3 meters (10 feet) maximum. The following bulk cable types (or equivalent) are recommended for interfacing with the parallel I/O ports:


b. Cable, flat, 50-conductor (with ground plane), 3M 3380-50.


An Intel iSBC 956 Cable Set, consisting of two cable assemblies, is recommended for parallel I/O interfacing. Both cable assemblies consist of a 50-conductor flat cable with a 50-pin PC connector at one end. When attaching the cable to J1, be sure that the connector is oriented properly with respect to pin 1 on the edge connector. (Refer to the footnotes in table 2-16.)

### 2-27. SERIAL I/O CABLING

Pin assignments and signal definitions for RS232C serial I/O interface are listed in table 2-6. An Intel iSBC 955 Cable Set is recommended for RS232C interfacing. One cable assembly consists of a 25-conductor flat cable with a 26-pin PC connector at one end and an RS232C interface connector at the other end. The second cable assembly includes an RS232C connector at one end and has spade lugs at

<table>
<thead>
<tr>
<th>Pin¹ ²</th>
<th>Function</th>
<th>Pin¹ ²</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Ground</td>
<td>2</td>
<td>Port CA bit 7</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td>4</td>
<td>Port CA bit 6</td>
</tr>
<tr>
<td>5</td>
<td></td>
<td>6</td>
<td>Port CA bit 5</td>
</tr>
<tr>
<td>7</td>
<td></td>
<td>8</td>
<td>Port CA bit 4</td>
</tr>
<tr>
<td>9</td>
<td></td>
<td>10</td>
<td>Port CA bit 3</td>
</tr>
<tr>
<td>11</td>
<td></td>
<td>12</td>
<td>Port CA bit 2</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td>14</td>
<td>Port CA bit 1</td>
</tr>
<tr>
<td>15</td>
<td></td>
<td>16</td>
<td>Port CA bit 0</td>
</tr>
<tr>
<td>17</td>
<td>Ground</td>
<td>18</td>
<td>Port CC bit 3</td>
</tr>
<tr>
<td>19</td>
<td></td>
<td>20</td>
<td>Port CC bit 2</td>
</tr>
<tr>
<td>21</td>
<td></td>
<td>22</td>
<td>Port CC bit 1</td>
</tr>
<tr>
<td>23</td>
<td></td>
<td>24</td>
<td>Port CC bit 0</td>
</tr>
<tr>
<td>25</td>
<td></td>
<td>26</td>
<td>Port CC bit 4</td>
</tr>
<tr>
<td>27</td>
<td></td>
<td>28</td>
<td>Port CC bit 5</td>
</tr>
<tr>
<td>29</td>
<td></td>
<td>30</td>
<td>Port CC bit 6</td>
</tr>
<tr>
<td>31</td>
<td>Ground</td>
<td>32</td>
<td>Port CC bit 7</td>
</tr>
<tr>
<td>33</td>
<td></td>
<td>34</td>
<td>Port C8 bit 7</td>
</tr>
<tr>
<td>35</td>
<td></td>
<td>36</td>
<td>Port C8 bit 6</td>
</tr>
<tr>
<td>37</td>
<td></td>
<td>38</td>
<td>Port C8 bit 5</td>
</tr>
<tr>
<td>39</td>
<td></td>
<td>40</td>
<td>Port C8 bit 4</td>
</tr>
<tr>
<td>41</td>
<td></td>
<td>42</td>
<td>Port C8 bit 3</td>
</tr>
<tr>
<td>43</td>
<td></td>
<td>44</td>
<td>Port C8 bit 2</td>
</tr>
<tr>
<td>45</td>
<td></td>
<td>46</td>
<td>Port C8 bit 1</td>
</tr>
<tr>
<td>47</td>
<td>Ground</td>
<td>48</td>
<td>Port C8 bit 0</td>
</tr>
<tr>
<td>49</td>
<td></td>
<td>50</td>
<td>EXT IN/CLR</td>
</tr>
</tbody>
</table>

1. All odd-numbered pins 1, 3, 5, ..., 49 are on component side of board. Pin 1 is the right-most pin when viewed from the component side of the board with the extractors at the top.

2. Cable connector numbering convention may not agree with board connector numbering convention.
Table 2-17. Parallel I/O Signal (Connector J1) DC Characteristics

<table>
<thead>
<tr>
<th>Signals</th>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Test Conditions</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port C8</td>
<td>V&lt;sub&gt;OL&lt;/sub&gt;</td>
<td>Output Low Voltage</td>
<td>I&lt;sub&gt;OL&lt;/sub&gt; = 20 mA</td>
<td>0.45</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;OH&lt;/sub&gt;</td>
<td>Output High Voltage</td>
<td>I&lt;sub&gt;OH&lt;/sub&gt; = -12 mA</td>
<td>0.95</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Low Voltage</td>
<td></td>
<td>2.0</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input High Voltage</td>
<td></td>
<td>-5.25</td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Current at Low V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.45 V</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;CL&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td>18</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>8255A Driver/Receiver</td>
<td>V&lt;sub&gt;OL&lt;/sub&gt;</td>
<td>Output Low Voltage</td>
<td>I&lt;sub&gt;OL&lt;/sub&gt; = 1.7 mA</td>
<td>0.45</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;OH&lt;/sub&gt;</td>
<td>Output High Voltage</td>
<td>I&lt;sub&gt;OH&lt;/sub&gt; = -200 μA</td>
<td>0.8</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Low Voltage</td>
<td></td>
<td>2.0</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input High Voltage</td>
<td></td>
<td>10</td>
<td>μA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Current at Low V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.45 V</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;CL&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td>18</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>EXT INTR0/</td>
<td>V&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Low Voltage</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 0.4V</td>
<td>0.8</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>V&lt;sub&gt;IH&lt;/sub&gt;</td>
<td>Input High Voltage</td>
<td></td>
<td>2.0</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;IL&lt;/sub&gt;</td>
<td>Input Current at Low V</td>
<td>V&lt;sub&gt;IN&lt;/sub&gt; = 2.4V</td>
<td>-1.0</td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>I&lt;sub&gt;CL&lt;/sub&gt;</td>
<td>Capacitive Load</td>
<td></td>
<td>30</td>
<td>pF</td>
<td></td>
</tr>
</tbody>
</table>

*Capacitive load values are approximations.

the other end; the spade lugs are used to interface to a teletypewriter. (See Appendix A for ASR33 TTY interface instructions.)

For OEM applications where cables will be made for the iSBC 86/12A board, it is important to note that the mating connector for J2 has 26 pins whereas the RS232C connector has 25 pins. Consequently, when connecting the 26-pin mating connector to 25-conductor flat cable, be sure that the cable makes contact with pins 1 and 2 of the mating connector and not with pin 26. Table 2-18 provides pin correspondence between connector J2 and an RS232C connector. When attaching the cable to J2, be sure that the PC connector is oriented properly with respect to pin I on the edge connector. (Refer to the footnotes in table 2-6.)

2-28. BOARD INSTALLATION

**CAUTION**

Always turn off the computer system power supply before installing or removing the iSBC 86/12A board and before installing or removing device interface cables. Failure to take these precautions can result in damage to the board.

NOTE

Inspect the modular backplane and cardcage and ensure that pull-up resistors have been included for pins 27, 28, 30, 32, 33, and 34. Earlier backplanes did not include pull-ups on these pins.

In an iSBC 80 Single Board Computer based system, install the iSBC 86/12A board in any slot that has not been wired for a dedicated function. In an Intellec
Microcomputer Development System, install the iSBC 86/12A board in any odd-numbered slot except slot 1 or any slot of an Intellec Series II Microcomputer Development System. If another module in the Intellec System is to supply the BCLK/ and CCLK/ signals, disconnect E105-E106 and E103-E104 jumpers on the iSBC 86/12A board. Make sure that auxiliary connector P2 (if used) mates with the user-installed mating connector. Attach the appropriate cable assemblies to connectors J1 and J2.
3-1. INTRODUCTION

This chapter lists the dual port RAM, ROM/EPROM, and I/O address assignments, describes the effects of a hardware initialization (power-up and reset), and provides programming information for the following programmable chips:

a. Intel 8251A USART (Universal Synchronous/Asynchronous Receiver/Transmitter) that controls the serial I/O port.

b. Intel 8253 PIT (Programmable Interval Timer) that controls various frequency and timing functions.

c. Intel 8255A PPI (Programmable Peripheral Interface) that controls the three parallel I/O ports.

d. Intel 8259A PIC (Programmable Interrupt Controller) that can handle up to 64 vectored priority interrupts for the on-board microprocessor.

This chapter also discusses the Intel 8086 Microprocessor (CPU) interrupt capability. A complete description of programming with Intel’s assembly language is given in the 8086 Assembly Language Reference Manual, Manual Order No. 9800640.

3-2. FAILSAFE TIMER

The 8086 CPU expects an acknowledge signal to be returned from the addressed I/O or memory device in response to each Read or Write Command. The iSBC 86/12A board includes a Failsafe Timer that is triggered during T1 of every machine cycle. If the Failsafe Timer is enabled by hardware jumper as described in table 2-4, and no acknowledge signal is received within approximately 6 milliseconds after the command is issued, the Failsafe Timer will time out and allow the CPU to exit the wait state. As described in Chapter 2, provision is made so that the Failsafe Timer output (TIME OUT INTR/) can optionally be used to interrupt the CPU.

NOTE

The 8259A must be used in the edge triggered mode with TIME OUT INTR/.

If the Failsafe Timer is not enabled by hardware jumper and an acknowledge signal is not returned for any reason, the CPU will hang up in a wait state. In this situation, the only way to free the CPU is to initialize the system as described in paragraph 3-7.

3-3. MEMORY ADDRESSING

The iSBC 86/12A board includes 32K bytes of dynamic random access memory (RAM) and four IC sockets to accommodate up to 16K bytes of user-installed read-only memory (ROM or EPROM). The iSBC 86/12A board features a dual port RAM access arrangement in which the on-board RAM can be accessed by the on-board 8086 microprocessor (CPU) or by another bus master via the Multibus interface. The ROM/EPROM can be accessed only by the CPU.

The dual port RAM can be accessed by another bus master that currently has control of the Multibus interface. It should be noted that, even though another bus master may be continually accessing the dual port RAM, this does not prevent the CPU from also accessing the dual port RAM. When this situation occurs, memory accesses by the CPU and controlling bus master are interleaved. Such interleaved access will, of course, impose a longer wait state both for the CPU and for the controlling bus master. Dual-port RAM access by another bus master does not interfere with the CPU while it is accessing the on-board ROM/EPROM and I/O devices.

To prevent the on-board CPU from gaining access to the dual port RAM while another bus master is accessing the dual port RAM, the following steps must be taken.

a. The external bus master must do the following steps when accessing dual port RAM:
   assert bus override (lock the bus)
   access dual port RAM
   unlock bus

b. The on-board bus master must do the following steps when accessing dual port RAM:
   assert bus override (lock the bus)
   access Multibus interface (must be unused valid memory)
   access dual port RAM
   unlock bus

Typical subroutines for accessing dual port RAM while preventing the on-board CPU from accessing RAM is shown in table 3-1.
Table 3-1. Typical Dual Port Access Subroutine

```
; CRITXCHG LOCKS OUT THE ON-BOARD CPU WHILE THE DUAL PORT RAM IS ACCESSED.
; SUBROUTINE ASSUMES PPI PORT A IS MODE 0 AND OVERRIDE/ IS JUMPERED TO PORT C BIT 0.
; DPACK ALLOWS OFF-BOARD MULTIMASTER TO LOCK OUT ON-BARD CPU WHILE DUAL PORT
; RAM IS ACCESSED.

; OFF-BOARD PROCESSOR
PUBLIC CRITXCHG
EXTERN DUAL-PORT-SEMA4
CRITXCHG LOCK XCHG DUAL-PORT-SEMA4, AH

; DUAL PORT (ON-BORD) PROCESSOR
PUBLIC DPACK
EXTERN ANY-OFFBOARD-ACCESS

DPACK MOV AL, 00H
OUT QCEH, AL ; RESETS BIT 0 OF PORT C
MOV AL, ANY-OFFBOARD-ACCESS ; IF OFFBOARD PROCESSOR
; HAS LOCKED BUS, WILL
; WAIT HERE UNTIL BUS
; AVAILABLE.

XCHG DUAL-PORT-SEMA4, AH
MOV AL, 01H
OUT QCEH, AL ; SETS BIT 0 OF PORT C
```

3-4. CPU ACCESS

Addresses for CPU access of ROM/EPROM and on-board RAM are provided in Table 3-2. Note that the ROM/EPROM addresses are assigned from the top down of the 1-megabyte address space with the bottom address being determined by the user ROM/EPROM configuration. The on-board RAM addresses are assigned from the bottom up of the 1-megabyte address space.

When the CPU is addressing on-board memory (RAM, ROM, or EPROM), an internal acknowledge signal is automatically generated and imposes one wait state for each ROM/EPROM or I/O operation; two wait states for each RAM read operation; and three wait states for each RAM write operation. When the CPU is addressing system memory via the Multibus interface, the CPU must first gain control of the Multibus interface and, after the Memory Read or Memory Write Command is given, must wait for the Transfer Acknowledge (XACK/) to be received from the addressed memory device. The Failsafe Timer, if enabled, will prevent a CPU hang-up in the event of a memory device equipment failure or a bus failure.

It should be noted in Table 3-2 that it is possible to configure ROM/EPROM such as to create illegal addresses. If an illegal address is used in conjunction with a Memory Write Command to ROM/EPROM, an internal acknowledge signal is generated as though the address was legal and the CPU will continue executing the program. However, in this case, erroneous data will be returned.

3-5. MULTIBUS INTERFACE ACCESS

As described in paragraph 2-13, the iSBC 86/12A board can be configured to permit Multibus interface access of 8K, 16K, 24K, or 32K bytes of on-board RAM. The Multibus interface allows both 8-bit and 16-bit masters to reside in the same system. To accomplish this, the memory is divided into two 8-bit data banks to form one 16-bit word. The banks are organized such that all even bytes are in one bank (DAT0-DAT7) and all odd bytes are in the other bank (DAT8-DATF).

The Byte High Enable (BHEN/) signal controls the odd data byte and, when active, enables the high odd byte (DAT8-/DATF/) onto the Multibus interface. Address bit ADR0/ controls the even data byte and, when active, enables the low byte (DAT0-/DAT7/) onto the Multibus interface. For maximum efficiency, 16-bit word operations must occur on an even byte boundary with BHEN/ active. Address bit ADR0/ is active for all even byte addresses. Odd byte addressing requires two operations to form a 16-bit word.
### Table 3-2. On-Board Memory Addresses (CPU Access)

<table>
<thead>
<tr>
<th>Type</th>
<th>Configuration</th>
<th>Legal Addresses</th>
<th>Illegal Addresses</th>
</tr>
</thead>
<tbody>
<tr>
<td>EPROM</td>
<td>Two 2758 chips</td>
<td>FF8000-FFFFFF</td>
<td>FF000-FFFF</td>
</tr>
<tr>
<td></td>
<td>Four 2758 chips</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Two 2716 chips</td>
<td>FF000-FFFFFF</td>
<td>FE000-FFFFF</td>
</tr>
<tr>
<td></td>
<td>Four 2716 chips</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Two 2732 chips</td>
<td>FE000-FFFFFF</td>
<td>FC000-FDFFFF</td>
</tr>
<tr>
<td></td>
<td>Four 2732 chips</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ROM</td>
<td>Two 2316E chips</td>
<td>FF000-FFFFFF</td>
<td>FE000-FFFFF</td>
</tr>
<tr>
<td></td>
<td>Four 2316E chips</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Two 2332A chips</td>
<td>FE000-FFFFFF</td>
<td>FC000-FDFFFF</td>
</tr>
<tr>
<td></td>
<td>Four 2332A chips</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RAM</td>
<td>Sixteen 2117 chips</td>
<td>0000-07FFF</td>
<td></td>
</tr>
<tr>
<td>iSBC 300 Multimodule RAM</td>
<td>Thirty two 2117 chips</td>
<td>000000-0FFFFF</td>
<td></td>
</tr>
<tr>
<td>iSBC 340 Multimodule PROM</td>
<td>Eight 2732 or 2332 chips</td>
<td>F8000-FFFFF</td>
<td></td>
</tr>
</tbody>
</table>

Byte operations can occur in two ways. The even byte can be accessed by controlling ADR0/, which places the data on the DAT0/-DAT7/ lines. (See figure 3-1A.) To access the odd data bank, which normally is placed on the DAT8/-DATF/ lines, a new data path is defined. The inactive state of ADR0/ and the active state of BHEN/ enable a swap byte buffer that places the odd data bank on DAT0/-DAT7/. (See figure 3-1B.) This permits an 8-bit bus master to access both bytes of a data word by controlling only ADR0/.

Figure 3-1C illustrates how a 16-bit bus master obtains a 16-bit word by a single address on an even byte boundary. Figure 3-1A illustrates how a 16-bit bus master may selectively address an even (low) data byte.

### 3-6. I/O ADDRESSING

The CPU communicates with the on-board programmable chips through a sequence of I/O Read and I/O Write Commands. As shown in table 3-3, each of these chips recognizes four separate hexadecimal I/O addresses that are used to control the various programmable functions. (The I/O address decoder operates on the lower 16 bits and all addresses must be on an even byte boundary.) Where two hexadecimal addresses are listed for a single function, either address may be used. For example, an I/O Read Command to port 00DA or 00DE will read the status of the 8251A USART.

<table>
<thead>
<tr>
<th>REF</th>
<th>MEMORY DATA PATHS</th>
<th>BHEN</th>
<th>ADR0</th>
<th>USED BY BUS MASTERS</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>LOW EVEN BYTES</td>
<td>DAT0/-DAT7/</td>
<td>1</td>
<td>8-BIT, 16-BIT, OR MIXED</td>
</tr>
<tr>
<td></td>
<td>BLOCKS</td>
<td>DAT8/-DATF/</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>HIGH ODD BYTES</td>
<td>DAT0/-DAT7/</td>
<td>1</td>
<td>8-BIT</td>
</tr>
<tr>
<td></td>
<td>BLOCKS</td>
<td>DAT8/-DATF/</td>
<td></td>
<td></td>
</tr>
<tr>
<td>B</td>
<td>LOW EVEN BYTES</td>
<td>DAT0/-DAT7/</td>
<td>1</td>
<td>8-BIT</td>
</tr>
<tr>
<td></td>
<td>BLOCKS</td>
<td>DAT8/-DATF/</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>HIGH ODD BYTES</td>
<td>DAT0/-DAT7/</td>
<td>0</td>
<td>16-BIT</td>
</tr>
<tr>
<td></td>
<td>BLOCKS</td>
<td>DAT8/-DATF/</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 3-1. Dual Port RAM Addressing (Multibus™ Interface Access)
3-7. SYSTEM INITIALIZATION

When power is initially applied to the system, a reset signal is automatically generated that performs the following:

a. The 8086 CPU internal registers are set as follows:
   - PSW = 0000
   - IP = 0000
   - DS = 0000
   - ES = 0000
   - Code Segment Register = FFFF
   - This effectively causes a long JMP to FFFFO.

b. The 8251A USART serial I/O port is set to the "idle" mode, waiting for a set of Command Words to program the desired function.

c. The 8255A PPI parallel I/O ports are set to the input mode.

The 8253 PIT and the 8259A PIC are not affected by the power-up sequence.

The reset signal is also gated onto the Multibus interface to initialize the remainder of the system components to a known internal state.

The reset signal can also be generated by an auxiliary

---

Table 3-3. I/O Address Assignments

<table>
<thead>
<tr>
<th>I/O Address*</th>
<th>Chip Select</th>
<th>Function</th>
</tr>
</thead>
</table>
| 00C0 or 00C4 | 8259A PIC   | Write: ICW1, OCW2, and OCW3  
              |             | Read: Status and Poll        |
| 00C2 or 00C6 |             | Write: ICW2, ICW3, ICW4, OCW1 (Mask)  
              |             | Read: OCW1 (Mask)            |
| 00C8         | 8255A PPI   | Write: Port A (J1)          
              |             | Read: Port A (J1)           |
| 00CA         |             | Write: Port B (J1)          
              |             | Read: Port B (J1)           |
| 00CC         |             | Write: Port C (J1)          
              |             | Read: Port C (J1) or Status |
| 00CE         |             | Write: Control              
              |             | Read: None                  |
| 00D0         | 8253 PIT    | Write: Counter 0 (Load Count ÷ N)  
              |             | Read: Counter 0             |
| 00D2         |             | Write: Counter 1 (Load Count ÷ N)  
              |             | Read: Counter 1             |
| 00D4         |             | Write: Counter 2 (Load Count ÷ N)  
              |             | Read: Counter 2             |
| 00D6         |             | Write: Control              
              |             | Read: None                  |
| 00DB or 00DC | 8251A USART | Write: Data (J2)            
              |             | Read: Data (J2)             |
| 00DA or 00DE |             | Write: Mode or Command      
              |             | Read: Status                |

*Odd addresses (i.e., 00C1, 00C3, ... 00DD) are illegal.
RESET switch. Pressing and releasing the RESET switch produces the same effect as the power-up reset described above.

3-8. 8251A USART PROGRAMMING

The USART converts parallel output data into virtually any serial output data format (including IBM Bi-Sync) for half- or full-duplex operation. The USART also converts serial input data into parallel data format.

Prior to starting transmitting or receiving data, the USART must be loaded with a set of control words. These control words, which define the complete functional operation of the USART, must immediately follow a reset (internal or external). The control words are either a Mode instruction or a Command instruction.

3-9. MODE INSTRUCTION FORMAT

The Mode instruction word defines the general characteristics of the USART and must follow a reset operation. Once the Mode instruction word has been written into the USART, sync characters or command instructions may be inserted. The Mode instruction word defines the following:

a. For Sync Mode:
   (1) Character length
   (2) Parity enable
   (3) Even/odd parity generation and check
   (4) External sync detect (not supported by the iSBC 86/12A board)
   (5) Single or double character sync

b. For Async Mode:
   (1) Baud rate factor (X1, X16, or X64)
   (2) Character length
   (3) Parity enable
   (4) Even/odd parity generation and check
   (5) Number of stop bits

Instruction word and data transmission formats for synchronous and asynchronous modes are shown in figures 3-2 through 3-5.

3-10. SYNC CHARACTERS

Sync characters are written to the USART in the synchronous mode only. The USART can be programmed for either one or two sync characters; the format of the sync characters is at the option of the programmer.

Figure 3-2. USART Synchronous Mode Instruction Word Format

Figure 3-3. USART Synchronous Mode Transmission Format
3-11. COMMAND INSTRUCTION FORMAT

The Command instruction word shown in figure 3-6 controls the operation of the addressed USART. A Command instruction must follow the mode and/or sync words. Once the Command instruction is written, data can be transmitted or received by the USART.

It is not necessary for a Command instruction to precede all data transactions; only those transmissions that require a change in the Command instruction. An example is a change in the enable transmit or enable receive bus. Command instructions can be written to the USART at any time after one or more data operations.

After initialization, always read the chip status and check for the TXRDY bit prior to writing either data or command words to the USART. This ensures that any prior input is not overwritten and lost. Note that issuing a Command instruction with bit 6 (IR) set will return the USART to the Mode instruction format.

3-12. RESET

To change the Mode instruction word, the USART must receive a Reset command. The next word written to the USART after a Reset command is assumed to be a Mode instruction. Similarly, for sync mode, the next word after a Mode instruction is assumed to be one or more sync characters. All control words written into the USART after the Mode instruction (and/or the sync character) are assumed to be Command instructions.

3-13. ADDRESSING

The USART chip uses Port 00D8 or 00DC to read and write I/O data; Port 00DA or 00DE is used to write mode and command words and read the USART status. (Refer to table 3-3.)
3-14. INITIALIZATION

A typical USART initialization and I/O data sequence is presented in figure 3-7. The USART chip is initialized in four steps:

a. Reset USART to Mode instruction format.

b. Write Mode instruction word. One function of mode word is to specify synchronous or asynchronous operation.

c. If synchronous mode is selected, write one or two sync characters as required.

d. Write Command instruction word.

To avoid spurious interrupts during USART initialization, disable the USART interrupt. This can be done by either masking the appropriate interrupt request input at the 8259A PIC or by disabling the 8086 microprocessor interrupts by executing a CLI instruction.

First, reset the USART chip by writing a Command instruction to Port 00DA (or 00DE). The Command instruction must have bit 6 set (IR = 1); all other bits are immaterial.

NOTE

This reset procedure should be used only if the USART has been completely initialized, or the initialization procedure has reached the point that the USART is ready to receive a Command word. For example, if the reset command is written when the initialization sequence calls for a sync character, then subsequent programming will be in error.
Next write a Mode instruction word to the UART. (See figures 3-2 through 3-5.) A typical subroutine for writing both Mode and Command instructions is given in table 3-4.

If the UART is programmed for the synchronous mode, write one or two sync characters depending on the transmission format.

Finally, write a Command instruction word to the UART. Refer to figure 3-6 and table 3-4.

IMPORTANT: During initialization, the 8251A UART requires a minimum recovery time of 6.5 microseconds (16 UART clock cycles) between back-to-back writes in order to set up its internal registers. This recovery time can be satisfied by the CPU performing several dummy instructions between the back-to-back writes to the 8251A UART to create a minimum delay of 6.5 microseconds. The following example will create a delay of approximately 7.2 microseconds.

```assembly
MOV AL,04EH ;UART MODE WORD
OUT ODAH,AL ;FIRST UART WRITE
MOV CX,3 ;DELAY
TAG: LOOP TAG ;DELAY
MOV AL,037H ;UART COMMAND WORD
OUT ODAH,AL ;SECOND UART WRITE
```

This precaution applies only to the UART initialization and does not apply otherwise.

3-15. OPERATION

Normal operating procedures use data I/O read and write, status read, and Command instruction write operations. Programming and addressing procedures for the above are summarized in following paragraphs.

NOTE

After the UART has been initialized, always check the status of the TXRDY bit prior to writing data or writing a new command word to the UART. The TXRDY bit must be true to prevent overwriting and subsequent loss of command or data words. The TXRDY bit is inactive until initialization has been completed; do not check TXRDY until after the command word, which concludes the initialization procedure, has been written.

Prior to any operating change, a new command word must be written with command bits changed as appropriate. (Refer to figure 3-6 and table 3-4.)

3-16. DATA INPUT/OUTPUT. For data receive or transmit operations, perform a read or write, respectively, to the UART. Table 3-5 and 3-6 provide examples of typical character read and write subroutines.

During a normal transmit operation, the UART generates a Transmit Ready (TXRDY) signal that indicates that the UART is ready to accept a data character for transmission. TXRDY is automatically reset when the CPU loads a character into the UART.

Similarly, during a normal receive operation, the UART generates a Receive Ready (RXRDY) signal that indicates that a character has been received and is ready for input to the CPU. RXRDY is automatically reset when a character is read by the CPU.

---

Table 3-4. Typical UART Mode or Command Instruction Subroutine

```assembly
PUBLIC CMD2,51INT EXTRN STAT0

CMD2: PUSH AX
PUSH F
CALL STAT0
AND AL,1
JZ LP
POPF
POPF
51INT: OUT ODAH,AL
RET
END

;CHECK TXRDY
;TXRDY MUST BE TRUE
;ENTER HERE FOR INITIALIZATION
```

3-8
Table 3-5. Typical USART Data Character Read Subroutine

```
PUBLIC     RX1, RXA1
EXTERN     STAT0

RX1:       CALL    STAT0
           AND     AL, 2
           JZ      RX1
           RET
RXA1:      IN      AL, 0D8H
           RET
           END
```

Table 3-6. Typical USART Data Character Write Subroutine

```
PUBLIC     TX1, TXA1
EXTERN     STAT0

TX1:       PUSH    AX
TX11:      CALL    STAT0
           AND     AL, 1
           JZ      TX11
           POP     AX
TXA1:      OUT     0D8H, AL
           RET
           END
```

The TXRDY and RXRDY outputs of the USART are available at the priority interrupt jumper matrix. If, for instance, TXRDY and RXRDY are input to the 8259A PIC, the PIC resolves the priority and interrupts the CPU. TXRDY and RXRDY are also available in the status word. (Refer to paragraph 3-17.)

3-17. STATUS READ. The CPU can determine the status of a serial I/O port by issuing an I/O Read Command to the upper port (00DA or 00DE) of the USART chip. The format of the status word is shown in figure 3-8. A typical status read subroutine is given in table 3-7.

3-18. 8253 PIT PROGRAMMING

A 22.1184-MHz crystal oscillator supplies the basic clock frequency for the programmable chips. This clock frequency is divided by 9, 18, and 144 to produce three jumper-selectable clocks: 2.46 MHz, 1.23 MHz, and 153.6 kHz. These clocks are available for input to Counter 0, Counter 1, and Counter 2 of the 8253 PIT. The default (factory connected) and optional jumpers for selecting the clock inputs to the three counters are listed in table 2-4.

Default jumpers connect the output of Counter 2 to the TXC and RXC inputs of the 8251A USART. Jumpers are included so that Counters 0 and 1 can provide real-time interrupts to the 8259A PIC.

Before programming the 8253 PIT, ascertain the input clock frequency and the output function of each of the three counters. These factors are determined and established by the user during installation.

3-19. MODE CONTROL WORD AND COUNT

All three counters must be initialized prior to their use. The initialization for each counter consists of two steps:
Figure 3-8. USART Status Read Format

a. A mode control word (figure 3-9) is written to the control register for each individual counter.

b. A down-count number is loaded into each counter; the down-count number is in one or two 8-bit bytes as determined by the mode control word.

The mode control word (figure 3-9) does the following:

a. Selects counter to be loaded.

b. Selects counter operating mode.

c. Selects one of the following four counter read/load functions:

(1) Counter latch (for stable read operation).
(2) Read or load most-significant byte only.
(3) Read or load least-significant byte only.
(4) Read or load least-significant byte first, then most-significant byte.

d. Sets counter for either binary or BCD count.

The mode control word and the count register bytes for any given counter must be entered in the following sequence:

Table 3-7. Typical USART Status Read Subroutine

```
:STAT0 READS STATUS FROM USART.
;DESTROYS-AL.
PUBLIC STAT0
STATO: IN AL,0DEH ;;GET STATUS
        ;;STAT0 READS STATUS FROM USART.
        ;;DESTROYS-AL.
        PUBLIC STAT0
        STATO: IN AL,0DEH ;;GET STATUS
        RET
END
```
Figure 3-9. PIT Mode Control Word Format

- Mode control word.
- Least-significant count register byte.
- Most-significant count register byte.

As long as the above procedure is followed for each counter, the chip can be programmed in any convenient sequence. For example, mode control words can be loaded first into each of three counters per chip, followed by the least-significant byte, most-significant byte, etc. Figure 3-10 shows the two programming sequences described above.

Since all counters in the PIT chip are downcounters, the value loaded in the count registers is decremented. Loading all zeroes into a count register results in a maximum count of $2^{16}$ for binary numbers or $10^4$ for BCD numbers.

When a selected count register is to be loaded, it must be loaded with the number of bytes programmed in the mode control word. One or two bytes can be loaded, depending on the appropriate down count. These two bytes can be programmed at any time following the mode control word, as long as the correct number of bytes is loaded in order.
The count mode selected in the control word controls the counter output. As shown in Figure 3-9, the PIT chip can operate in any of six modes:

a. **Mode 0: Interrupt on terminal count.** In this mode, Counters 0 and 1 can be used for auxiliary functions, such as generating real-time interrupt intervals. After the count value is loaded into the count register, the counter output goes low and remains low until the terminal count is reached. The output then goes high until either the count register or the mode control register is reloaded.

b. **Mode 1: Programmable one-shot.** In this mode, the output of Counter 0 and/or Counter 1 will go low on the count following the rising edge of the GATE input from Port 00CC (assuming Port 00CC jumpers are so configured). The output will go high on the terminal count. If a new count value is loaded while the output is low, it will not affect the duration of the one-shot pulse until the succeeding trigger. The current count can be read at any time without affecting the one-shot pulse. The one-shot is retriggerable, hence the output will remain low for the full count after any rising edge of the gate input.

c. **Mode 2: Rate generator.** In this mode, the output of Counter 0 and/or Counter 1 will be low for one period of the clock input. The period from one output pulse to the next equals the number of input counts in the count register. If the count register is reloaded between output pulses, the present period will not be affected but the subsequent period will reflect the new value. The gate input, when low, will force the output high. When the gate input goes high, the counter will start from the initial count. Thus, the gate input can be used to synchronize the counter. When Mode 2 is set, the output will remain high until after the count register is loaded; thus, the count can be synchronized by software.

d. **Mode 3: Square wave generator.** Mode 3, which is the primary operating mode for Counter 2, is used for generating Baud rate clock signals. In this mode, the counter output remains high until one-half of the count value in the count register has been decremented (for even numbers). The output then goes low for the other half of the count. If the value in the count register is odd, the counter output is high for \((N + 1)/2\) counts, and low for \((N - 1)/2\) counts.
a. Mode 4: Software triggered strobe. After this mode is set, the output will be high. When the count is loaded, the counter begins counting. On terminal count, the output will go low for one input clock period and then go high again. If the counter register is reloaded between output pulses, the present count will not be affected, but the subsequent period will reflect the new value. The count will be inhibited while the gate input is low. Reloading the count register will restart the counting for the new value.

f. Mode 5: Hardware triggered strobe. Counter 0 and/or Counter 1 will start counting on the rising edge of the gate input and the output will go low for one clock period when the terminal count is reached. The counter is retriggerable. The output will not go low until the full count after the rising edge of the gate input.

Table 3-8 provides a summary of the counter operation versus the gate inputs. The gate inputs to Counters 0 and 1 are tied high by default jumpers; these gates may optionally be controlled by Port CC. The gate input to Counter 2 is not optionally controlled.

<table>
<thead>
<tr>
<th>Modes</th>
<th>Signal Status</th>
<th>Low Or Going Low</th>
<th>Rising</th>
<th>High</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Disables counting</td>
<td>—</td>
<td>Enables counting</td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>—</td>
<td>1) Initiates counting 2) Resets output after next clock</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>1) Disables counting 2) Sets output immediately high</td>
<td>Initiates counting</td>
<td>Enables counting</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>1) Disables counting 2) Sets output immediately high</td>
<td>Initiates counting</td>
<td>Enables counting</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>Disables counting</td>
<td>—</td>
<td>Enables counting</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>—</td>
<td>Initiates counting</td>
<td>—</td>
<td></td>
</tr>
</tbody>
</table>

3-20. ADDRESSING

As listed in table 3-3, the PIT uses four I/O addresses. Addresses 00D0, 00D2, and 00D4, respectively, are used in loading and reading the count in Counters 0, 1, and 2. Address 00D6 is used in writing the mode control word to the desired counter.

3-21. INITIALIZATION

To initialize the PIT chip, perform the following:

a. Write a mode control word for Counter 0 to 00D6. Note that all mode control words are written to 00D6, since the mode control word must specify which counter is being programmed. (Refer to figure 3-9.) Table 3-9 provides a sample subroutine for writing mode control words to all three counters.

b. Assuming the mode control word has selected a 2-byte load, load least-significant byte of count into Counter 0 at 00D0. (Count value to be loaded is described in paragraphs 3-24 through 3-26.) Table 3-10 provides a sample subroutine for loading 2-byte count value.

c. Load most-significant byte of count into Counter 0 at 00D0.

NOTE

Be sure to enter the downcount in two bytes if the counter was programmed for a two-byte entry in the mode control word. Similarly, enter the downcount value in BCD if the counter was so programmed.

d. Repeat steps b and c for Counters 1 and 2.

3-22. OPERATION

The following paragraphs describe operating procedures for a counter read, clock frequency divide/ratio selection, and interrupt timer counter selection.

3-23. COUNTER READ. There are two methods that can be used to read the contents of a particular counter. The first method involves a simple read of the desired counter. The only requirement with this method is that, in order to ensure stable count reading, the desired counter must be inhibited by controlling its gate input. Only Counter 0 and Counter 1 can be read using this method because the gate input to Counter 2 is not controllable.

The second method allows the counter to be read "on-the-fly." The recommended procedure is to use a mode control word to latch the contents of the count
Table 3-9. Typical PIT Control Word Subroutine

```
PUBLIC INTTMR

INTTMR:  MOV    AL,30H   ;MODE CONTROL WORD FOR COUNTER 0
          OUT    0D8H,AL
          MOV    AL,70H   ;MODE CONTROL WORD FOR COUNTER 1
          OUT    0D8H,AL
          MOV    AL,B6H   ;MODE CONTROL WORD FOR COUNTER 2
          OUT    0D8H,AL
          RET
          END
```

Table 3-10. Typical PIT Count Value Load Subroutine

```
PUBLIC LOAD0

LOAD0:   MOV    AL,C    ;GET LSB
          OUT    0D0H,AL
          MOV    AL,CH   ;GET MSB
          OUT    0D0H,AL
          RET
          END
```

Register; this ensures that the count reading is accurate and stable. The latched value of the count can then be read.

**NOTE**

If a counter is read during the down count, it is mandatory to complete the read procedure; that is, if two bytes were programmed to the counter, then two bytes must be read before any other operations are performed with that counter.

To read the count of a particular counter, proceed as follows (a typical counter read subroutine is given in table 3-11):

a. Write counter register latch control word (figure 3-11) to Port 00D6. Control word specifies desired counter and selects counter latching operation.

b. Perform a read operation of desired counter; refer to table 3-3 for counter addresses.

**NOTE**

Be sure to read one or two bytes, whichever was specified in the initialization mode control word. For two bytes, read in the order specified.

3-24. CLOCK FREQUENCY/DIVIDE RATIO SELECTION. Table 2-4 lists the default and optional timer input frequencies to Counters 0 through 2. The timer input frequencies are divided by the counters to generate TMR0 INTR OUT (Counter 0), TMR1 INTR OUT (Counter 1), and the 8251A Baud Rate Clock (Counter 2).
If the binary equivalent of count value \( N = 256 \) is loaded into Counter 2, then the output frequency is 4800 Hz, which is the desired clock rate for synchronous mode operation. Note that counter 2 must be in binary mode.

3-26. Asynchronous Mode. In the asynchronous mode, the TXC and/or RXC rates equal the Baud rate times one of the following multipliers: \( X_1 \), \( X_{16} \), or \( X_{64} \). Therefore, the count value is determined by:

\[
N = \frac{C}{BM}
\]

where \( N \) is the count value,

\( B \) is the desired Baud rate,

\( M \) is the Baud rate multiplier (1, 16, or 64),

and

\( C \) is 1.23 MHz, the input clock frequency.

Thus, for a 4800 Baud rate, the required count value \( (N) \) is:

\[
N = \frac{1.23 \times 10^6}{4800 \times 16} = 16.
\]

If the binary equivalent of count value \( N = 16 \) is loaded into Counter 2, then the output frequency is 4800 \( \times 16 \) Hz, which is the desired clock rate for asynchronous mode operation. Count values \( (N) \) versus rate multiplier \( (M) \) for each Baud rate are listed in table 3-12.

**NOTE**

During initialization, be sure to load the count value \( (N) \) into the appropriate counter and the Baud rate multiplier \( (M) \) into the 8251A USART.

3-27. RATE GENERATOR/INTERVAL TIMER. Table 3-13 shows the maximum and minimum rate generator frequencies and timer intervals for Counters 0 and 1 when these counters,

### Table 3-11. Typical PIT Counter Read Subroutine

```assembly
;READ1 READS COUNTER 1 ON-THE-FLY INTO CX. MSB IN CH, LSB IN CL.
;DESTROYS-AL,CX.

PUBLIC READ1

READ1:
    MOV AL,40H
    OUT 0DCH,AL
    IN AL,0D2H
    MOV CL,A
    IN AL,0D2H
    MOV CH,AL
    RET

END
```
Table 3-12. PIT Count Value Vs Rate Multiplier for Each Baud Rate

<table>
<thead>
<tr>
<th>Baud Rate: (B)</th>
<th>*Count Value (N) For</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>M = 1</td>
</tr>
<tr>
<td>75</td>
<td>16384</td>
</tr>
<tr>
<td>110</td>
<td>11171</td>
</tr>
<tr>
<td>150</td>
<td>8192</td>
</tr>
<tr>
<td>300</td>
<td>4096</td>
</tr>
<tr>
<td>600</td>
<td>2048</td>
</tr>
<tr>
<td>1200</td>
<td>1024</td>
</tr>
<tr>
<td>2400</td>
<td>512</td>
</tr>
<tr>
<td>4800</td>
<td>256</td>
</tr>
<tr>
<td>9600</td>
<td>128</td>
</tr>
<tr>
<td>19200</td>
<td>64</td>
</tr>
<tr>
<td>38400</td>
<td>32</td>
</tr>
<tr>
<td>76800</td>
<td>16</td>
</tr>
</tbody>
</table>

*Count Values (N) assume clock is 1.23 MHz. Double Count Values (N) for 2.46 MHz clock. Count Values (N) and Rate Multipliers (M) are in decimal.

respectively, have 1.23-MHz and 153.6-kHz clock inputs. The table also provides the maximum and minimum generator frequencies and time intervals that may be obtained by connecting Counters 0 and 1 in series.

3-28. INTERRUPT TIMER. To program an interval timer for an interruption terminal count, program the appropriate timer for the correct operating mode (Mode 0) in the control word. Then load the count value (N), which is derived by:

\[ N = TC \]

where

- \( N \) is the count value for Counter 1,
- \( T \) is the desired interrupt time interval in seconds, and
- \( C \) is the internal clock frequency (Hz).

Table 3-13. PIT Rate Generator Frequencies and Timer Intervals

<table>
<thead>
<tr>
<th></th>
<th>Single Timer¹ (Counter 0)</th>
<th>Single Timer² (Counter 1)</th>
<th>Dual Timer³ (0 and 1 in Series)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Rate Generator (frequency)</td>
<td>Minimum</td>
<td>Maximum</td>
<td>Minimum</td>
</tr>
<tr>
<td></td>
<td>18.75 Hz</td>
<td>614.4 kHz</td>
<td>2.344 Hz</td>
</tr>
<tr>
<td>Real-Time Interrupt (interval)</td>
<td>1.63 ( \mu \text{sec} )</td>
<td>53.3 msec</td>
<td>13 ( \mu \text{sec} )</td>
</tr>
</tbody>
</table>

NOTES:
1. Assuming a 1.23-MHz clock input.
2. Assuming a 153.6-kHz clock input.
3. Assuming Counter 0 has 1.23-MHz clock input.

Table 3-14 shows the count value (N) required for several time intervals (T) that can be generated for Counters 0 and 1.

Table 3-14. PIT Time Intervals Vs Timer Counts

<table>
<thead>
<tr>
<th>( T ) (( \mu \text{sec} ))</th>
<th>( N^* )</th>
</tr>
</thead>
<tbody>
<tr>
<td>10 ( \mu \text{sec} )</td>
<td>12</td>
</tr>
<tr>
<td>100 ( \mu \text{sec} )</td>
<td>123</td>
</tr>
<tr>
<td>1 ( \text{msec} )</td>
<td>1229</td>
</tr>
<tr>
<td>10 ( \text{msec} )</td>
<td>12288</td>
</tr>
<tr>
<td>50 ( \text{msec} )</td>
<td>61440</td>
</tr>
</tbody>
</table>

*Count Values (N) assume clock is 1.23 MHz. Count Values (N) are in decimal.

3-29. 8255A PPI PROGRAMMING

The three parallel I/O ports interfaced to connector J1 are controlled by an Intel 8255A Programmable Peripheral Interface chip. Port A includes bidirectional data buffers and Ports B and C include IC sockets for installation of either input terminators or output drivers depending on the user's application.

Default jumpers set the Port A bidirectional data buffers to the output mode. Optional jumpers allow the bidirectional data buffers to be set to the input mode or allow any one of the eight Port C bits to selectively set the Port A bidirectional data buffers to the input or output mode.

Table 2-7 lists the various operating modes for the three PPI parallel I/O ports. Note that Port A (00C8) can be operated in Modes 0, 1, or 2; Port B (00CA) can be operated in Mode 0 or 1; Port C (00CC) can be operated in Mode 0.
3-30. CONTROL WORD FORMAT

The control word format shown in figure 3-12 is used to initialize the PPI to define the operating mode of the three ports. Note that the ports are separated into two groups. Group A (control word bits 3 through 6) defines the operating mode for Port A (00C8) and the upper four bits of Port C (00CC). Group B (control word bits 0 through 2) defines the operating mode for Port B (00CA) and the lower four bits of Port C (00CC). Bit 7 of the control word controls the mode set flag.

3-31. ADDRESSING

The PPI uses four consecutive even addresses (00C8 through 00CE) for data transfer, obtaining the status of Port C (00CC), and for port control. (Refer to table 3-3.)

3-32. INITIALIZATION

To initialize the PPI, write a control word to port 00CE. Refer to figure 3-12 and table 3-15 and assume that the control word is 92 (hexadecimal). This initializes the PPI as follows:

a. Mode Set Flag active
b. Port A (00C8) set to Mode 0 Input
c. Port C (00CC) upper set to Mode 0 Output
d. Port B (00CA) set to Mode 0 Input
e. Port C (00CC) lower set to Mode 0 Output

3-33. OPERATION

After the PPI has been initialized, the operation is completed by simply performing a read or a write to the appropriate port.

3-34. READ OPERATION. A typical read subroutine for Port A is given in table 3-16.

3-35. WRITE OPERATION. A typical write subroutine for Port C is given in table 3-17. As shown in figure 3-13, any of the Port C bits can be selectively set or cleared by writing a control word to Port 00CE.

3-36. 8259A PIC PROGRAMMING

The 8259A PIC functions as an overall manager in an interrupt-driven system environment. It accepts requests from the peripheral equipment, determines which of the incoming requests is of the highest importance (priority), ascertains whether the incoming request has a higher priority value than the level currently being serviced, and may issue an interrupt to the CPU based on this determination.

The on-board master 8259A PIC handles up to eight vectored priority interrupts and has the capability of expanding the number of priority interrupts by cascading one or more of its interrupt input lines with slave 8259A PIC's. (Refer to paragraph 2-14.)

The basic functions of the PIC are to (1) resolve the priority of interrupt requests, (2) issue a single interrupt request to the CPU based on that priority, and (3) send the CPU a vectored restart address for servicing the interrupting device.

Figure 3-12. PPI Control Word Format
Table 3-15. Typical PPI Initialization Subroutine

```plaintext
;INTPAR Initializes Parallel Port Modes.
;DESTRYS-AL.

PUBLIC INTPAR

INTPAR:
MOVAL, 92H ;Mode Word to PPI Port A&B IN,C OUT
OUT0CEH, AL
RET
END
```

Table 3-16. Typical PPI Port Read Subroutine

```plaintext
;AREAD Reads a Byte from Port A into Reg AL.
;DESTRYS-AL.

AREAD

AREAD: INAL, 0C8H ;Get Byte
RET
END
```

Table 3-17. Typical PPI Port Write Subroutine

```plaintext
;COUT Outputs a Byte from Reg AL to Port C.
;USES-AL; DESTRYS-NOTHING.

PUBLIC COUT

COUT:
OUT0CCH, AL ;Output Byte
RET
END
```

3-37. INTERRUPT PRIORITY MODES

The PIC can be programmed to operate in one of the following modes:

a. Nested Mode
b. Fully Nested Mode
c. Automatic Rotating Mode
d. Specific Rotating Mode
e. Special Mask Mode
f. Poll Mode

3-38. NESTED MODE. In this mode, the PIC input signals are assigned a priority from 0 through 7. The PIC operates in this mode unless specifically programmed otherwise. Interrupt IR0 has the highest priority and IR7 has the lowest priority. When an interrupt is acknowledged, the highest
priority request is available to the CPU. Lower priority interrupts are inhibited; higher priority interrupts will be able to generate an interrupt that will be acknowledged if the CPU has enabled its own interrupt input through software. The End-Of-Interrupt (EOI) command from the CPU is required to reset the PIC for the next interrupt.

3-39. FULLY NESTED MODE. This mode is used only when one or more PIC's are slaved to the master PIC, in which case the priority is conserved within the slave PIC's.

The operation in the fully nested mode is the same as the nested mode except as follows:

a. When an interrupt from a slave PIC is being serviced, that particular PIC is not locked out from the master PIC priority logic. That is, further interrupts of higher priority within this slave PIC will be recognized and the master PIC will initiate an interrupt to the CPU.

b. When exiting the interrupt service routine, the software must check to determine if another interrupt is pending from the same slave PIC. This is done by sending an End-Of-Interrupt (EOI) command to the slave PIC and then reading its In-Service (IS) register. If the IS register is clear (empty), an EOI command is sent to the master PIC. If the IS register is not clear (interrupt pending), no EOI command should be sent to the master PIC.

3-40. AUTOMATIC ROTATING MODE. In this mode, the interrupt priority rotates. Once an interrupt on a given input is serviced, that interrupt assumes the lowest priority. Thus, if there are a number of simultaneous interrupts, the priority will rotate among the interrupts in numerical order. For example, if interrupts IR4 and IR6 request service simultaneously, IR4 will receive the highest priority. After service, the priority level rotates so that IR4 has the lowest priority and IR5 assumes the highest priority. In the worst case, seven other interrupts are serviced before IR4 again has the highest priority. Of course, if IR4 is the only request, it is serviced promptly. The priority shifts when the PIC receives an End-Of-Interrupt (EOI) command.

3-41. SPECIFIC ROTATING MODE. In this mode, the software can change interrupt priority by specifying the bottom priority, which automatically sets the highest priority. For example, if IR5 is assigned the bottom priority, IR6 assumes the highest priority. In specific rotating mode, the priority can be rotated by writing a Specific Rotate at EOI (SEOI) command to the PIC. This command contains the BCD code of the interrupt being serviced; that interrupt is reset as the bottom priority. In addition, the bottom priority interrupt can be fixed at any time by writing a command word to the appropriate PIC.

3-42. SPECIAL MASK MODE. One or more of the eight interrupt request inputs can be individually masked during the PIC initialization or at any subsequent time. If an interrupt is masked while it is being serviced, lower priority interrupts are inhibited. There are two ways to enable the lower priority interrupts:

a. Write an End-Of-Interrupt (EOI) command.
b. Set the Special Mask Mode.

The Special Mask Mode is useful when one or more interrupts are masked. If for any reason an input is masked while it is being serviced, the lower priority interrupts are disabled. However, it is possible to enable the lower priority interrupt with the Special Mask Mode. In this mode, the lower priority lines are enabled until the Special Mask Mode is reset. Higher priorities are not affected.

3-43. POLL MODE. In this mode the CPU internal Interrupt Enable flip-flop is clear (interrupts disabled) and a software subroutine is used to initiate a Poll command. In the Poll Mode, the addressed PIC treats an I/O Read Command as an interrupt acknowledge, sets its In-Service flip-flop if there is a pending interrupt request, and reads the priority level. This mode is useful if there is a common service routine for several devices.

3-44. STATUS READ

Interrupt request inputs are handled by the following three internal PIC registers:

a. Interrupt Request Register (IRR), which stores all interrupt levels that are requesting service.
b. In-Service Register (ISR), which stores all interrupt levels that are being serviced.
c. Interrupt Mask Register (IMR), which stores the interrupt request lines which are masked.

These registers can be read by writing a suitable command word and then performing a read operation.

3-45. INITIALIZATION COMMAND WORDS

The on-board master PIC and each slave PIC requires a separate initialization sequence to work in a
The initialization sequence requires three Initialization Command Words (ICW’s) for a single PIC system and requires four ICW’s for a master PIC with one to eight slaves. The ICW formats are shown in figure 3-14.

The first Initialization Command Word (ICW1), which is required in all modes of operation, consists of the following:

- a. Bits 0 and 4 are both 1’s and identify the word as ICW1 for an 8086 CPU operation.
- b. Bit 1 denotes whether or not the PIC is employed in a multiple PIC configuration. For a single master PIC configuration (no slaves), bit 1=1; for a master with one or more slaves, bit 1=0.

**NOTE**

Bit 1=0 when programming a slave PIC.

- c. Bit 3 establishes whether the interrupts are requested by a positive-true level input or requested by a low-to-high input. This applies to all input requests handled by the PIC. In other words, if bit 3=1, a low-to-high transition is required to request an interrupt on any of the eight levels handled by the PIC.

The second Initialization Command Word (ICW2) represents the vectoring byte (identifier) and is required by the 8086 CPU during interrupt processing. ICW2 consists of the following:

- a. Bits D3-D7 (A11-A15) represent the five most significant bits of the vector byte. These are supplied by the programmer.
- b. Bits D0-D2 represent the interrupt level requesting service. These bits are provided by the 8259A during interrupt processing. These bits should be programmed as 0’s when initializing the PIC.

**NOTE**

The 8086 CPU multiplies the vector byte by four. This value is then used by the CPU as the vector address.

Table 3-18 lists the vector byte contents for interrupts IR0-IR7.

<table>
<thead>
<tr>
<th>Table 3-18. Interrupt Vector Byte</th>
</tr>
</thead>
<tbody>
<tr>
<td>D7</td>
</tr>
<tr>
<td>-----</td>
</tr>
<tr>
<td>IR7</td>
</tr>
<tr>
<td>IR6</td>
</tr>
<tr>
<td>IR5</td>
</tr>
<tr>
<td>IR4</td>
</tr>
<tr>
<td>IR3</td>
</tr>
<tr>
<td>IR2</td>
</tr>
<tr>
<td>IR1</td>
</tr>
<tr>
<td>IR0</td>
</tr>
</tbody>
</table>
The third Initialization Command Word (ICW3) is required only if bit 1=0 in ICW1, specifying that multiple PIC's are used; i.e., one or more PIC's are slaved to the on-board master PIC. ICW3 programming can be in one of two formats: master mode format and slave mode format.

a. For master mode, the D0-D7 (S0-S7) bits correspond to the IR0-IR7 bits of the master PIC. For example, if a slave PIC is connected to the master PIC IR3 input, code bit 3=1.

b. For a slave PIC, the D0-D2 (ID0-ID2) bits identify the master IR line that the slave PIC is connected to. The slave compares its cascade input (generated by the master PIC) with these bits and, if they are equal, the slave releases an interrupt vector byte upon the reception of the second INTA during interrupt processing. For example, if a slave is connected to the master interrupt line IR5, code bits ID0-ID2=101.

The fourth Initialization Command Word (ICW4), which is required for all modes of operation, consists of the following:

a. Bit D0 is a 1 to identify that the word is for an 8086 CPU.

b. Bit D1 (AEI) programs the end-of-interrupt function. Code bit 1=1 if an EOI is to be automatically executed (hardware). Code Bit 1=0 if an EOI command is to be generated by software before returning from the service routine.

c. Bit D2 (M/S) specifies if ICW4 is addressed to a master PIC or a slave PIC. For example, code bit 2=1 in ICW4 for the master PIC. If bit D3 (BUF) is zero, bit D2 has no function.

d. Bit D3 (BUF) specifies whether the 8259A is operating in the buffered or nonbuffered mode. For example, code bit 3=1 for buffered mode.

The master PIC in an iSBC 86/12A, with or without slaves, must be operated in the buffered mode.

e. Bit D4 (FNM) programs the nested or fully nested mode. (Refer to paragraphs 3-38 and 3-39).

In summary, three or four ICW's are required to initialize the master and each slave PIC. Specifically

- Master PIC — No Slaves
  
  ICW1
  ICW2
  ICW4

- Master PIC — With Slave(s)
  
  ICW1
  ICW2
  ICW3
  ICW4

- Each Slave PIC
  
  ICW1
  ICW2
  ICW3
  ICW4

3-46. OPERATION COMMAND WORDS

After being initialized, the master and slave PIC's can be programmed at any time for various operating modes. The Operation Command Word (OCW) formats are shown in figure 3-15 and discussed in paragraph 3-49.

3-47. ADDRESSING

The master PIC uses Port 00C0 or 00C2 to write initialization and operation command words and Port 00C4 or 00C6 to read status, poll, and mask bytes. Addresses for the specific functions are provided in table 3-3.

Slave PIC's, if employed, are accessed via the Multibus interface and their addresses are determined by the hardware designer.

3-48. INITIALIZATION

To initialize the PIC's (master and slaves), proceed as follows (table 3-19 provides a typical PIC initialization subroutine for a PIC operated in the non-bus vectored mode; tables 3-20 and 3-21 are typical master PIC and slave PIC initialization subroutines for the bus vectored mode):

a. Disable system interrupts by executing a CLI (Clear Interrupt Flag) instruction.

b. Initialize master PIC by writing ICW's in the following sequence:

1. Write ICW1 to Port 00C0 and ICW2 to Port 00C2.

2. If slave PIC's are used, write ICW3 and ICW4 to Port 00C2. If no slave PIC's are used, omit ICW3 and write ICW4 only to Port 00C2.

c. Initialize each slave PIC by writing ICW's in the following sequence: ICW1, ICW2, ICW3, and ICW4.
Figure 3-15. PIC Operation Control Word Formats
### Table 3-19. Typical PIC Initialization Subroutine (NBV Mode)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADMX9</td>
<td>INITIALIZES THE PIC, A 32-BYTE ADDRESS BLOCK BEGINNING WITH 00020H IS SET UP FOR INTERRUPT SERVICE ROUTINES.</td>
</tr>
<tr>
<td>PIC MASK IS SET, DISABLING ALL PIC INTERRUPTS.</td>
<td></td>
</tr>
<tr>
<td>PIC IS IN FULLY NESTED MODE, NON-AUTO EOI.</td>
<td></td>
</tr>
<tr>
<td>USES SMASK, DESTROYS A.</td>
<td></td>
</tr>
</tbody>
</table>

| PUBLIC INT59 |
| EXTRN SMASK |
| INT59: MOV AL,13H |
| OUT 0C0H,AL ;ICW1 TO PIC |
| MOV AL,08H |
| OUT 0C2H,AL ;ICW2 TO PIC |
| MOV AL,1DH |
| OUT 0C2H,AL ;ICW4 TO PIC |
| MOV AL,0FFH |
| CALL SPROCESS |
| RET |
| END |

### Table 3-20. Typical Master PIC Initialization Subroutine (BV Mode)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADMXMA</td>
<td>Initializes MASTER PIC WITH A SINGLE SLAVE ATTACHED</td>
</tr>
<tr>
<td>TO THE B LEVEL INTERRUPT INPUT.</td>
<td></td>
</tr>
<tr>
<td>PIC MASK IS SET WITH ALL PIC INTERRUPTS DISABLED.</td>
<td></td>
</tr>
<tr>
<td>MASTER PIC IS FULLY NESTED, NON-AUTO EOI.</td>
<td></td>
</tr>
<tr>
<td>USES SMASK, DESTROYS AL.</td>
<td></td>
</tr>
</tbody>
</table>

| PUBLIC INTMA |
| EXTRN SPROCESS |
| INTMA: MOV AL,11H ;ICW1 |
| MOV AL,08H |
| OUT 0C0H,AL ;ICW2 |
| OUT 0C2H,AL |
| MOV AL,01H ;ICW3 |
| OUT 0C2H,AL |
| MOV AL,1DH ;ICW4 |
| OUT 0C2H,AL |
| MOV AL,0FFH |
| CALL SPROCESS |
| RET |
| END |

### Table 3-21. Typical Slave PIC Initialization Subroutine (BV Mode)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADMXSL</td>
<td>Initializes A SLAVE PIC LOCATED AT ADDRESS BLOCK</td>
</tr>
<tr>
<td>BEGINNING WITH 00040H.</td>
<td></td>
</tr>
<tr>
<td>PIC IS FULLY NESTED, NON-AUTO EOI.</td>
<td></td>
</tr>
<tr>
<td>PIC IS IDENTIFIED AS SLAVE 0.</td>
<td></td>
</tr>
<tr>
<td>USES SETI, DESTROYS AL.</td>
<td></td>
</tr>
</tbody>
</table>

| PUBLIC INTSL |
| INTSL: MOV AL,11H ;ICW1 |
| MOV AL,10H ;ICW2 |
| OUT 0C0H,AL |
| MOV AL,00H ;ICW3 |
| OUT 0C2H,AL |
| MOV AL,19H ;ICW4 |
| OUT 0C2H,AL |
| RET |
| END |
d. Enable system interrupts by executing an STI (Set Interrupt Flag) instruction.

**NOTE**

Each PIC independently operates in the nested mode (paragraph 3-38) after initialization and before an Operation Control Word (OCW) programs it otherwise.

3-49. OPERATION

After initialization, the master PIC and slave PIC's can independently be programmed at any time by an Operation Command Word (OCW) for the following operations:

a. Auto-rotating priority.
b. Specific rotating priority.
c. Status read of Interrupt Request Register (IRR).
d. Status read of In-Service Register (ISR).
e. Interrupt mask bits are set, reset, or read.
f. Special mask mode set or reset.

Table 3-22 lists details of the above operations. Note that an End-Of-Interrupt (EOI) or a Special End-Of-Interrupt (SEOI) command is required at the end of each interrupt service routine to reset the ISR. The EOI command is used in the fully nested and auto-rotating priority modes and the SEOI command, which specifies the bit to be reset, is used in the specific rotating priority mode. Tables 3-23 through 3-27 provide typical subroutines for the following:

a. Read IRR (table 3-23).
b. Read ISR (table 3-24).

<table>
<thead>
<tr>
<th>Operation</th>
<th>Procedure</th>
</tr>
</thead>
<tbody>
<tr>
<td>Auto-Rotating Priority Mode</td>
<td>To set:</td>
</tr>
<tr>
<td></td>
<td>In OCW2, write a Rotate Priority at EOI command (A0H) to Port 00C0.</td>
</tr>
<tr>
<td></td>
<td>Terminate interrupt and rotate priority:</td>
</tr>
<tr>
<td></td>
<td>In OCW2, write EOI command (20H) to Port 00C0.</td>
</tr>
<tr>
<td>Specific Rotating Priority Mode</td>
<td>To set:</td>
</tr>
<tr>
<td></td>
<td>In OCW2, write a Rotate Priority at SEOI command in the following format to Port 00C0:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>1 1 1 0 0 L2 L1 L0</td>
</tr>
<tr>
<td></td>
<td>BCD of IR line to be reset and/or put into lowest priority.</td>
</tr>
<tr>
<td></td>
<td>To terminate interrupt and rotate priority:</td>
</tr>
<tr>
<td></td>
<td>In OCW2, write an SEOI command in the following format to Port 00C0:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>0 1 1 0 0 L2 L1 L0</td>
</tr>
<tr>
<td></td>
<td>BCD of ISR flip-flop to be reset.</td>
</tr>
<tr>
<td></td>
<td>To rotate priority without EOI:</td>
</tr>
<tr>
<td></td>
<td>In OCW2, write a command word in the following format to Port 00C0:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>1 1 0 0 0 L2 L1 L0</td>
</tr>
<tr>
<td></td>
<td>BCD of bottom priority IR line.</td>
</tr>
</tbody>
</table>
### Table 3-22. PIC Operation Procedures (Continued)

<table>
<thead>
<tr>
<th>Operation</th>
<th>Procedure</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Interrupt Request Register (IRR) Status</strong></td>
<td>The IRR stores a &quot;1&quot; in the associated bit for each IR input line that is requesting an interrupt. To read the IRR (refer to footnote):</td>
</tr>
<tr>
<td></td>
<td>(1) Write $0A_{H}$ to Port $00C0$.</td>
</tr>
<tr>
<td></td>
<td>(2) Read Port $00C0$. Status is as follows:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>IR Line: 7 6 5 4 3 2 1 0</td>
</tr>
<tr>
<td><strong>In-Service Register (ISR) Status</strong></td>
<td>The ISR stores a &quot;1&quot; in the associated bit for priority inputs that are being serviced. The ISR is updated when an EOI command is issued. To read the ISR (refer to footnote):</td>
</tr>
<tr>
<td></td>
<td>(1) Write $0B_{H}$ to Port $00C0$.</td>
</tr>
<tr>
<td></td>
<td>(2) Read Port $00C0$. Status is as follows:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>IR Line: 7 6 5 4 3 2 1 0</td>
</tr>
<tr>
<td></td>
<td>Be sure to reset ISR bit at end-of-interrupt when in the following modes:</td>
</tr>
<tr>
<td></td>
<td>Auto-Rotating (both types) and Special Mask. To reset ISR in OCW2, write:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>0 1 1 0 0 L2 L1 L0</td>
</tr>
<tr>
<td></td>
<td>BCD identifies bit to be reset.</td>
</tr>
<tr>
<td><strong>Interrupt Mask Register</strong></td>
<td>To set mask bits in OCW1, write the following mask byte to Port $00C2$:</td>
</tr>
<tr>
<td></td>
<td>D7 D6 D5 D4 D3 D2 D1 D0</td>
</tr>
<tr>
<td></td>
<td>IR Bit Mask: M7 M6 M5 M4 M3 M2 M1 M0</td>
</tr>
<tr>
<td></td>
<td>1 = Mask Set, 0 = Mask Reset</td>
</tr>
<tr>
<td><strong>Special Mask Mode</strong></td>
<td>The Special Mask Mode enables desired bits that have been previously masked; lower priority bits are also enabled.</td>
</tr>
<tr>
<td></td>
<td>To set, write $6B_{H}$ to Port $00C0$.</td>
</tr>
<tr>
<td></td>
<td>To reset, write $4B_{H}$ to Port $00C0$.</td>
</tr>
</tbody>
</table>

**NOTE:**

If previous operation was addressed to same register, it is not necessary to rewrite the OCW.
c. Set mask register (table 3-25).
d. Read mask register (table 3-26).
e. Issue EOI command (table 3-27).

3-50. HARDWARE INTERRUPTS

The 8086 CPU includes two hardware interrupt inputs, NMI and INTR, classified as non-maskable and maskable, respectively.

3-51. NON-MASKABLE INTERRUPT (NMI)

The NMI input has the higher priority of the two interrupt inputs. A low-to-high transition on the NMI input will be serviced at the end of the current instruction or between whole moves of a block-type instruction. Worst-case response to NMI is during a multiply, divide, or variable shift instruction.

When the NMI input goes active, the CPU performs the following:

a. Pushes the Flag registers onto the stack (same as a PUSHF instruction).

b. If not already clear, clears the Interrupt Flag (same as a CLI instruction); this disables maskable interrupts.

c. Transfers control with an indirect call through vector location 00008.

The NMI input is intended only for catastrophic error handling such as a system power failure. Upon completion of the service routine, the CPU automatically restores the flags and returns to the main program.

Table 3-23. Typical PIC Interrupt Request Register Read Subroutine

```
;RR0 READS PIC INTERRUPT REQUEST REG.
;DESTROYS-AL.
PUBLIC RR0

RR0:  MOV  AL,0AH ;OCW3 RR INSTRUCTION TO PIC
      OUT  0C0H,AL
      IN   AL,0C0H
      RET END
```

Table 3-24. Typical PIC In-Service Register Read Subroutine

```
;RIS0 READS PIC IN-SERVICE REGISTER.
;DESTROYS-A.
PUBLIC RIS0

RIS0:  MOV  AL,0BH ;OCW3 RIS INSTRUCTION TO PIC
       OUT  0C0H,AL
       IN   AL,0C0H
       RET END
```

Table 3-25. Typical PIC Set Mask Register Subroutine

```
;SMASK STORES AL REG INTO PIC MASK REG.
;A ONE MASKS OUT AN INTERRUPT, A ZERO ENABLES IT.
;USES-AL, DESTROYS-THING.
PUBLIC SMASK

SMASK:  OUT  0C2H,AL
        RET END
```
Table 3-26. Typical PIC Mask Register Read Subroutine

```
;RMASK READS PIC MASK REG INTO AL REG.
;DESTROYS-AL.

PUBLIC    RMASK

RMASK: IN AL,OC2H
RET
END
```

Table 3-27. Typical PIC End-Of-Interrupt Command Subroutine

```
;EOI ISSUES END-OF-INTERRUPT TO PIC.
;DESTROYS-AL.

PUBLIC    EOI

EOI: MOV AL,20H
OUT 0COH,AL ;;NON-SPECIFIC EOI
RET
END
```

3-52. MASKABLE INTERRUPT (INTR)

The INTR input has the lower priority of the two interrupt inputs. A high level on the INTR input will be serviced at the end of the current instruction or at the end of a whole move for a block-type instruction.

When INTR goes active, the CPU performs the following (assuming the Interrupt Flag is set):

a. Issues two acknowledge signals; upon receipt of the second acknowledge signal, the interrupting device (master or slave PIC) will respond with a one-byte interrupt identifier.

b. Pushes the Flag registers onto the stack (same as a PUSHF instruction).

c. Clears the Interrupt Flag, thereby disabling further maskable interrupts.

d. Multiplies by four (4) the binary value (X) contained in the one-byte identifier from the interrupting device.

e. Transfers control with an indirect call through location 4X.

Upon completion of the service routine, the CPU automatically restores its flags and returns to the main program.

3-53. MASTER PIC BYTE IDENTIFIER. The master (on-board) PIC responds to the second acknowledge signal from the CPU only if the interrupt request is from a non-slaved device; i.e., a device that is connected directly to one of the master PIC IR inputs. The master PIC has eight IR inputs numbered IR0 through IR7, which are identified by a 3-bit binary number. Thus, if an interrupt request occurs on IR5, the master PIC responds to the second acknowledge signal from the CPU by outputting the byte 000001012 (05H). The CPU multiplies this value by four and transfers control with an indirect call through 000101002 (14H).

3-54. SLAVE PIC BYTE IDENTIFIER. Each slave PIC is initialized with a 3-bit identifier (ID) in ICW3. These three bits will form a part of the byte identifier transferred to the CPU in response to the second acknowledge signal.

The slave PIC requests an interrupt by driving the associated master PIC IR line. The master PIC, in turn, drives the CPU INTR input high and the CPU outputs the first of two acknowledge signals. In response to the first acknowledge signal, the master PIC outputs a 3-bit binary code to slaved PIC's; this 3-bit code allows the appropriate slave PIC to respond to the second acknowledge signal from the CPU.

Assume that the slave PIC has the ID code 1112 assigned in ICW3, and that the device requesting service is driving the IR2 line (010). Thus, in response to the second acknowledge signal, the slave PIC outputs 001110102 (3Ah). The CPU multiplies this value by four and transfers control with an indirect call through 111010002 (E8H).
CHAPTER 4
PRINCIPLES OF OPERATION

4-1. INTRODUCTION

This chapter provides a functional description and a circuit analysis of the iSBC 86/12A Single Board Computer. Figures 4-1 and 4-2, located at the end of this chapter, are simplified foldout logic diagrams that illustrate the functional interface between the 8086 microprocessor (CPU) and the on-board facilities and between the CPU and the system facilities via the Multibus interface. Also shown in figure 4-2 is the Dual Port Control Logic that allows the iSBC 86/12A board to function in a master/slave relationship with the Multibus interface to allow another bus master to access the on-board dual port RAM.

4-2. FUNCTIONAL DESCRIPTION

A brief description of the functional blocks of logic comprising the iSBC 86/12A board is given in the following paragraphs. An operational circuit analysis is given beginning with paragraph 4-13.

4-3. CLOCK CIRCUITS

The clock circuit composed of A16, A17, and A18 is stabilized by a 22.1184-MHz crystal. This circuit provides nominal 153.6-kHz, 1.23-MHz, and 2.46-MHz optional clock frequencies to the 8253 Programmable Interval Timer (PIT); 2.46-MHz Baud rate clock to the 8251A Universal Synchronous/Asynchronous Receiver/Transmitter (USART); and a 22.12-MHz clock frequency to the Dual Port Control Logic and RAM Controller.

The clock circuit composed of A80 and A63 is stabilized by an 18.432-MHz crystal. This circuit divides the crystal frequency by two to provide the nominal 9.22-MHz Bus Clock (BCLK/) and Constant Clock (CCLK/) signals to the Multibus interface. The BCLK/ signal is also used by the 8289 Bus Arbitter. Removable jumpers are provided to allow this clock circuit to be disabled if some other source supplies BCLK/ and CCLK/ to the Multibus interface.

Clock generator A38 is stabilized by a 15-MHz crystal and provides a nominal 5-MHz clock to CPU A39, Status Decoder A81, Bus Arbitter A82, and Bus Command Decoder A83. Clock A38 also provides a reset signal on power-up and when commanded to do so by an optional signal supplied via auxiliary connector P2. The RESET signal initializes the system as well as certain iSBC 86/12A board components to a known internal state.

4-4. CENTRAL PROCESSOR UNIT

The 8086 Microprocessor (CPU A39), which is the heart of the single board computer, performs the system processing functions and generates the address and control signals required to access memory and I/O devices. Control signals S0, S1, and S2 are driven by the CPU and decoded by Status Decoder A81 to develop the various signals required to control the board. The CPU AD0-AD15 pins are used to multiplex the 16-bit input/output data and the lower 16-bits of the address. During the first part of a transfer cycle, for example, the lower 16-bits (AD0-AD15) and the upper 4-bits (AD16-AD19) are strobed into Address Latch A40/41/57 by the Address Latch Enable (ALE) signal. (The ALE signal is derived by decoding S0, S1, and S2.) The Address Latch outputs form the 20-bit address bus AB0-AB13; i.e., AB0-ABF and AB10-AB13. During the remainder of the transfer cycle, the AD0-AD15 pins of the CPU are used to form the 16-bit data bus AD0-ADF.

4-5. INTERVAL TIMER

The 8253 Programmable Interval Timer (PIT) includes three independently controlled counters that provide optional (jumper selectable) timing inputs to the on-board I/O devices and the CPU interrupts. The clock frequency of 2.46 MHz, 1.23 MHz, or 153.6 kHz, which is derived from the clock circuit composed of A16, A17, and A18, provides the basic timing input.

Counter 2 provides timing for the serial I/O port (8251A USART). This counter, in conjunction with the USART, can provide programmable Baud rates from 110 to 9600. Counter 0 can be used in one of two ways: (1) as a clock generator it can be buffered to provide an external user-defined clock or (2) as an interval timer to generate a CPU interrupt. Counter 1, which is the system interval timer and can also generate an interrupt, has a range of 1.6 microseconds to 853.3 milliseconds. If longer times are needed, Counters 0 and 1 can be cascaded to provide a single timer with a maximum delay of over 7 hours.
4-6. SERIAL I/O

The 8251A USART provides RS232C compatibility and is configured as a data terminal. Synchronous or asynchronous mode, character size, parity bits, stop bits, and Baud rates are all programmable. Data, clocks and control lines to and from connector J2 are buffered.

4-7. PARALLEL I/O

The 8255A Programmable Peripheral Interface provides 24 programmable I/O lines. Two IC sockets are provided so that, depending on the application, TTL drivers or I/O terminators may be installed to complete the interface to connector J1. The 24 lines are grouped into three ports of eight lines each; these ports can be programmed to be simple I/O ports, strobed I/O ports with handshaking, or one port can be programmed as a bidirectional port with control lines. The iSBC 86/12A board includes various optional functions controlled by the parallel I/O lines such as an RS232C interface line, timer gate control lines, bus override, strobed I/O port interrupts, and one Multibus interface interrupt.

4-8. INTERRUPT CONTROLLER

The 8259A Programmable Interrupt Controller (PIC) handles up to eight vectored priority interrupts. The 8259A PIC provides the capability to expand the number of priority interrupts by cascading each interrupt line with another 8259A PIC. (Refer to figure 2-2.) This is done by programming the master PIC (the one on the iSBC 86/12A board) so that an interrupt line (e.g., IR3) is connected to a slave PIC (the one interfaced to the master PIC via the Multibus interface). If an IR3 interrupt is sensed by the master PIC, it will allow the slave PIC to send the restart vector address to the CPU. Each interrupt line into the master PIC can be individually programmed to be a non-bus vectored (NBV) interrupt line (master PIC generates the restart address) or a bus vectored (BV) interrupt (cascaded to a slave PIC which generates the restart address). The iSBC 86/12A board can handle eight on-board or single Multibus interface interrupt lines (an interrupt line which does not have a slave PIC connected to it) or, with the aid of eight slave PIC's, expand the number of interrupts to 64. All 64 interrupts must be processed through the slave PIC's and must therefore be external to the iSBC 86/12A board.

There are nine jumper-selectable interrupt sources: serial I/O port (2), parallel I/O interface (2), timers (2), external via J1 (1), power fail (1), and Multibus interface time out (1). The eight Multibus interface interrupt lines (INT0/-INT7/) can be connected to the master PIC to provide 8 to 64 bus interrupt levels. The user can map interrupt sources into interrupt levels by hardware jumpers. The iSBC 86/12A board can also generate one Multibus interface interrupt that is controlled by an 8255A PPI output bit.

NOTE

The 86/12A board must be capable of Multibus interface access when using interrupts.

4-9. ROM/EPROM CONFIGURATION

IC sockets A28, A29, A46, and A47 are provided for user installation of ROM or EPROM chips; jumpers are provided to accommodate either 2K, 4K, or 8K chips. The ROM/EPROM address space is located at the top of the 1-megabyte memory space because the 8086 CPU branches to FFFFF0 after a reset. Starting addresses for the different ROM/EPROM configurations are F0000 (using 2K chips), F8000 (using 4K chips), and FC000 (using 8K chips).

When the iSBC 340 Multimodule EPROM board is installed, the starting address is F8000.

4-10. RAM CONFIGURATION

The iSBC 86/12A board includes 32K bytes of read/write memory composed of sixteen 2117 Dynamic RAM chips and an 8202A RAM Controller. If the iSBC 300 Multimodule RAM board is installed, the read/write memory is expanded to 64k bytes of memory composed of thirty-two 2117 dynamic RAM chips and an 8202A RAM Controller.

The Dual Port Control Logic interfaces the RAM with the Multibus interface so that the iSBC 86/12A board can perform as a slave RAM device when not acting as a bus master. This dual port is designed to maximize the CPU throughput by defaulting control to the CPU when not in demand. Each time a bus master generates a memory request to the dual port RAM via the Multibus interface, the RAM must be taken away from the CPU (when the CPU is not using it). When the slave request is completed, the control of the RAM returns to the CPU.

The dual port consists of CPU address and data buffers and decoder; bidirectional address and data bus (Multibus interface) drivers; slave RAM address decoder/translator; control logic; and the RAM and RAM controller.
The CPU address and data buffers separate the on-
board bus (I/O and ROM/EPROM) from the dual
port bus. On-board RAM addresses (as seen by the
CPU) are (assigned from the bottom up) 00000-
07FFF. If the iSBC 300 Multimodule RAM board is
installed, the on-board RAM addresses are 00000-
0FFFF.

The address bus drivers and data bus drivers
separate the dual port bus from the Multibus
interface. The slave RAM address decoder is
separate from the CPU RAM address decoder to
provide independent Multibus interface address
selection that can be located throughout the
1-megabyte address space. The slave RAM address
is selected by specifying the base address and
memory size. The base address can be on any 8K
boundary (16K boundary if iSBC 300 Multimodule
RAM board is installed) with the exception that the
memory space cannot extend across a 128K boun-
dary. The memory size specifies the amount of Dual
Port RAM accessible by the Multibus interface and is
switch selectable in 8K increments (16K increments
if iSBC 300 Multimodule RAM board is installed).
This provides the capability to reserve sections of the
dual port RAM for use only by the CPU and frees up
the address space. Regardless of what base address
is selected, the slave RAM address is mapped into an
on-board RAM address (as seen by the CPU). (Refer
to figure 2–1.)

4-11. BUS STRUCTURE

The iSBC 86/12A board architecture is organized
around a three-bus hierarchy: the on-board bus, the
dual port bus, and the Multibus interface. (Refer to
figure 4–3.) Each bus can communicate only within
itself and an adjacent bus, and each bus can operate
independently of each other. The performance of the
iSBC 86/12A board is directly related to which bus it
must go to perform an operation; that is, the closer
the bus to the on-board bus, the better the performance.

The iSBC 86/12A board operates at a 5-MHz CPU
 cycle and requires one to three wait states for all on-
board system accesses. (A RAM write requires three
wait states; a RAM read requires two wait states;
and a ROM/EPROM or I/O operation requires one
wait state.) However, the pipeline effect of the 8086
CPU effectively “hides” these wait states.

The core of the iSBC 86/12A board bus architecture is
the on-board bus, which connects the CPU to all on-
board I/O devices, ROM/EPROM, and the dual port
RAM bus. Activity on this bus does not require
control of the outer buses, thus permitting indepen-
dent execution of on-board activities. Activities at
this level require no bus overhead and operate at
maximum board performance.

The next bus in the hierarchy is the dual port
bus. This bus controls the dynamic RAM and
communicates with the on-board bus and the
Multibus interface. The dual port bus can be in one of
three states:

a. State 1 — On-board bus is controlling it but not
   using it (not busy).

b. State 2 — On-board bus is controlling it and
   using it (busy).

c. State 3 — Multibus interface is controlling it
   and using it (busy).

State 1 is the idle state of the dual port bus and is left
in control of the on-board bus to minimize delays
when the CPU needs it. When the on-board bus
requires the dual port bus to access RAM, the dual
port bus control logic will go from State 1 to State
2. (If the dual port bus is busy, it will wait until it is
not busy.) Activity at this level requires a minimum
of bus overhead and the RAM performance is
designed to equal that of on-board activity (if the dual
port bus is not busy when the on-board bus requests
it). The dual port bus control logic returns to State 1
when the CPU completes its operation. This level of
bus activity operates independently of the Multibus
interface activity (if the Multibus interface does not
need the dual port bus).

When the Multibus interface requests the dual port
bus, the control logic goes from State 1 to 3 (it will wait
if busy) in about 150 nanoseconds and, upon
completion, returns to State 1. The Multibus inter-
face use of the dual port bus is independent of the on-
board activity.

When the on-board bus needs the Multibus interface,
it must go through the dual port bus to the Multibus
interface. The on-board bus uses the dual port bus
only to communicate with the Multibus interface and
leaves the dual port bus in State 1. Activity at this
level requires a minimum 200-nanosecond overhead
for Multibus interface exchange.

Figure 4–3. Internal Bus Structure
4-12. MULTIBUS INTERFACE

The iSBC 86/12A board is completely Multibus interface compatible and supports both 8-bit and 16-bit operations. The Multibus interface includes the Bus Arbiter A82, Bus Command Decoder A83, bidirectional address bus and data bus drivers, and interrupt drivers and receivers. The Bus Arbiter allows the iSBC 86/12A board to operate as a bus master in the system in which the 8086 CPU can request the Multibus interface when a bus resource is needed.

4-13. CIRCUIT ANALYSIS

The schematic diagram for the iSBC 86/12A board is given in figure 5–2. The schematic diagram consists of 11 sheets, each of which includes grid coordinates. Signals that traverse from one sheet to another are assigned grid coordinates at both the signal source and signal destination. For example, the grid coordinates 2ZB1 locate a signal source (or signal destination as the case may be) on sheet 2 zone B1.

Both active-high and active-low signals are used. A signal mnemonic that ends with a virgule (e.g., DAT7/) denotes that the signal is active low (≤0.4V). Conversely, a signal mnemonic without a virgule (e.g., ALE) denotes that the signal is active high (≥2.0V).

Figures 4-1 and 4-2 at the end of this chapter are simplified logic diagrams of the input/output, interrupt, and memory sections. These diagrams will be helpful in understanding both the addressing scheme and the internal bus structure of the board.

4-14. INITIALIZATION

When power is applied in a start-up sequence, the contents of the 8086 CPU program counter, program status word, interrupt enable flip-flop, etc., are subject to random factors and cannot be predicted. For this reason, a power-up sequence is used to set the CPU, Bus Arbiter, and I/O ports to a known internal state.

When power is initially applied to the iSBC 86/12A board, capacitor C26 (2ZD6) begins to charge through resistor R9. The charge developed across C26 is sensed by a Schmitt trigger, which is internal to Clock Generator A38. The Schmitt trigger converts the slow transition appearing at pin 11 into a clean, fast-rising synchronized RESET signal at pin 10. The RESET signal is inverted by A48–6 to develop RESET/ and INIT/. The RESET/ signal automatically sets the 8086 CPU program counter to FFFFF0 and clears the interrupt enable flip-flop; resets the parallel I/O ports to the input mode; resets the serial I/O port to the “idle” mode; and resets the Bus Arbiter (outputs are tristated). The INIT/ signal is transmitted over the Multibus interface to set the entire system to a known internal state.

The initialization described above can be performed at any time by inputting an AUX RESET/ signal via auxiliary connector P2.

4-15. CLOCK CIRCUITS

The 5-MHz CLK is developed by Clock Generator A38 (22ZC6) in conjunction with crystal Y2. This clock is the time base for CPU A39, Status Decoder A81, Bus Arbiter A82, and Bus Command Decoder A83.

The time base for Bus Clock (BCLK/) and Constant Clock (CCLK/) is provided by Clock Generator A80 (10ZB5) and crystal Y3. The 18.432-MHz crystal frequency is divided by A63 and driven onto the Multibus interface through jumpers E105-E106 and E103-E104. The BCLK/ signal is also used as a clock input to the Bus Arbiter A82.

The time base for the remaining functions on the board is provided by clock Generator A17 (7ZA6) and crystal Y1. The nominal 22.12-MHz crystal frequency appearing at the OSC output of A17 is buffered and supplied to the Dual Port Control Logic and to RAM Controller A70. Clock Generator A17 also divides the crystal frequency by nine to develop a 2.46-MHz clock at its 42TTL output. The 2.46-MHz clock is applied directly to the clock input of the 8251A USART and applied through A18 to provide a selectable clock for the 8253 PIT. Divider A16 divides the 2.46 MHz clock by two and by nine, respectively, to produce 1.23-MHz and 153.6-kHz selectable clocks for the 8253 PIT.

4-16. 8086 CPU TIMING

The 8086 CPU uses the 5-MHz clock input to develop the timing requirements for various time-dependent functions described in following paragraphs.

4-17. BASIC TIMING. Each CPU bus cycle consists of at least four clock (CLK) cycles referred to as T1, T2, T3, and T4. The address is emitted from the CPU during T1 and data transfer occurs on the bus during T3 and T4; T2 is used primarily for changing the direction of the bus during read operations. In the event that a “not ready” indication is given by the addressed device, “wait” states (TW) are inserted between T3 and T4. Each inserted TW state is of the same duration as a CLK cycle. Periods can occur between CPU-driven bus cycles; these periods are referred to as “idle” states (TI) or inactive CLK cycles. The processor uses TI states for internal housekeeping.
4-18. BUS TIMING. The CPU generates status signals S0, S1, and S2 during T1 of every machine cycle. These status signals are used by Status Decoder A81, Bus Arbiter A82, and Bus Command Decoder A83 to identify the following types of machine cycles.

<table>
<thead>
<tr>
<th>S2</th>
<th>S1</th>
<th>S0</th>
<th>CPU Machine Cycle</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Interrupt Acknowledge</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>I/O Read</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>I/O Write</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>Halt</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Code Access</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>Memory Read</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>Memory Write</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>Passive</td>
</tr>
</tbody>
</table>

A read cycle begins in T1 with the assertion of the Address Latch Enable (ALE) signal and the emission of the address. (Refer to figure 4-4.) The trailing edge of the ALE signal latches the address into Address Latch A40/41/57 (22B2). (The BHEN/ signal and address bit AD0 address the low byte, high byte, or both bytes.) The Data Transmit/Receive (DT/\overline{R}) signal, which is asserted at the end of T1, is used to set up the various data buffers and data bus drivers for a CPU read operation. The Memory Read Command (MRDC/) or I/O Read Command (IORC/) is asserted from the beginning of T2 to the beginning of T4. At the beginning of T3, the AD0-AD15 lines of the local bus are switched to the "data" mode and the Data Enable (DEN) signal is asserted. (The DEN signal enables the data buffers.) The CPU examines the state of its READY input during the last half of T3. If its READY input is high (signifying that the addressed device has placed data on the data lines), the CPU proceeds into T4; if its READY input is low, the CPU enters a wait (TW) state and stays there until READY goes high. The external effect of using the READY input is to preserve the exact state of the CPU at the end of T3 for an integral number of clock periods before finishing the transfer cycle. This 'stretching' of the system timing, in effect, increases the allowable access time for memory or I/O devices. By inserting TW states, the CPU can accommodate slower memory or slower I/O devices. The CPU accepts the data and terminates the command in T4; the DEN signal then goes false and the data buffers are tristated.

**Figure 4-4. CPU Read Timing**

---

*NOTE: INTA/, AMWC/, MWTC/, AIOWC/, IOWC/ = V̅OH
*DETONES CPU INPUT OR OUTPUT
**DETONES STATUS DECODER A81 OUTPUT SIGNAL.*
A write cycle begins in T1 with the assertion of the ALE signal and the emission of the address. (Refer to figure 4-5.) The trailing edge of ALE latches the address into the address latch as described for a read cycle. The DT/R signal remains high throughout the entire write cycle to set up the data buffers and data bus drivers for a CPU write operation. Status Decoder A81 (3ZB4) provides two types of write strobe signals: advanced (AMWT/ and AIOWC/) and normal (MWTC/ and IOWC/). As shown in figure 4-5, the advanced memory and advanced I/O write strobes are issued one clock cycle earlier than the normal memory and I/O write strobes. (The ISBC 86/12A board doesn’t use advanced I/O write strobe AIOWC/.) At the beginning of T2, the advanced write and DEN signals are asserted and the AD0-AD15 lines of the local bus are switched to the “data” mode. (The DEN signal enables the data buffers.) The CPU then places the data on the AD0-AD15 lines and, at the beginning of T3, the normal write strobe is issued. The CPU examines the state of its READY input during the last half of T3. When READY goes high (signifying that the addressed device has accepted the data), the CPU enters T4 and terminates the write strobe. DEN then goes false and the data buffers are triestado.

The CPU interrupt acknowledge (INTA) cycle timing is shown in figure 4-6. Two back-to-back INTA cycles are required for each interrupt initiated by the 8259A PIC or by a slave 8259A PIC cascaded to the master PIC. The INTA cycle is similar to a read cycle. The basic difference is that an INTA/signal is asserted instead of an MRDC/ or IORC/ signal and the address bus is floated. In the second INTA cycle, a byte of information (supplied by the 8259A PIC) is read from “data” lines AD0-AD7. This byte, which identifies the interrupting source, is multiplied by four by the CPU and used as a pointer into an interrupt vector look-up table.
Figure 4-6. CPU Interrupt Acknowledge Cycle Timing

NOTES:
1. MRDC, IORC, AMWCR, MWTCR, AIOCRC, IOCRC = $V_{OH}$, BHEN = $V_{OL}$
2. THE TWO INTA CYCLES RUN BACK-TO-BACK, THUS, THE LOCAL BUS IS FLOATING WHEN THE SECOND INTA CYCLE IS ENTERED.

*DEOTES CPU INPUT OR OUTPUT
**DEOTES STATUS DECODER A81 OUTPUT
4-19. ADDRESS BUS

The address bus is shown in weighted lines in figures 4-1 and 4-2. The 20-bit address (AD0-AD19) is output by CPU A39 (2ZB4) during the first clock cycle (T1) of the memory or I/O instruction. The trailing edge of the Address Latch Enable (ALE) signal, output by Status Decoder A81 (3ZB4) during T1, strobes and latches the address into Latch A40/41/57 (2ZB2). The latched address is distributed as follows:

a. AB3-ABF to I/O Address Decoder A54/55/56 (6ZA6).
b. ABB-AB12 to PROM Address Decode Logic A68 (6ZC6).
c. AB1-ABC to PROM A28/29/46/47 (6ZC3).
d. AB13 to on-board RAM address recognition gate A53-6 (6ZD5).

4-20. DATA BUS

At the beginning of clock cycle T2, the CPU AD0-AD15 pins become the source or destination of data bus AD0-ADF. Data can be sourced to or input from the following:

a. Data Buffer A44/45 (4ZC3).
b. Data Buffer A60/61 (4ZC5).

4-21. BUS TIME OUT

Bus Time Out one-shot A5 (10ZA6) is triggered by the leading edge of the ALE signal. If the CPU halts, or is hung up in a wait state for approximately 10 (±15%) milliseconds, A5 times out and asserts the TIMEOUT/ signal. If jumper E5-E6 (2ZB6) is installed, the TIMEOUT/ signal drives the CPU READY line high through A7-12 and A38-5 to allow the CPU to exit the wait state. The TIMEOUT/ signal is also routed as a TIMEOUT INTR/ signal to the interrupt jumper matrix (8ZC2).

4-22. INTERNAL CONTROL SIGNALS

Status Decoder A81 (3ZB4) receives the 5-MHz CLK signal from Clock Generator A38 and status signals S0-S2 from CPU A39. The CLK signal establishes when the command signals are generated as a result of decoding S0-S2. The following signals are output from Status Decoder A81:

<table>
<thead>
<tr>
<th>Signal</th>
<th>Definition</th>
</tr>
</thead>
<tbody>
<tr>
<td>ALE</td>
<td>Address Latch Enable. Strobes address into Address Latch A40/41/57.</td>
</tr>
<tr>
<td>A1OWC/</td>
<td>Advanced I/O Write. An I/O Write Command that is issued earlier than IOWC/ in an attempt to avoid imposing a CPU wait state. (Not Used)</td>
</tr>
<tr>
<td>AMWC/</td>
<td>Advanced Memory Write Command. A Memory Write Command that is issued earlier than MWTC/ in an attempt to avoid imposing a CPU wait state.</td>
</tr>
<tr>
<td>DEN</td>
<td>Data Enable. Enables Data Buffers A44/456 and A60/61.</td>
</tr>
<tr>
<td>DT/R</td>
<td>Data Transmit/Receive. Establishes direction of data transfer through Data Buffers A44/45 and A60/61 and Data Bus Buffers A69/89/90.</td>
</tr>
<tr>
<td>IORC/</td>
<td>I/O Read Command to on-board PPI, USART, PIT, and PIC.</td>
</tr>
<tr>
<td>IOWC/</td>
<td>I/O Write Command to on-board PPI, USART, PIT, and PIC.</td>
</tr>
<tr>
<td>INTA/</td>
<td>Interrupt Acknowledge. Provides on-board control during INTA cycle.</td>
</tr>
<tr>
<td>MCE</td>
<td>Master Cascade Enable. Enable cascade address from master 8259A PIC onto local bus so that slave PIC address can be latched.</td>
</tr>
<tr>
<td>MRDC/</td>
<td>Memory Read Command. Establishes direction of data transfer through Memory Data Buffers A71/91.</td>
</tr>
<tr>
<td>MWTC/</td>
<td>Memory Write Command. Places the 8202 RAM Controller A70 in a write mode.</td>
</tr>
</tbody>
</table>

4-23. DUAL PORT CONTROL LOGIC

The Dual Port Control Logic (figure 5-2 sheet 11) allows the dual port RAM facilities to be shared by the on-board CPU or by another bus master via the Multibus interface. When not acting as a bus master or when not accessing the dual port RAM, the iSBC 86/12A board can act as a "slave" RAM device in a multiple bus master system. When accessing the dual port RAM, the on-board CPU has priority over any attempt to access the dual port RAM via the Multibus interface. In this situation, the bus access is held off until the CPU has completed its particular read or write operation. When a bus access is in progress, the Dual Port Control Logic enters the "slave" mode and any subsequent CPU request will be held off until the slave mode is terminated. Figures 4-7 and 4-8 are timing diagrams for the Dual Port Control Logic.

4-24. MULTIBUS INTERFACE ACCESS TIMING. Figure 4-7 illustrates the Dual Port Control Logic timing for dual port RAM access via the Multibus interface. (P-periods P0 through P17 are used only for descriptive purposes and have no relationship to the 22.12-MHz clock signal.) When the OFF BD RAM CMD signal goes high, A49-10 (11ZC6) goes high and A49-7 (11ZB5) goes low on the next rising edge of the clock at the end of P0 (assuming that ON BD RAM RQT/ and RAM XACK/ are both high).
Figure 4-7. Dual Port Control Multibus™ Interface Access Timing With CPU Lockout
At the end of P1, A50-5 (11ZC5) goes high and asserts the SLAVE MODE/ via inverter A31-8 (11ZC4). The outputs of A50-5 and A49-7 are ANDed to hold A50-5 in the preset (high) state. At the end of P2, A49-14 (11ZC3) goes low and asserts the SLAVE CMD EN/ signal, which gates DP RD/ or DP WRT/ to RAM Controller A70 (10ZB6); SLAVE CMD EN/ also gates the subsequently generated RAM XACK/ to the CPU READY input (RAM XACK/ is generated by the RAM Controller when data has been read from or written into RAM.)

The RAM Controller asserts RAM XACK/ during P13 and A49-10 goes low on the next rising edge of the clock. The bus master then terminates the OFF BD RAM CMD signal which terminates the SLAVE CMD EN/ signal. The SLAVE CMD EN/ signal going high terminates the DPRD/ or DPWRT/ signal. The RAM Controller next terminates RAM XACK/ and then A49-7 goes high on the next rising edge of the clock. At the end of P16, A50-5 goes low terminating the SLAVE MODE/ signal. At the end of P17, A49-14 goes high.

The foregoing discussion pertains only to the operation of the Dual Port Control Logic for Multibus interface access of the dual port RAM. The actual addressing and transfer of data are discussed in paragraph 4-38.

4-25. CPU ACCESS TIMING. Figure 4-8 illustrates the Dual Port Control Logic timing for dual port RAM access by the on-board 8086 CPU. (P-periods P0 through P13 are used only for descriptive purposes and have no relationship to the 22.12-MHz clock signal.) To demonstrate that the CPU has priority in the access of the dual port RAM, figure 4-8 shows the OFF BD RAM CMD signal active when the CPU access is initiated by the ON BD RAM RQT/ signal. The timing has progressed through P0, during which time A49-10 has been clocked high and A49-7 has been clocked low.

Flip-Flop A50-9 is preset (high) when the Status Decoder asserts the ALE/ signal at the beginning of T1 in the CPU instruction cycle. When the ON BD RAM RQT/ signal is asserted, the EXT ALE signal goes low and, since A51-6 is now low, A49-10 goes low on the next rising edge of the clock. Flip-Flop A50-5 is thus prevented from being clocked high and therefore keeps the DP ON BD ADDR EN/ signal asserted and suppresses the SLAVE MODE/ signal.

The ON BD CMD EN/ signal is asserted at the same time as the ON BD RAM RQT/ signal since A49-14 is high. The ADV MEM WRT/ or MEM RD/ signal from the Status Decoder is ANDed with the ON BD RAM RQT/ signal to prevent A50-5 from changing states when ALE/ goes false at the end of T1 in the instruction. (A49-10 is allowed to go high on the next rising edge of the clock after ALE/ goes false.)

The subsequently generated DP RD/ or DP WRT/ signal, gated by the asserted ON BD CMD EN/ signal, is transmitted to RAM Controller A70 (10ZB6). When the read or write is completed, the RAM Controller asserts RAM XACK/ and A49-10 goes low at the end of P12. At the end of P13, the CPU terminates the instruction and the ON BD RAM RQT/, DP RD/ or DP WRT/, and ADV MEM WRT/ or MEM RD/ signals go false. The RAM XACK/ signal is then terminated and A49-10 goes high at the end of P0. At the end of P1, the SLAVE MODE/ is entered when A50-5 goes high.

The foregoing discussion pertains only to the operation of the Dual Port Control Logic for CPU access of on-board RAM. The actual addressing and transfer of data are discussed in paragraph 4-37.

4-26. MULTIBUS INTERFACE ARBITRATION

The Multibus interface arbitration circuits consist of the Bus Arbitrator A82 (3ZD4), Bus Command Decoder A83 (3ZC4), bidirectional Address Bus Driver A87/88 (5ZA3), bidirectional Data Bus Driver A69/89/90 (4ZB4), and the Slave RAM Decode Logic (figure 5-2 sheet 3).

The falling edge of CLK provides the timing to establish when Bus Arbitrator actions are initiated. The falling edge of BCLK/ provides the bus timing reference for the Bus Arbitrator, which allows the iSBC 86/12A board to assume the role of bus master. When the ON BD ADR/ (3ZC7) signal is false (high) and the S0-S2 status signals indicate either a read or write operation, the Bus Arbitrator drives CBRQ/ and BREQ/ low and BPRO/ high (3ZD2). The BREQ/ output, in conjunction with CBRQ/, from each bus master in the system is used by the Multibus interface when the bus priority is resolved by a parallel priority scheme as described in paragraph 2-24. The BPRO/ output, in conjunction with CBRQ/, is used by the Multibus interface when the bus priority is resolved by a serial priority scheme as described in paragraph 2-23.

The iSBC 86/12A board gains control of the Multibus interface when the BPRN/ input to the Bus Arbitrator is driven low and CBRQ/ is high. On the next falling edge of BCLK/, the Bus Arbitrator drives BUSY/ and BUS ADEN/ low. The BUSY/ output indicates that the bus is in use and that the current bus master, in control, will not relinquish control until it raises its BUSY/ signal.

The BUS ADEN/ output, which can be thought of as a "master bus control" signal, is applied to the
Figure 4-8. Dual Port Control CPU Access Timing With Multibus™ Interface Lockout
AEN2/ input of Clock Generator A38 (2ZC6), the Bus Address Driver A87/88 (5ZC3), and the input of AND gate A2-11 (3ZC5). With AEN2/ enabled, the Clock Generator is prepared to recognize the ensuing acknowledge signal (AACK/ or XACK/) transmitted by the addressed system device. To ensure adequate setup for the address and data, counter A4 (2ZB6) is held in the clear state as long as ALE/ is asserted. When ALE/ goes false, A4-3 is clocked low by the 5-MHz clock to generate T21/. This signal (T21/) is driven through gate A2-11 (3ZC5) to enable the Bus Command Decoder A83.

The false ON BD ADR/ signal enables the Bus Command Decoder, which decodes S0-S2 and drives the appropriate command low on the Multibus interface when CLK goes low. The Bus Command Decoder also drives BUS DEN (3ZC2) high to enable Data Bus Driver A69/89 (4ZB4). The Data Bus Driver is switched to the appropriate “transmit” or “receive” mode depending on the state of the DT/R output of Status Decoder A81 (3ZB4).

After the command is acknowledged (signified by the addressed device driving the Multibus interface XACK/ line low), the CPU terminates the appropriate command. The Bus Arbiter terminates BUS ADEN/ and the Bus Command Decoder terminates BUS DEN. The Bus Arbiter may or may not relinquish control of the Multibus interface (depends on how the Bus Arbiter is jumpered) by driving BREQ/ high and BPRO/ low and then raising BUSY/.

It should be noted that, after gaining control of the Multibus interface, the isc 86/12A board can invoke a “bus lock” condition to prevent losing control at a critical time. (For instance, it may be desired to execute several consecutive commands without having to contend for the bus after each command is executed.) The “bus lock” condition is invoked by driving the Bus Arbiter LOCK input low in one of two ways:

a. By executing a software LOCK XCNG command.

b. By clearing an option bit via I/O Port 00CC.

During an interrupt from the 8259A PIC, the LOCK input is automatically driven low by the first of two INTA/ signals issued by Status Decoder A81. (Refer to paragraphs 4-40 through 4-42.)

4-28. ON-BOARD I/O OPERATION. Address bits AB3-ABF are applied to the I/O Address Decoder composed of A54/55/56 (6ZB6). The ADV I/O ADR signal is developed by flip-flop A30-16 (2ZA2) when the ALE signal latches the CPU inverted S2 signal. When ADV I/O ADR is true, the I/O Address Decoder develops IO AACK/ (6ZA2) when AB8-ABF are false, AB6-AB7 are true, and AB5 is false. The I/O AACK/ signal enables decoder A54 (6ZA4) which then decodes AB3-AB4. (The I/O AACK/ signal also drives the CPU READY input high.) Assuming AB8-ABF are false, AB3-AB7 are decoded to generate the following chip select signals:

```
<table>
<thead>
<tr>
<th>Bits</th>
<th>Addresses*</th>
<th>Chip Select</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 1 0 0 0</td>
<td>C0, C2, C4, C6</td>
<td>8250CS/</td>
</tr>
<tr>
<td>1 1 0 0 1</td>
<td>C8, CA, CC, CE</td>
<td>8255CS/</td>
</tr>
<tr>
<td>1 1 0 1 0</td>
<td>D0, D2, D4, D6</td>
<td>8232CS/</td>
</tr>
<tr>
<td>1 1 0 1 1</td>
<td>D8, DA, DC, DE</td>
<td>8251CS/</td>
</tr>
</tbody>
</table>
```

*Odd addresses (i.e., C1, C3, . . . DD) are invalid.

The IO AACK/ signal is driven through A32-8 and A6-8 (6ZD4), respectively, to develop PROM IO EN/ and ON BD ADR/. PROM IO EN/ enables Data Buffer A44/45 (4ZD3) and ON BD ADR/ inhibits the Bus Arbiter A82 and Bus Command Decoder A83. The DT/R output of Status Decoder A81 is inverted (A20-12, 4ZC6) to select the proper direction of data transfer through the Data Buffer.

After the proper I/O device is enabled, the specific function for the device is selected by address bits AB1-AB2 and the IORC/ or IOWC/ output of Status Decoder A81.

4-29. SYSTEM I/O OPERATION. Address bits AB3-ABF are decoded by the I/O Address Decoder as described in paragraph 4-28. If the address is not for an on-board I/O device, the ON BD ADR/ signal is false (high) and enables the Bus Arbiter A82 (3ZD4) and Bus Command Decoder A83 (3ZC4). The Bus Arbiter and Bus Command Decoder, which are clocked by the 5-MHz clock to latch in and decode status signals S0-S2, then acquire control of the Multibus interface as described in paragraph 4-26.

4-30. ROM/EPROM OPERATION

The four ROM/EPROM chips are installed by the user in IC sockets A28/29/46/47 (6ZC3). The ROM/EPROM addresses are assigned from the top down in the 1-megabyte address space; the bottom
address is determined by the user configuration of chips as follows:

<table>
<thead>
<tr>
<th>ROM</th>
<th>EPROM</th>
<th>Address Block</th>
</tr>
</thead>
<tbody>
<tr>
<td>2332A</td>
<td>2732</td>
<td>FF000-FFFFF</td>
</tr>
<tr>
<td>2316E</td>
<td>2716</td>
<td>FE000-FFFFF</td>
</tr>
<tr>
<td>2758</td>
<td></td>
<td>FC000-FFFFF</td>
</tr>
</tbody>
</table>

Jumper posts E94 through E99 and switch S1 must be properly configured to accommodate the type of ROM/EPROM installed. (Refer to table 2-4.)

IC sockets A29 and A47 accommodate the top half of the installed ROM/EPROM; IC sockets A28 and A46 accommodate the ROM/EPROM space directly below that installed in A29 and A47. The low-order bytes (bits DB0-DB7) are installed in A29 and A28; the high-order bytes (bits DB8-DBF) are installed in A47 and A46.

When ADV IO ADDR is false, a custom ROM A68 (6ZC6) decodes address bits ABB-AB12. If the address is within the limit specified, the O4 and O3 output pins will be low and the O2 and O1 output pins will depend on whether the address is in the upper half or lower half of the address block. For instance, if 2758 EPROM chips are installed and the address is in the range FF000-FFFFF, the O2 and O1 pins will be high and low, respectively; if the address is in the range FP800-FFFFF, the O2 and O1 pins will both be high. The O4 and O3 output pins are compared with address bit AB13. If AB13 is high, the PROM AACK/ signal is asserted; if AB13 is low, the ON BD RAM RQT/ signal is asserted.

When ALE goes false, Decoder A18 (6ZC4) is enabled and decodes the inputs presented by the O2 and O1 output of A68. If O2/O1 = 10, PCS2/ is asserted and enables A28 and A46; if O2 and O1 = 11, PCS3/ is asserted and enables A29 and A47. Each chip of the selected pair of chips is individually addressed by AB1-ABC. Thus, when the associated enable signal (PCS2/ or PCS3/) is asserted, the contents of the address specified by AB1-ABC are transferred to the CPU via Data Buffer A44/45.

4-31. ROM/EPROM OPERATION WITH iSBC 340 MULTIMODULE EPROM. The eight ROM/EPROM chips are installed, by the user, in IC sockets A29/A47/A1/A2/A3/A4/A5/A6. (ROM/EPROM IC sockets A1-A6 are located on the iSBC 340 Multimodule EPROM board. Refer to Appendix B.) The ROM/EPROM addresses are assigned from the top down in the 1-megabyte address space. The bottom address is F8000 and extends upward to FFFFF. A jumper must be placed between posts E94 and E96 and between E97 and E99 to accommodate the additional ROM/EPROM installed. In addition, switch positions 7 and 8 of S1 must be off. (Refer to table 2-4.)

IC sockets A29, A47, A3, and A6 accommodate the top half of the installed ROM/EPROM; IC sockets A1, A2, A4, and A5 accommodate the lower half of the installed ROM/EPROM. The low-order bytes (bits DB0-DB7) are installed in IC sockets A1, A2, A3, and A29; the high-order bytes (bits DB8-DBF) are installed in IC sockets A4, A5, A6, and A47.

When ADV IO ADDR is false, a custom ROM (A68, 6ZB6) decodes address bits ABB-AB12 and switch S1 positions 7 and 8. If the address is within F8000-FFFFF, the O4 and O3 output pins will be low and the O2 and O1 output pins will change according to the address. Table 4-1 lists O1, O2 states and the chips selected for the various address blocks. The O4 and O3 output pins are compared with address bit AB13. If AB13 is high, the PROM AACK/ signal is asserted; if AB13 is low, the ON BD RAM RQT/ signal is asserted.

When ALE goes false, Decoder A18 (6ZC4) is enabled and decodes the inputs presented by the O2 and O1 outputs of A68. For example, if O2/O1 = 00, PCS0/ is asserted and enables A1 and A4; if O2/O1 = 11, PCS3/ is asserted and enables A29 and A47. Each chip of the selected pair of chips is individually addressed by AB1-ABC. Thus when the associated enable signal is asserted, the contents of the address specified by AB1-ABC are transferred to the CPU via Data Buffer A44/45.

4-32. RAM OPERATION

As described in paragraph 4-23, the Dual Port Control Logic allows the on-board RAM facilities to be shared by the 8086 CPU and another bus master via the Multibus interface. The following paragraphs describe the RAM Controller, RAM chip arrays, and the overall operation of how the RAM is addressed for read/write operation.

4-33. RAM CONTROLLER. All address and control inputs to the on-board RAM are supplied by RAM Controller A70 (10ZC6). The RAM Controller automatically provides a 128-cycle RAS refresh timing cycle to the dynamic RAM composed of RAM chips A72-79 and A92-99.

The RAM Controller, when enabled by a low input to its PCS/ pin, multiplexes the address to the RAM chips. Low-order address bits A0-A6 are presented at the RAM address lines and RAS/ is driven low at the beginning of the first memory clock cycle. High-order address bits A7-A13 are presented at the RAM
address lines and CAS/ is driven low during the second memory clock cycle. The RAM Controller drives its WE/ output pin according to whether the CPU instruction is a read or write. For a write operation, the DP WT/ input is low to the RAM Controller, in which case the WE/ output is driven low. For a read operation, the DPRD/ input is low and the WE/ output remains high. When the memory cycle (read or write) starts, the RAM Controller drives its SACK/ output low; when the memory cycle is complete, it drives its XACK/ output low. The SACK/ and XACK/ go high when the RD/ or WR/ input goes high.

### 4-34. RAM CHIPS

Even bytes of data are stored in A72-A79 and odd bytes of data are stored in A92-A99. The WE/ input pin to A72-A79 is controlled by ANDing the RAM Controller WE/ output and memory address bit AM0. The WE/ input pin to A92-A99 is controlled by ANDing the RAM Controller WE/ output, AM0, and MBHEN/ (Memory Byte High Enable).

### 4-35. RAM CONTROLLER WITH iSBC 300 MULTIMODULE RAM

All address and control inputs to the onboard RAM are supplied by RAM Controller A1. (RAM IC sockets A1-A19 are located on the iSBC 300 Multimodule RAM board. Refer to Appendix B). The RAM Controller automatically provides a 128-cycle RAS refresh timing cycle to the dynamic RAM composed of RAM chips A72-A79, A92-A99, A3-A10, and A12-A19.

The RAM Controller when enabled by a low input to its PCS/ pin, multiplexes the address to the RAM chips. Low-order address bits A0-A6 are presented at the RAM address lines and RAS/ is driven low at the beginning of the first memory clock cycle. High-order address bits A7-A13 are presented at the RAM address lines and CAS/ is driven low during the second memory clock cycle. The RAM Controller drives its WE/ output pin according to whether the CPU instruction is a read or write. For a write operation, the DP WT/ input is low to the RAM Controller, in which case the WE/ output is driven low. For a read operation, the DPRD/ input is low and the WE/ output remains high. When the memory cycle (read or write) starts, the RAM Controller drives its SACK/ output low; when the memory cycle is complete, it drives its XACK/ output low. The SACK/ and XACK/ go high when the RD/ or WR/ input goes high.

### 4-36. RAM CHIPS WITH iSBC 300 MULTIMODULE RAM

Even bytes of data are stored in A72-A79 and A3-A10 and odd bytes are stored in A92-A99 and A12-A19. The WE/ signal to A72-A79, A3-A10 is developed by ANDing the RAM Controller WE/ output with memory address bit AM0. The WE2/ signal to A92-A99, A12-A19 is developed by ANDing the RAM Controller WE/ output, AM0, and MBHEN/ (Memory Byte High enable).

### 4-37. ON-BOARD READ/WRITE OPERATION

When the O4 output of A68 (6ZC6) and address bit AB13 are both low, the output of A53-6 (6ZD5) goes low and asserts the ON BD RAM RQT/ signal. When ON BD RAM RQT/ goes low, A52-3 (11ZA3) is enabled and generates ON BD CMD EN/ to generate RAM CS via A52-11 and to gate DPRD/ or DPWT/ to the RAM Controller. (See figure 4-8.) The RAM Controller then multiplexes the address to RAM and, depending on which input command is true (DPRD/ or DPWT/), drives its WE/ output high or low. (The WE/ output is driven low for a write; it remains high for a read.) The SACK/ and XACK/ signals are generated by the RAM Controller as described in paragraph 4-33. The CPU completes the read or write operation when XACK/ is asserted.
During the CPU access of on-board RAM, the Address Bus Drivers and Data Bus Drivers are disabled and the Address Buffer and Data Buffer are enabled.

4-38. BUS READ/WRITrE OPERATION. When another bus master has control of the Multibus interface, that bus master can address the iSBC 86/12A board as a slave RAM device. The bus master first places the address on the Multibus interface and then asserts MRDC/ or MWTC/. Address bits ADRD/ADRI/0/ and switch S1 present a 10-bit address to a special ROM (A67) (3ZB5); address bits ADR11/ADRI/3/ are decoded by A66 (3ZB6). The switch settings of S1 represent the base address and memory bus size; the O1-O3 outputs of A67 are ATRD/ATRF/, which are multiplexed by A86 (5ZC4) into memory address bits AMD-AMF when the SLAVE READY/ signal is subsequently activated by the Dual Port Control Logic. The O4 output of A67 is driven through A23-4 (when the 128K byte matches) to develop the OFF BD RAM ADDR QRT signal, which is applied to the Dual Port Control Logic. If no CPU access is in progress, the Dual Port Control Logic then enters the slave mode and, when A49-10 (112/06) goes low, develops the RAM CS and SLAVE CMD EN/ signals. RAM CS enables RAM Controller A70 (102/6G) and SLAVE CMD EN/ gates DPRD/ or DPWT/ (3ZA6) to the RAM Controller. The RAM Controller then multiplexes the address to RAM and, depending on which input command is true (DPRD/ or DPWT/), drives its WE/ output high or low. (The WE/ output is driven low for a write; it remains high for a read.) The SACK/ and XACK/ signals are generated by the RAM Controller as described in paragraph 4-33. The CPU completes the read or write operation when XACK/ is asserted.

During the Multibus interface access of on-board RAM, the SLAVE READY/ signal enables the Address Bus Drivers (A86/87/88); the ON BD ADR/ signal is false and enables the Data Bus Drivers (A69/89).

4-39. BYTE OPERATION. For Multibus interface operation, the on-board RAM is organized as two 8-bit data banks; all even byte data is in one bank (DAT0-DAT7/) and all odd byte data is in the other bank (DAT8-DATF/). Refer to figure 3-1 which shows the data path for Multibus interface operation by 8-bit and 16-bit bus masters.

All word operations must occur on an even byte address boundary with BHEN/ asserted (low). Byte operations can occur in one of two ways:

a. The even bank can be accessed by controlling ADR0/, which places the data on the DAT0/-DAT7/ lines. (Refer to figure 3-1A.)

b. To access the odd bank, which is normally placed on DAT8/-DATF/, the data path shown in figure 3-1B is implemented. This requires that BHEN be false (high) and ADR0/ be low.

These operations permit the access of both bytes of the 16-bit data word by controlling ADR0/. In other words, ADR0/ specifies a unique byte and is not a part of a 16-bit word operation.

Shown below are the states of BHEN/ and ADR0/ for 8-bit and 16-bit operations and the effects on transceiver control and memory block chip select.

<table>
<thead>
<tr>
<th>Bus Control Lines</th>
<th>Data Bus Driver Chip Select</th>
<th>Memory Block Chip Select</th>
</tr>
</thead>
<tbody>
<tr>
<td>BHEN/ ADR0/ A69 A89 A90 A72-A79 A92-A99</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 1 Off A99 A90 On* A89 A69</td>
<td></td>
<td></td>
</tr>
<tr>
<td>1 0 On Off A89 A90 Off On</td>
<td></td>
<td></td>
</tr>
<tr>
<td>0 1 Off Off A92 A91 A90</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

*don't care condition

4-40. INTERRUPT OPERATION

The 8259A PIC can support both bus vectored (BV) and non-bus vectored (NBV) interrupts. For both BV and NBV interrupts, the on-board PIC (A24) (82B5) serves as the master PIC. (Refer to paragraph 2-14.) The master PIC drives the CPU INTR input high to initiate an interrupt request and the CPU then enters the interrupt timing cycle in which two INTA cycles occur back-to-back. The NBV and BV interrupts are described in the following paragraphs.

NOTE

The iSBC 86/12A board must be capable of Multibus interface access when using interrupts.

4-41. NBV INTERRUPT. Assume that a NBV interrupt is initiated by an on-board function driving the IR5 line high to the on-board PIC; if no higher interrupt is in progress, the PIC then drives the CPU INTR input high. Assuming that the NMI interrupt is inactive and that the CPU interrupt enable flip-flop is set, the CPU suspends the current operation and proceeds with the first of two back-to-back INTA cycles. (Refer to figure 4-6 for signals activated during the first and subsequent INTA cycle.)

The Bus Arbiter A82 (3ZD4) acquires control of the Multibus interface and the MCE signal from the Status Decoder A81 (3ZB4) drives the LOCK/ signal low to ensure Multibus interface control until the second INTA cycle is complete. The Bus Command Decoder A83 (3ZC4) drives the INTA/ signal low. On
receipt of the first INTA/ signal, the master PIC freezes the internal state of its priority resolution logic. The first INTA/ signal also sets flip-flop A63-5 (8ZA2), which generates the 1st INTA ACK/ signal to drive the CPU READY input high.

The CPU then proceeds with the second INTA cycle. On receipt of the second INTA/ signal, the master PIC places an 8-bit identifier for IR5 on the data bus, and drives its DEN/ output low. The resultant LOCAL INTA DEN/ signal enables Data Buffer A44/45 and drives the CPU READY input high. (The second INTA/ signal clears flip-flop A63-5.) The CPU then inputs the 8-bit identifier and terminates the interrupt timing cycle.

The CPU multiplies the 8-bit identifier by four to derive the restart address of the interrupting device. After the service routine is completed, the CPU automatically resets all its affected flags and returns to the main program.

4-42. BV INTERRUPT. As far as the CPU is concerned, BV interrupts are handled exactly the same as NBV interrupts. Assume that the IR6 line to the master PIC is driven by a slave PIC on the Multibus interface. When IR6 goes high, the master PIC drives the CPU INTR input high as previously described. On receipt of the first INTA/ signal, the master PIC generates BUS INTA DEN/ via its DEN/ output and places the interrupt address code for IR6 on its C0-C2 pins; since QMCE/ is enabled by the MCE output of the Status Decoder, the C0-C2 is transferred to the Address Latch via address lines AD8-ADA. (These bits are latched when the ALE signal goes false.) The BUS INTA DEN/ signal enables the Data Bus Driver in preparation to receive the 8-bit identifier from the slave PIC. (The interrupt address code is now on Multibus interface address lines ADR8-ADRA/.)

The first INTA/ signal sets flip-flop A63-5 to drive the CPU READY input high. The CPU then proceeds with the second INTA cycle. When the second INTA/ signal is driven onto the Multibus interface and the slave PIC recognizes its address, it outputs an 8-bit identifier onto the DAT0-/DAT7/ lines and drives the Multibus interface XACK/ line low. (The second INTA/ also toggles and clears flip-flop A63-5.) The CPU then inputs the 8-bit identifier and terminates the interrupt timing cycle.

The CPU multiplies the 8-bit identifier by four to derive the restart address of the interrupting device. After the service routine is completed, the CPU automatically resets all its affected flags and returns to the main program.
Figure 4-2. ISBC 86/12A ROM/EPROM and Dual Port RAM Simplified Logic Diagram
5-1. INTRODUCTION

This chapter provides a list of replaceable parts, service diagrams, and service and repair assistance instructions for the iSBC 86/12A Single Board Computer.

5-2. REPLACEABLE PARTS

Table 5-1 provides a list of replaceable parts for the iSBC 86/12A board. Table 5-2 identifies and locates the manufacturers specified in the MFR CODE column in table 5-1. Intel parts that are available on the open market are listed in the MFR CODE column as “COML”; every effort should be made to procure these parts from a local (commercial) distributor.

5-3. SERVICE DIAGRAMS

The iSBC 86/12A board parts location diagram and schematic diagram are provided in figures 5-1 and 5-2, respectively. On the schematic diagram, a signal mnemonic that ends with a slash (e.g., IOWC/) is active low. Conversely, a signal mnemonic without a slash (e.g., INTR) is active high.

5-4. SERVICE AND REPAIR ASSISTANCE

Before calling the Product Service Hotline, you should have the following information available:

a. Date you received the product.

b. Complete part number of the product (including dash number). On boards, this number is usually silkscreened onto the board. On other MCSD products, it is usually stamped on a label.

c. Serial number of product. On boards, this number is usually stamped on the board. On other MCSD products, the serial number is usually stamped on a label.

d. Shipping and billing addresses.

e. If your Intel product warranty has expired, you must provide a purchase order number for billing purposes.

f. If you have an extended warranty agreement, be sure to advise the Hotline personnel of this agreement.

Use the following numbers for contacting the Intel Product Service Hotline

**Telephone**

All U.S. locations, except Alaska, Arizona, & Hawaii: (800) 528-0595

All other locations: (602) 869-4600

**TWX Number** 910 - 951 - 1330

---

**Table 5-1. Replaceable Parts**

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>A1,37,62</td>
<td>IC, 74125, Quad Bus Buffer (3-state)</td>
<td>SN74125</td>
<td>TI</td>
<td>3</td>
</tr>
<tr>
<td>A2,21,53</td>
<td>IC, 74S32, Quad 2-Input Positive-OR Gate</td>
<td>SN74S32</td>
<td>TI</td>
<td>3</td>
</tr>
<tr>
<td>A3,7</td>
<td>IC, 74S10, Triple 3-Input Positive-NAND Gate</td>
<td>SN74S10</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A4,49</td>
<td>IC, 74S175, Hex Quad D-Type Flip-Flop</td>
<td>SN74S175</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A5</td>
<td>IC, 9602, Dual One-Shot Multivibrator</td>
<td>9602PC</td>
<td>FAIR</td>
<td>1</td>
</tr>
<tr>
<td>A6,51</td>
<td>IC, 74S11, Triple 3-Input Positive-AND Gate</td>
<td>SN74S11</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A8,9</td>
<td>IC, Intel 8226, 4-Bit Bidirectional Bus Driver</td>
<td>8226</td>
<td>COML</td>
<td>2</td>
</tr>
<tr>
<td>A14</td>
<td>IC, 75189, Quad Line Receivers</td>
<td>SN75189</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A15</td>
<td>IC, 75188, Quad Line Drivers</td>
<td>SN75188</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A16</td>
<td>IC, 74163, Sync 4-Bit Counter</td>
<td>SN74163</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A17,90</td>
<td>IC, Intel 8224, Clock Generator and Driver</td>
<td>8224</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>A18,54</td>
<td>IC, 74S139, Decoder/Multiplexer</td>
<td>SN74S139</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A19,32</td>
<td>IC, 74S08, Quad 2-Input Positive-AND Gate</td>
<td>SN74S08</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A20,34</td>
<td>IC, 74S04, Hex Inverters</td>
<td>SN74S04</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A22,59</td>
<td>IC, 7432, Quad 2-Input Positive-OR Gate</td>
<td>SN7432</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A23</td>
<td>IC, 74S02, Quad 2-Input Positive-NOR Gate</td>
<td>SN74S02</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A24</td>
<td>IC, Intel 8259A, Programmable Interrupt Controller</td>
<td>SN74S04A</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A25</td>
<td>IC, Intel 8255A, Programmable Peripheral Interface</td>
<td>SN74S05</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A26</td>
<td>IC, Intel 8253, Programmable Interval Timer</td>
<td>SN74S06</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A27</td>
<td>IC, Intel 8251A, Programmable Comm. Interface</td>
<td>SN74S07</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A30,57</td>
<td>IC, 74LS75, 4-Bit Bistable Latch</td>
<td>SN74LS75</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A31,33,43,52</td>
<td>IC, 74S00, Quad 2-Input Positive-NAND Gate</td>
<td>SN74S00</td>
<td>TI</td>
<td>4</td>
</tr>
<tr>
<td>A34,94,65</td>
<td>IC, 74LS04, Hex Inverters</td>
<td>SN74LS04</td>
<td>TI</td>
<td>3</td>
</tr>
<tr>
<td>A36</td>
<td>IC, 74LS00, Quad 2-Input Positive-NAND Gate</td>
<td>SN74LS00</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A38</td>
<td>IC, Intel 8284A, 18-Pin Clock Generator</td>
<td>8284A</td>
<td>COML</td>
<td>1</td>
</tr>
</tbody>
</table>
### Table 5-1. Replaceable Parts (Continued)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>A39</td>
<td>IC, Intel 8086, 16-Bit Microprocessor</td>
<td>8086</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>A40,41,71,91</td>
<td>IC, 74S373, Octal D-Type Latches</td>
<td>SN74S373</td>
<td>TI</td>
<td>4</td>
</tr>
<tr>
<td>A42,44,45,58,60,61</td>
<td>IC, Intel 8286, 8-Bit Non-Inverting Transceiver</td>
<td>8286</td>
<td>COML</td>
<td>6</td>
</tr>
<tr>
<td>A48</td>
<td>IC, 7438, Quad 1-Input Positive-NAND Gate</td>
<td>SN7438</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A50,63</td>
<td>IC, 74S74, Dual D-type Edge-Triggered Flip-Flop</td>
<td>SN74S74</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>A55</td>
<td>IC, 74S30, 8-Input Positive-NAND Gate</td>
<td>SN74S30</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A56</td>
<td>IC, 7425, Dual 4-Input Positive-NOR Gate</td>
<td>SN74S25</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A64</td>
<td>IC, 74S140, Dual 4-Input Positive-NAND Gate</td>
<td>SN74S140</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A65</td>
<td>IC, 8097, 3-State Hex Buffers</td>
<td>DM8097</td>
<td>NAT</td>
<td>1</td>
</tr>
<tr>
<td>A66</td>
<td>IC, 74LS138</td>
<td>SN74LS138</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>A67</td>
<td>IC, PROM, Address Decoder</td>
<td>INTEL</td>
<td>9100134</td>
<td>1</td>
</tr>
<tr>
<td>A68</td>
<td>IC, PROM, Address Decoder</td>
<td>INTEL</td>
<td>9100129</td>
<td>1</td>
</tr>
<tr>
<td>A69,87-90</td>
<td>IC, Intel 8287, 8-Bit Inverting Transceiver</td>
<td>8287</td>
<td>COML</td>
<td>5</td>
</tr>
<tr>
<td>A70</td>
<td>IC, Intel 8202A, Dynamic RAM Controller</td>
<td>8202A</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>A72-79,92-99</td>
<td>IC, Intel 2117-4, Dynamic RAM</td>
<td>2117-4</td>
<td>COML</td>
<td>16</td>
</tr>
<tr>
<td>A81,83</td>
<td>IC, Intel 8288, Bus Controller for 8086</td>
<td>8288</td>
<td>COML</td>
<td>2</td>
</tr>
<tr>
<td>A82</td>
<td>IC, Intel 8289, Bus Arbiter for 8086</td>
<td>8299</td>
<td>INTEL</td>
<td>1</td>
</tr>
<tr>
<td>A86</td>
<td>IC, 74S240, Octal Buffer/Line Driver/Line Receiver</td>
<td>SN74S240</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>CR1,2</td>
<td>Diode, 1N914B</td>
<td>OBD</td>
<td>COML</td>
<td>2</td>
</tr>
<tr>
<td>C1,2,4,11,13,15,19,21-25,28-51,65-75,91</td>
<td>Cap., mono, 0.1µF, +80 -20%, 50V, Low Profile</td>
<td>OBD</td>
<td>COML</td>
<td>57</td>
</tr>
<tr>
<td>C3</td>
<td>Cap., mono, 1.0µF, ±10%, 50V</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>C12, 64</td>
<td>Cap, mica, 1.0µF, ±5%, 500V</td>
<td>OBD</td>
<td>COML</td>
<td>3</td>
</tr>
<tr>
<td>C20,98</td>
<td>Cap., mono, 0.001µF, ±20%, 50V</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>C26</td>
<td>Cap., tant, 10µF, ±10%, 20V</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>C92</td>
<td>Cap., mono, 0.33µF, +80 -20%, 50V</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>C52,54,55,57,58,60,61</td>
<td>Cap., mono, 0.047µF, +80 -20%, 50V, Low Profile</td>
<td>OBD</td>
<td>COML</td>
<td>16</td>
</tr>
<tr>
<td>C53,56,59,62,77,80,83,86</td>
<td>Cap., mono, 0.01µF, +80 -20%, 50V, Low Profile</td>
<td>OBD</td>
<td>COML</td>
<td>8</td>
</tr>
<tr>
<td>C88-90,93-97</td>
<td>Cap., tant, 22µF, ±10%, 15V</td>
<td>OBD</td>
<td>COML</td>
<td>8</td>
</tr>
<tr>
<td>RP1</td>
<td>Res., pack, 8-pin, 1K, ±5%, 2W PP</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>RP2</td>
<td>Res., pack, 14-pin, 1K, ±2%, 1.5W PP</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>RP3</td>
<td>Res., pack, 16-pin, 10K, ±5%, 2W PP</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>RP4</td>
<td>Res., pack, 6-pin, 2.2K, ±5%, 1W PP</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>R1,11,16,17</td>
<td>Res., fxd, comp, 10K, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>4</td>
</tr>
<tr>
<td>R2,</td>
<td>Res., fxd, comp, 33K, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>2</td>
</tr>
<tr>
<td>R3-5,13,20</td>
<td>Res., fxd, comp, 5.1K, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>5</td>
</tr>
<tr>
<td>R7,8,10,14,18,19,21,23</td>
<td>Res., fxd, comp, 1K, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>8</td>
</tr>
<tr>
<td>R9</td>
<td>Res., fxd, comp, 100K, 5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>R12</td>
<td>Res., fxd, comp, 330 ohm, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>R15</td>
<td>Res., fxd, comp, 270 ohm, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>R22</td>
<td>Res., fxd, comp, 20K, ±5%, ¼W</td>
<td>OBD</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>S1</td>
<td>Switch, 8-position, DIP</td>
<td>S1</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>S1</td>
<td>Switch, 8-position, DIP</td>
<td>S1</td>
<td>COML</td>
<td>1</td>
</tr>
<tr>
<td>VR1</td>
<td>Voltage regulator</td>
<td>MC79L05AC</td>
<td>MOT</td>
<td>1</td>
</tr>
<tr>
<td>XA8,9</td>
<td>Socket, 16-pin, DIP</td>
<td>DILB18P-108</td>
<td>BURNDY</td>
<td>2</td>
</tr>
<tr>
<td>XA10-13</td>
<td>Socket, 14-pin, DIP</td>
<td>DILB14P-108</td>
<td>BURNDY</td>
<td>4</td>
</tr>
<tr>
<td>XA28,29,46,47</td>
<td>Socket, 24-pin, DIP</td>
<td>524-AG37D</td>
<td>AUGAT</td>
<td>4</td>
</tr>
<tr>
<td>XA38,70</td>
<td>Socket, 40-pin, DIP</td>
<td>540-A37D</td>
<td>AUGAT</td>
<td>2</td>
</tr>
<tr>
<td>XA67,68</td>
<td>Socket, 18-pin, DIP</td>
<td>DILB18P-108</td>
<td>BURNDY</td>
<td>2</td>
</tr>
<tr>
<td>XA71,91</td>
<td>Socket, 20-pin, DIP</td>
<td>520-AG37D</td>
<td>AUGAT</td>
<td>2</td>
</tr>
<tr>
<td>Y1</td>
<td>Crystal, 22.1184-MHz, fundamental</td>
<td>OBD</td>
<td>CTS</td>
<td>1</td>
</tr>
<tr>
<td>Y2</td>
<td>Crystal, 15-MHz, fundamental</td>
<td>OBD</td>
<td>CTS</td>
<td>1</td>
</tr>
<tr>
<td>Y3</td>
<td>Crystal, 18.432-MHz, fundamental</td>
<td>OBD</td>
<td>CTS</td>
<td>1</td>
</tr>
<tr>
<td>Extractor, Card</td>
<td>Post, Wire Wrap</td>
<td>S-203</td>
<td>SCA</td>
<td>2</td>
</tr>
<tr>
<td>Plug, Shorting, 2-position</td>
<td>89531-6</td>
<td>AMP</td>
<td>139</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Plug, Shorting, 2-position</td>
<td>530153-1</td>
<td>AMP</td>
<td>2</td>
</tr>
</tbody>
</table>
Always contact the Product Service Hotline before returning a product to Intel for repair. You will be given a repair authorization number, shipping instructions, and other important information which will help Intel provide you with fast, efficient service. If you are returning the product because of damage sustained during shipment or if the product is out of warranty, a purchase order is required before Intel can initiate the repair.

In preparing the product for shipment to the Repair Center, use the original factory packing material, if possible. If this material is not available, wrap the product in a cushioning material such as Air Cap TH-240, manufactured by the Sealed Air Corporation, Hawthorne, N.J. Then enclose in a heavy duty corrugated shipping carton, and label "FRAGILE" to ensure careful handling. Ship only to the address specified by Product Service Hotline personnel.

Table 5-2. List of Manufacturers' Codes

<table>
<thead>
<tr>
<th>Mfr. Code</th>
<th>Manufacturer</th>
<th>Address</th>
<th>Mfr. Code</th>
<th>Manufacturer</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>AMP</td>
<td>AMP, Inc.</td>
<td>Harrisburg, PA</td>
<td>MOT</td>
<td>Motorola Semiconductor</td>
<td>Phoenix, AZ</td>
</tr>
<tr>
<td>AUG</td>
<td>Augat, Inc.</td>
<td>Attleboro, MA</td>
<td>NAT</td>
<td>National Semiconductor</td>
<td>Santa Clara, CA</td>
</tr>
<tr>
<td>CTS</td>
<td>CTS Corp.</td>
<td>Elkhart, IN</td>
<td>SCA</td>
<td>Scanbe, Inc.</td>
<td>El Monte, CA</td>
</tr>
<tr>
<td>FAIR</td>
<td>Fairchild Semiconductor</td>
<td>Mt. View, CA</td>
<td>TI</td>
<td>Texas Instruments</td>
<td>Dallas, TX</td>
</tr>
<tr>
<td>INTEL</td>
<td>Intel Corp.</td>
<td>Santa Clara, CA</td>
<td>COML</td>
<td>Available from any commercial source. Order by Description (OBD)</td>
<td></td>
</tr>
</tbody>
</table>
### Jumpers

<table>
<thead>
<tr>
<th>Jumpers</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>W1</td>
<td>A-B</td>
<td>N/A</td>
</tr>
<tr>
<td>W2</td>
<td>A-B</td>
<td>N/A</td>
</tr>
<tr>
<td>W3</td>
<td>A-B</td>
<td>N/A</td>
</tr>
<tr>
<td>W4</td>
<td>A-B</td>
<td>N/A</td>
</tr>
<tr>
<td>W5</td>
<td>A-B</td>
<td>N/A</td>
</tr>
<tr>
<td>W6</td>
<td>A-B</td>
<td>See table 2-4</td>
</tr>
<tr>
<td>E83-E64</td>
<td>Open</td>
<td>When installed enables common ground between chassis.</td>
</tr>
</tbody>
</table>
### Jumper Chart

<table>
<thead>
<tr>
<th>Jumper</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E3-E4</td>
<td>Open</td>
<td>See Table 2-4</td>
</tr>
<tr>
<td>E5-E8</td>
<td>Installed</td>
<td>See Table 2-4</td>
</tr>
<tr>
<td>E92-E93</td>
<td>Installed</td>
<td>N/A</td>
</tr>
<tr>
<td>E132-E133</td>
<td>Open</td>
<td>Install to allow use of AACK/ from Multibus interface.</td>
</tr>
</tbody>
</table>

### Glossary

- **AB0-AB13**: Address Bus 0-13
- **AD0-ADF**: Address Bits 0-F
- **ADV IO ADR**: Advance Input/Output Address
- **AUX RESET**: Auxiliary Reset
- **BHE**: Byte High Enable
- **CLK**: Clock
- **INIT**: Initialize
- **LOCK**: Lock
- **RESET**: Reset
- **S0**: Status Bit zero
- **S1**: Status Bit one
- **S2**: Status Bit two
- **SYS CLOCK**: System Clock
- **T21**: Timing Pulse 21
- **TIME OUT INTR**: Time Out Interrupt
### Jumper Table

<table>
<thead>
<tr>
<th>Jumper</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E107-108</td>
<td>Open</td>
<td>Install to use AACK</td>
</tr>
<tr>
<td>E112 through E128</td>
<td>E120-E126</td>
<td>See figure 2-1</td>
</tr>
<tr>
<td>E120-E130</td>
<td>E120-E130</td>
<td>See table 2-13</td>
</tr>
<tr>
<td>E131-E144</td>
<td>E144-E143</td>
<td>See table 2-13</td>
</tr>
<tr>
<td>E151-E152</td>
<td>Installed</td>
<td>See paragraph 2-24</td>
</tr>
<tr>
<td>WT A-B-C</td>
<td>A-C</td>
<td>N/A</td>
</tr>
<tr>
<td>S1</td>
<td>None</td>
<td>See figure 2-1</td>
</tr>
</tbody>
</table>

### Glossary

- **AACK**: Advance Acknowledge
- **ADV MEM WRT**: Advance Memory Write
- **ALE**: Address Latch Enable
- **ATRO-ATRF**: Address Transformed D-F
- **BPRO**: Bus Priority Out
- **BPRN**: Bus Priority In
- **BREQ**: Bus Request
- **BUS ADEN**: Bus Address Enable
- **BUS DEN**: Bus Data Enable
- **BUSY**: Busy
- **CBRQ**: Common Bus Request
- **DEN**: Data Enable
- **DPDRD**: Dual Port Read
- **DPWRT**: Dual Port Write
- **DT/R**: Data Transmit/Read
- **INH**: Inhibit
- **INTA**: Interrupt Acknowledge
- **INTA CYCLE**: Interrupt Acknowledge Cycle
- **IORD**: Input/Output Read
- **IOWC**: Input/Output Write Command
- **IOWT**: Input/Output Write
- **MEM RD**: Memory Read
- **MRDC**: Memory Read Command
- **MRTC**: Memory Write Command
- **OFF BD RAM ADDR**: Off Board Random Access Memory Address Request
- **OFF BD RAM CMD**: Off Board Random Access Memory Command
- **OFF BD RD**: Off Board Read
- **QMCE**: Qualified Master Cascade Enable
- **XACK**: Transfer Acknowledge
<table>
<thead>
<tr>
<th>Glossary</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>DAT0-DATF</td>
<td>Data Bits 0-F</td>
</tr>
<tr>
<td>DB0-DBF</td>
<td>Data Bus 0-F</td>
</tr>
<tr>
<td>DM0-DMF</td>
<td>Multibus Data 0-F</td>
</tr>
</tbody>
</table>
### Glossary

<table>
<thead>
<tr>
<th>Term</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADR0-ADR13</td>
<td>Address 0-13</td>
</tr>
<tr>
<td>AMO-AMF</td>
<td>Memory Address 0-F</td>
</tr>
<tr>
<td>BHEN</td>
<td>Byte High Enable</td>
</tr>
<tr>
<td>MSBHEN</td>
<td>Memory Byte High Enable</td>
</tr>
</tbody>
</table>
Figure 5-2. SBC 86/12A Schematic Diagram (Sheet 5 of 11)
<table>
<thead>
<tr>
<th>Jumper</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E94-E96</td>
<td>E94-E96</td>
<td>See table 2-4</td>
</tr>
<tr>
<td>E97-E99</td>
<td>E97-E96</td>
<td></td>
</tr>
<tr>
<td>S1</td>
<td>2718 Mode</td>
<td></td>
</tr>
</tbody>
</table>

**Glossary**

- **8251 CS**: 8251 Chip Select
- **8253 CS**: 8253 Chip Select
- **8255 CS**: 8255 Chip Select
- **8259 CS**: 8259 Chip Select
- **DB0-DBF**: Data Bus 0-F
- **I/O AACK**: Input/Output Advanced Acknowledge
- **ON BD ADR**: On Board Address
- **ON BD RAM REQ**: On Board Random Access Memory Request
- **PCS0**: PROM Chip Select 0
- **PCS1**: PROM Chip Select 1
- **PROM AACK**: Programmable Advanced Acknowledge
- **PROM I/O EN**: Programmable Input/Output Enable
**Jumpers**

<table>
<thead>
<tr>
<th>Jumpers</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E38-E40</td>
<td>E38-E40</td>
<td></td>
</tr>
<tr>
<td>E41-E43</td>
<td>E41-E43</td>
<td></td>
</tr>
<tr>
<td>E44-E47</td>
<td>Open</td>
<td></td>
</tr>
<tr>
<td>E48-E50</td>
<td>Open</td>
<td></td>
</tr>
<tr>
<td>E51-E52</td>
<td>Open</td>
<td></td>
</tr>
<tr>
<td>E53-E55</td>
<td>E54-E55</td>
<td></td>
</tr>
<tr>
<td>E56-E58</td>
<td>E56-E57</td>
<td></td>
</tr>
<tr>
<td>E59-E62</td>
<td>E59-E60</td>
<td></td>
</tr>
</tbody>
</table>

**Glossary**

- **51TX INTR**: 8251 Transmit Interrupt
- **51RX INTR**: 8251 Receive Interrupt
- **8202 CLK**: 8202 Clock
- **DATA SET RDY**: Data Set Ready
- **SEC CTS**: Secondary Clear to Send
- **SEC REC SIG**: Secondary Receive Signal
- **TMR0 INTR**: Timer 0 Interrupt
- **TMR1 INTR**: Timer 1 Interrupt
- **TRANS SIG ELE TIMING**: Transmit Signal Element Timing
### Jumper Table

<table>
<thead>
<tr>
<th>Jumper</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E95-E91</td>
<td>E96-E76, E96-E80</td>
<td>No Connection</td>
</tr>
<tr>
<td>87-89*</td>
<td></td>
<td>NMI Disable</td>
</tr>
</tbody>
</table>

### Glossary

<table>
<thead>
<tr>
<th>Term</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1st INTA DEN</td>
<td>First Interrupt Acknowledge Data Enable</td>
</tr>
<tr>
<td>BUS INTA DEN</td>
<td>Bus Interrupt Acknowledge Data Enable</td>
</tr>
<tr>
<td>INTR</td>
<td>Interrupt</td>
</tr>
<tr>
<td>Local INTA</td>
<td>Local Interrupt Acknowledge</td>
</tr>
<tr>
<td>Local INTA DE</td>
<td>Local Interrupt Acknowledge Data Enable</td>
</tr>
<tr>
<td>NMI</td>
<td>Non-maskable Interrupt</td>
</tr>
<tr>
<td>PA INTR</td>
<td>Port A Interrupt</td>
</tr>
<tr>
<td>PB INTR</td>
<td>Port B Interrupt</td>
</tr>
</tbody>
</table>
Figure 5-2. iSBC 86/12A Schematic Diagram (Sheet 8 of 11)
Jumpers

<table>
<thead>
<tr>
<th>Jumpers</th>
<th>Factory Default</th>
<th>Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>E105-E106</td>
<td>Installed</td>
<td>See table 2-9</td>
</tr>
<tr>
<td>E106-E108</td>
<td>Installed</td>
<td></td>
</tr>
<tr>
<td>W9 A-D</td>
<td>Installed</td>
<td></td>
</tr>
<tr>
<td>W9 A-C</td>
<td>Installed</td>
<td></td>
</tr>
</tbody>
</table>

Glossary

- **BCLK**: Bus Clock
- **CAS**: Column Address Strobe
- **CCLK**: Constant Clock
- **DMRO-DMRF**: Dynamic RAM Output 0-F
- **RAM AACK**: Random Access Memory Advance Acknowledge
- **RAM XACK**: Random Access Memory Transfer Acknowledge
- **WE1-WE2**: Write Enable 1 and 2
Glossary

DP ON BD ADR EN  | Dual Port On Board Address Enable
ON BD CMD EN    | On Board Command Enable
ON BD RAM ACK   | On Board Random Access Memory Acknowledge
RAM CS          | Random Access Memory Chip Select
SLAVE CMD EN    | Slave Command Enable
SLAVE DATA EN   | Slave Data Enable
A-1. INTRODUCTION

This appendix provides information required to modify a Model ASR-33 Teletypewriter for use with certain Intel iSBC 80 computer systems.

A-2. INTERNAL MODIFICATIONS

[WARNING]

Hazardous voltages are exposed when the top cover of the teletypewriter is removed. To prevent accidental shock, disconnect the teleprinter power cord before proceeding beyond this point.

Remove the top cover and modify the teletypewriter as follows:

a. Remove blue lead from 750-ohm tap on current source resistor, reconnect this lead to 1450-ohm tap. (Refer to figures A-1 and A-2.)

b. On terminal block, change two wires as follows to create an internal full-duplex loop (refer to figures A-1 and A-3):
   1. Remove brown/yellow lead from terminal 3; reconnect this lead to terminal 5.
   2. Remove white/blue lead from terminal 4; reconnect this lead to terminal 5.

c. On terminal block, remove violet lead from terminal 8; reconnect this lead to terminal 9. This changes the receiver current level from 60 mA to 20 mA.

A relay circuit card must be fabricated and connected to the paper tape reader drive circuit. The relay circuit card to be fabricated requires a relay, a diode, a thyractor, a small ‘vector’ board for mounting the components, and suitable hardware for mounting the assembled relay card.

A circuit diagram of the relay circuit card is included in figure A-4; this diagram also includes the part numbers of the relay, diode, and thyractor. (Note that a 470-ohm resistor and a 0.1 F capacitor may be substituted for the thyractor.) After the relay circuit card has been assembled, mount it in position as shown in figure A-5. Secure the card to the base plate using two self-tapping screws. Connect the relay circuit to the distributor trip magnet and mode switch as follows:

a. Refer to figure A-4 and connect a wire (Wire ‘A’) from relay circuit card to terminal L2 on mode switch. (See figure A-6.)

b. Disconnect brown wire shown in figure A-7 from plastic connector. Connect this brown wire to terminal L2 on mode switch. (Brown wire will have to be extended.)

c. Refer to figure A-4 and connect a wire (Wire ‘B’) from relay circuit board to terminal L1 on mode switch.

A-3. EXTERNAL CONNECTIONS

Connect a two-wire receive loop, a two-wire send loop, and a two-wire tape reader control loop to the external device as shown in figure A-4. The external connector pin numbers shown in figure A-4 are for interface with an RS232C device.

A-4. iSBC 530 TTY ADAPTER

The iSBC 530 TTY adapter, which converts RS232C signal levels to an optically isolated 20 mA current loop interface, provides signal translation for transmitted data, received data, and a paper tape reader relay. The iSBC 530 TTY adapter interfaces an Intel iSBC 80 computer system to a teletypewriter as shown in figure A-8.

The iSBC 530 TTY adapter requires +12V at 98 mA and -12V at 98 mA. An auxiliary supply must be used if the iSBC 80 system does not supply this power. A schematic diagram of the iSBC 530 TTY adapter is supplied with the unit. The following auxiliary power connector (or equivalent) must be procured by the user:

Connector, Molex 09-50-7071
Pins, Molex 08-50-0106
Polarizing Key, Molex 15-04-0219
Figure A-1. Teletype Component Layout

Figure A-2. Current Source Resistor

Figure A-3. Terminal Block
Figure A-4. Teletypewriter Modifications

Figure A-5. Relay Circuit

Figure A-6. Mode Switch
Figure A-7. Distributor Trip Magnet

Figure A-8. TTY Adapter Cabling
B-1. INTRODUCTION

This appendix provides information for installing the ISBC 300 Multimodule RAM Board and the ISBC 340 Multimodule EPROM Board on the ISBC 86/12A board.

B-2. ISBC 300 MULTIMODULE RAM INSTALLATION

The following steps explain how to unpack and install the ISBC 300 Multimodule RAM.

1. Unpack the ISBC 300 Multimodule RAM.
2. Inspect the ISBC 300 Multimodule RAM for damage. If damage exists, follow the instructions for repairs in Section 5 of this manual.
3. Remove the ISBC 86/12A board from the backplane and place it on a soft surface (preferably a piece of foam), component side up.
4. Remove IC (8202) at A70 from the ISBC 86/12A board.
5. Remove IC’s (74S373) at A71 and A91 from the ISBC 86/12A board.

NOTE

Save these IC’s, they will be reinstalled at a later step.

6. Insert the ISBC 300 Multimodule RAM mating pins into socket A70 and other mating pins, orienting the board as shown in figure B-1.

Figure B-1. ISBC 300 Multimodule RAM Orientation
7. Ensure the mating pins are aligned and carefully press the iSBC 300 Multimodule RAM into place by applying pressure at A1 of the iSBC 300 Multimodule RAM.

8. Place nylon spacer between the iSBC 86/12A board and the iSBC 300 Multimodule RAM board at one of the holes shown in figure B-1.

9. Insert screw from solder side through the iSBC 86/12A board, the spacer, and the iSBC 300 Multimodule RAM board.

10. Attach nut and tighten finger tight.

11. Repeat steps 8 through 10 for the other two holes.

12. Tighten all three screws, using a screw driver.

**CAUTION**
Do not overtighten screws as damage to the board could result.

13. Insert 8202 IC (removed in step 4) into location A1 on the iSBC 300 Multimodule RAM.

14. Insert the two 74S373 IC's (removed in step 5) into locations A2 and A11 on the iSBC 300 Multimodule RAM.

**CAUTION**
Ensure that the IC's are properly oriented in their sockets or they could be damaged when power is applied.

15. Remove two IC's, from the iSBC 86/12A board at locations A67 and A68.

16. Insert new IC, part number 142672-001, at location A67.

17. Insert new IC, part number 142672-002, at location A68.

18. Set the switches on S1 per figure 2-1.

**B-3. iSBC 340 MULTIMODULE EPROM INSTALLATION**

The following steps explain how to unpack and install the iSBC 340 Multimodule EPROM.

1. Unpack the iSBC 340 Multimodule EPROM.

2. Inspect the iSBC 340 Multimodule EPROM for damage. If damage exists, follow the instructions for repairs in Section 5 of this manual.

3. Install your EPROM's in the iSBC 340 Multimodule EPROM.

4. Trim the leads of the EPROMs at the end of the connectors.

**CAUTION**
Do not cut connectors.

5. Remove the iSBC 86/12A board from the backplane and place it on a soft surface (preferably a piece of foam), component side up.

6. Remove EPROM's from locations A28 and A46, if installed.

7. Bend all capacitors, that will reside under the iSBC 340 Multimodule EPROM, down against the board.

8. Hold the iSBC 86/12A board on edge and install two screws (reference figure B-2), from the solder side.

9. Place a spacer on each of the screws.

10. Install the iSBC 340 Multimodule EPROM on the iSBC 86/12A board in the location shown in figure B-2.

11. Press the iSBC 340 Multimodule EPROM into place by pressing at locations A3 and A6.

12. Install the two nuts and tighten them finger tight.

13. Tighten the two nuts with a screw driver.

**CAUTION**
Do not overtighten as damage to the board could result.

14. Reinstall the EPROM's removed in step 6 in locations A3 and A6, of the iSBC 340 board.

15. Set the switches on S1 per Table 2-4.

**B-4. SERVICE INFORMATION**

The following paragraphs provide a list of replaceable parts and service diagrams.

**B-5. REPLACEABLE PARTS**

Table B-1 provides a list of replaceable parts for the
Figure B-2. iSBC 340 Multimodule EPROM Orientation

iSBC 300 Multimodule RAM and iSBC 340 Multimodule EPROM. Table B-2 identifies and locates the manufacturers specified in the MFR CODE column in table B-1. Intel parts that are available on the open market are listed in the MFR CODE columns as "COML"; every effort should be made to procure these parts from a local (commercial) distributor.

B-6. SERVICE DIAGRAMS

The iSBC 300 Multimodule RAM parts location diagram and schematic diagram areae provided in figures B-3 and B-4, respectively. The iSBC 340 Multimodule PROM parts location diagram and schematic diagram are provided in figures B-5 and B-6, respectively.

Table B-1. Replaceable Parts, iSBC 300 Multimodule RAM and iSBC 340 Multimodule PROM

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>A3-10,12-19 (300)</td>
<td>IC, Intel 2117-4, Dynamic RAM Cap., Cer. 0.1μF, +80 -20%, 50V</td>
<td>2117-4</td>
<td>COML</td>
<td>16</td>
</tr>
<tr>
<td>C1-6 (340)</td>
<td>Cap., Cer., 0.1μF, +80 -20%, 50V</td>
<td>OBD</td>
<td>COML</td>
<td>6</td>
</tr>
<tr>
<td>C1-3,6,8,10,12-21,23, 26,27-24 (300)</td>
<td>Cap., mono, 0.01μF, ±10%, 15V Cap., tantalum, 22μF, ±10%, 15V</td>
<td>OBD</td>
<td>COML</td>
<td>26</td>
</tr>
<tr>
<td>C4,7,9,11,22,24,26,38 (300)</td>
<td>OBD</td>
<td>COML</td>
<td>8</td>
<td></td>
</tr>
<tr>
<td>C5,36,37 (300)</td>
<td>OBD</td>
<td>COML</td>
<td>3</td>
<td></td>
</tr>
</tbody>
</table>
Figure B-3. ISBC 300 Multimodule RAM Parts Location Diagram
Glossary

AB1-ABC 12 Address Bits 1-C
CSO/CS3/ Chip Select 0 through Chip Select 3.
(CSO) = PCS0; (CS3) = PCS3; CS1 and CS2/ are not
connected to ICC3800A board.)
DB0-DBF 16 Data Bus 0-F
CS/ Chip Select (CS/ = PCS2/)
PGM/PD Program/Power Down

NOTES: UNLESS OTHERWISE SPECIFIED
1. CONDITION VOLTAGES ARE -1 MICROAMPERES, 500 MICROamps, NOV.
2. THROUGH HOLE CONNECTIONS MATCH WITH SOCKET ON MOTHER BOARD.
3. IC'S #6, #8, #9, #10 MOTHER BOARD AS INSTR. NO. 6."
Figure B-4. iSBC Multimodule RAM Schematic
C-1. INTRODUCTION

This appendix provides information about two custom programmed PROMs that are used on the iSBC 86/12A board. One is used for on-board Chip Select and Address Selection (A65), and the other is used for Address Transformation (A67).

The PROMs that are shipped from the factory with the iSBC 86/12A, support the basic iSBC 86/12A board with or without the iSBC 340 Multimodule PROM. When the iSBC 300 Multimodule RAM is ordered, a new set of PROMs are shipped. These two configurations are described in the following paragraphs.

A third configuration is listed in table C-8 that may be programmed by the customer. This third configuration allows 2758's, 2716's, or 2732's to be installed on the iSBC 340 Multimodule EPROM memory expansion board.

C-2. ADDRESS TRANSFORMATION PROM

The iSBC 86/12A board has up to 64k of dual port RAM which may be accessed by both the on-board processor and the bus. The base address of RAM on-board is fixed. The base address of RAM from the bus may be set on any 8k (or 16k if iSBC 300 Multimodule RAM installed) boundary. It is the job of this PROM to transform the bus address to the proper on-board address for correct dual-port access.

The base address, as seen from the bus, is set by 4 switches: sections 1 through 4 of S1. These switches may be set in any one of 16 patterns, corresponding to the sixteen 8k or 16k boundaries in a 128k address space. Table C-1 shows how these switches are set.

The size of RAM available to the bus may also be specified. Two additional switches enable 8k, 16k, 24k, or 32k (16k, 32k, 48k, or 64k if iSBC 340 Multimodule RAM installed) to the bus. See table C-2.

RAM may also be totally disabled from the bus by selecting a 128k byte segment that is out of range. This is accomplished by jumpering post 112 to 114 and removing any other segment jumper.

The PROM used is an Intel 3625, 1k by 4 bipolar PROM. As such, it has 10 address inputs and 4 outputs. Four of the inputs, (PROM address lines A0,

<table>
<thead>
<tr>
<th>Table C-1. RAM Base Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-16</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>O</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
<tr>
<td>C</td>
</tr>
</tbody>
</table>

* C = Closed, O = Open
Table C-2. RAM Size

<table>
<thead>
<tr>
<th>S1*</th>
<th>RAM Available to Bus</th>
</tr>
</thead>
<tbody>
<tr>
<td>6-11</td>
<td>5-12</td>
</tr>
<tr>
<td>C</td>
<td>C</td>
</tr>
<tr>
<td>C</td>
<td>O</td>
</tr>
<tr>
<td>O</td>
<td>C</td>
</tr>
<tr>
<td>O</td>
<td>O</td>
</tr>
</tbody>
</table>

* C = Closed, O = Open

A1, A2, A3) connect directly to bus address lines ADRD/, ADRE/, ADFR/, and ADRE10/. These lines tell the PROM the current address on the bus so that the PROM may determine if that address is for the on-board RAM. Since the address lines on the bus are inverted, the address represented by the inputs will be the complement of the actual input. Four more address inputs (PROM lines A4, A5, A6, A7) connect to the base address switches to tell the PROM the top address of the RAM. The final two inputs (PROM lines A8 and A9) connect to the bus memory size switches to determine the amount of RAM available to the bus.

One of the PROM outputs (O4) is the RAM select line. This output is negative-true, that is, it goes low when an on-board RAM location is selected.

The other three outputs are the transformed address lines to the RAM. These lines are also negative-true. Output O1 = ATRD/, O2 = ATRE/, O3 = ATRF/.

For explanation purposes, the PROM is broken up into four 256-byte pages. Each page corresponds to one setting of the RAM size switches. Table C-3 shows the relation between switch settings and the PROM page selected.

**C-3. ADDRESS TRANSFORMATION PROM CONFIGURATIONS**

Table C-4 lists the address transformation PROM outputs for a factory shipped PROM (A67) to support the iSBC 86/12A board. For presentation, the PROM address is divided into 3 groups. The page number (A) specifies the upper 2 bits of the PROM address (A8 and A9). The right hand column of each table (B) specifies the middle 4 bits of the PROM address (A4, A5, A6, and A7). The top row of each table specifies the lower 4 bits of the PROM address (A0, A1, A2, and A3).

The PROM address may be found by combining the bits from groups A, B, and C. For example, a particular entry is on page 3, row 4, column 5. The address within the PROM is 345 hex.

Table C-5 lists the address transformation PROM outputs for a factory shipped PROM (A67) to support the iSBC 86/12A board and the iSBC 300 Multi-module RAM.

**C-4. MEMORY CHIP SELECT PROM**

The iSBC 86/12A can have up to 64k of on-board RAM and up to 8 EPROMs. These functional blocks are interconnected with several on-board buses. It is the job of the memory chip select PROM to select the proper block, send control signals to the bus enable logic, and generate an acknowledge if required.

The PROM used is an Intel 3625, 1k by 4 bipolar PROM. As such, it has 10 address inputs and 4 outputs. Eight of the inputs (PROM address input lines A0-A7) connect to CPU address lines ABB-AB12 so that the PROM may select the proper chips. PROM address input lines A8 and A9 connect to switch S1 positions 7 and 8 which allows the user to select 1 of 4 possible sizes for the EPROM block.

There are four output lines from the memory chip select PROM. The two lower outputs (O1 and O2) are encoded by a 2-to-4 line decoder. The outputs from the 2-to-4 line decoder select which set of EPROM chips will be enabled. The two upper outputs (O3 and O4) are used to control the on or off board RAM request and to enable or disable the 2-to-4 line decoder for PROM selection. Table C-6 lists the output coding from the memory chip select PROM and table C-7 lists the input and outputs for the 2-to-4 decoder.

Table C-3. RAM Size - PROM Page

<table>
<thead>
<tr>
<th>S1*</th>
<th>RAM Size</th>
<th>PROM Page</th>
<th>PROM Address Range</th>
</tr>
</thead>
<tbody>
<tr>
<td>8-9</td>
<td>7-10</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C</td>
<td>C</td>
<td>8k/16k</td>
<td>0</td>
</tr>
<tr>
<td>C</td>
<td>O</td>
<td>16k/32k</td>
<td>1</td>
</tr>
<tr>
<td>O</td>
<td>C</td>
<td>24k/48k</td>
<td>2</td>
</tr>
<tr>
<td>O</td>
<td>O</td>
<td>32k/64k</td>
<td>3</td>
</tr>
</tbody>
</table>

* C = Closed, O = Open
### Table C-4. Translator PROM Contents for Intel Part Number 9100134

#### Page 0  A = 0  8K of RAM (Part Number 9100134)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>4</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

#### Page 1  A = 1  16K of RAM

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>4</td>
<td>5</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

#### Page 2  A = 1  24K of RAM

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
<td>4</td>
<td>5</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>
### Table C-4. Translator PROM Contents for Intel Part Number 9100134 (Cont’d)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

### Table C-5. Translator PROM Contents for Intel Part Number 142672-001

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>F</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>
Table C-5. Translator PROM Contents for Intel Part Number 142672-001 (Continued)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 A B C D E F</td>
</tr>
<tr>
<td>0</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>1</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>2</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>3</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>4</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>5</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>6</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>7</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>8</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>9</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>A</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>B</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>C</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>D</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>E</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>F</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
</tbody>
</table>

Page 3  A = 3  64K of RAM

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 A B C D E F</td>
</tr>
<tr>
<td>0</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>1</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>2</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>3</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>4</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>5</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>6</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>7</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>8</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>9</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>A</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>B</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>C</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>D</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>E</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>F</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
</tbody>
</table>

C-5. MEMORY CHIP SELECT PROM CONFIGURATIONS

Table C-8 lists the chip select PROM outputs for a factory shipped PROM (A68) to support the iSBC 86/12A board and an iSBC 340 Multimodule EPROM. For presentation, the PROM address is divided into 3 groups. The page number (A) specifies the upper 2 bits of the PROM address (A8 and A9). The left hand column of each table (B) specifies the middle 4 bits of the PROM address (A4, A5, A6, and A7). The top row of each table specifies the lower 4 bits of the PROM address (A0, A1, A2, and A3).

The PROM address may be found by combining the bits from groups A, B, and C. For example, a particular entry is on page 2, row A, column 7. The address within the PROM is 2A7 hex.

Table C-9 lists the chip select PROM outputs for a factory shipped PROM (A68) to support the iSBC 86/12A board, the iSBC 300 Multimodule RAM, and the iSBC 340 Multimodule EPROM.

Table C-10 lists the chip select PROM outputs for a customer programmed PROM (A68) to support Intel 2758, 2716, or 2732 EPROMs, iSBC 300 Multimodule RAM, and iSBC 340 Multimodule EPROM. The PROM map listed in Table C-10 must be programmed into an Intel 3625 PROM by the customer. This PROM replaces the decode PROM located at position A68 on the iSBC 86/12A board. The factory shipped PROM at location A67 is not replaced.

In Table C-10 the “x” value represents one of the following two values:

1. X = F if iSBC 300 Multimodule RAM expansion option is not installed.

C.5
2. X = 7 if iSBC 300 Multimodule RAM option is installed.

C-6. SWITCH SETTINGS FOR 2758, 2716, OR 2732 EPROMS WITH THE iSBC 340 MULTIMODULE EPROM

Jumpers E94 through E99 and switch S1 must be reconfigured to accommodate 2716, 2732, or 2758 EPROMs. The following table lists the jumper and switch settings for 2716, 2732, or 2758 EPROMs.

<table>
<thead>
<tr>
<th>EPROM Type</th>
<th>Jumpers</th>
<th>Switch S1</th>
</tr>
</thead>
<tbody>
<tr>
<td>2758</td>
<td>E94-E95, E97-E98</td>
<td>ON</td>
</tr>
<tr>
<td>2716</td>
<td>E94-E96, E97-E98</td>
<td>ON, OFF</td>
</tr>
<tr>
<td>2732</td>
<td>E94-E96, E97-E99</td>
<td>OFF, ON</td>
</tr>
</tbody>
</table>

Table C-6. Memory Chip Select PROM Outputs

<table>
<thead>
<tr>
<th>Chip Output</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>O4</td>
<td>O3</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
</tr>
</tbody>
</table>

Table C-7. EPROM Select Coding

<table>
<thead>
<tr>
<th>Input</th>
<th>Output</th>
</tr>
</thead>
<tbody>
<tr>
<td>PCS0/</td>
<td>PCS1/</td>
</tr>
<tr>
<td>1A</td>
<td>1B</td>
</tr>
<tr>
<td>0 0</td>
<td>0 1</td>
</tr>
<tr>
<td>1 0</td>
<td>1 1</td>
</tr>
</tbody>
</table>
## Table C-8. Chip Select PROM Contents for Intel Part Number 9100129

### Page 0  A = 0  2K of EPROM (Part Number 9100129)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

### Page 1  A = 1  4K of EPROM (Type 2716)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

### Page 2  A = 2  8K of EPROM (Type 2732)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>
Table C-8. Chip Select PROM Contents for Intel Part Number 9100129 (Cont’d)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>8</td>
</tr>
</tbody>
</table>

Table C-9. Chip Select PROM Contents for Intel Part Number 142672-002

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

Page 1  A = 1  4K of EPROM (Type 2716)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>F</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

C-8
Table C-9. Chip Select PROM Contents for Intel Part Number 142672-002 (Continued)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>7</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

Page 3

A = 3 16K of EPROM (Type 2732 with ISBC 340 Multimodule EPROM)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>7</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>8</td>
</tr>
</tbody>
</table>

Table C-10. User Coded Chip Select PROM Contents

Page 0

A = 0 2K of EPROM (Type 2758)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>7</td>
</tr>
<tr>
<td>1</td>
<td>X</td>
</tr>
<tr>
<td>2</td>
<td>F</td>
</tr>
<tr>
<td>3</td>
<td>F</td>
</tr>
<tr>
<td>4</td>
<td>F</td>
</tr>
<tr>
<td>5</td>
<td>F</td>
</tr>
<tr>
<td>6</td>
<td>F</td>
</tr>
<tr>
<td>7</td>
<td>F</td>
</tr>
<tr>
<td>8</td>
<td>F</td>
</tr>
<tr>
<td>9</td>
<td>F</td>
</tr>
<tr>
<td>A</td>
<td>F</td>
</tr>
<tr>
<td>B</td>
<td>F</td>
</tr>
<tr>
<td>C</td>
<td>F</td>
</tr>
<tr>
<td>D</td>
<td>F</td>
</tr>
<tr>
<td>E</td>
<td>F</td>
</tr>
<tr>
<td>F</td>
<td>F</td>
</tr>
</tbody>
</table>

C-9
Table C-10. User Coded Chip Select PROM Contents (Continued)

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 A B C D E F</td>
</tr>
<tr>
<td>0</td>
<td>7 7 7 7 7 7 7 7 7 7 7 7 7 7 7</td>
</tr>
<tr>
<td>1</td>
<td>X X X X X X X X X X X X X X X X</td>
</tr>
<tr>
<td>2</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>3</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>4</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>5</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>6</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>7</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>8</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>9</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>A</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>B</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>C</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>D</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>E</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>F</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 A B C D E F</td>
</tr>
<tr>
<td>0</td>
<td>7 7 7 7 7 7 7 7 7 7 7 7 7 7 7</td>
</tr>
<tr>
<td>1</td>
<td>X X X X X X X X X X X X X X X X</td>
</tr>
<tr>
<td>2</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>3</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>4</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>5</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>6</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>7</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>8</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>9</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>A</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>B</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>C</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>D</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>E</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>F</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>B = Base Address Switches</th>
<th>C = Bus Address (Inverted)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 1 2 3 4 5 6 7 8 9 A B C D E F</td>
</tr>
<tr>
<td>0</td>
<td>7 7 7 7 7 7 7 7 7 7 7 7 7 7 7</td>
</tr>
<tr>
<td>1</td>
<td>X X X X X X X X X X X X X X X X</td>
</tr>
<tr>
<td>2</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>3</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>4</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>5</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>6</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>7</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>8</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>9</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>A</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>B</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>C</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>D</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>E</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
<tr>
<td>F</td>
<td>F F F F F F F F F F F F F F F F</td>
</tr>
</tbody>
</table>
1-1. INTRODUCTION

The iSBC 303 Multimodule Generator/Checker parity board (figure 1-1) generates and checks the parity for up to 64K of iSBC 86 based on board dynamic RAM. It is designed to be used in systems that require minimal error checking. There is no degradation in the operating speed of the base board when using the iSBC 303 Parity board.

1-2. DESCRIPTION

The iSBC 303 Parity board is software controlled thus requiring few interconnections not already provided by the base board interface. Parity error indication is provided by two interrupt lines as well as two on board indicators. On a write operation, the parity bit is established and stored in the iSBC 303 Parity board for each byte of data. On a read operation, each byte of data that is read is checked for proper parity. If an error exists, a visual as well as an interrupt indication is given.

The addition of an iSBC 303 Parity board does not preclude the adding of other Multimodule boards.

1-3. EQUIPMENT SUPPLIED

The following is supplied with the iSBC 303 Parity board:

- Schematic Diagram, dwg. no. 143172
- Two 20 pin spacer sockets (for use when an iSBC 300 RAM Multimodule board is installed)
- One 40 pin spacer socket (for use when an iSBC 300 RAM Multimodule board is installed)
- Two socket pins (for use when an iSBC 300 RAM Multimodule board is installed)
- Three long nylon spacers (for use when an iSBC 300 RAM Multimodule board is installed)
- Three short nylon spacers
- Three long nylon screws (for use when an iSBC 300 RAM Multimodule board is installed)
- Three short nylon screws (for use when an iSBC 300 RAM Multimodule board is not installed)
- Three nylon nuts

The spacers, screws, sockets, and nuts are used for mounting the iSBC 303 Parity board as described in section 2.

1-4. SPECIFICATIONS

Specifications for the iSBC 303 Parity board are listed in table 1-1.

![Figure 1-1. iSBC 303™ Parity Board](image)
Table 1-1. Specifications

<table>
<thead>
<tr>
<th>PHYSICAL CHARACTERISTICS</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Width:</td>
<td>6.096 cm (2.40 inches).</td>
<td></td>
</tr>
<tr>
<td>Length:</td>
<td>15.875 cm (6.25 inches).</td>
<td></td>
</tr>
<tr>
<td>Height:</td>
<td>0.594 cm (0.234 inches)</td>
<td>iSBC 303 Parity board only.</td>
</tr>
<tr>
<td></td>
<td>1.82 cm (0.718 inches)</td>
<td>iSBC 303 Parity board and iSBC base board.</td>
</tr>
<tr>
<td></td>
<td>2.667 cm (1.05 inches)</td>
<td>iSBC 303 Parity board, iSBC 300 Multimodule RAM board, and iSBC base board.</td>
</tr>
<tr>
<td>Weight:</td>
<td>70 gm (2.5 oz)</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ENVIRONMENTAL REQUIREMENTS</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Operating Temperature:</td>
<td>0° to 55°C (32° to 131°F).</td>
<td></td>
</tr>
<tr>
<td>Relative Humidity:</td>
<td>To 90% without condensation.</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>POWER REQUIREMENTS (Maximum)</th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>VCC = +5V ±5%</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Icc = 605 mA (Does not include current for the Dynamic RAM Controller and Memory Latches as they are considered part of the base board power)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
2-1. INTRODUCTION

This chapter provides instructions for installing the iSBC 303 Parity board. These instructions include unpacking and inspection, installation considerations, physical dimensions, and installation procedures.

2-2. UNPACKING & INSPECTION

Inspect the shipping carton immediately upon receipt for evidence of mishandling during transit. If the shipping carton is severely damaged or water-stained, request that the carrier’s agent be present when the carton is opened. If the carrier’s agent is not present when the carton is opened and the contents are damaged, keep the carton and packing material for the agent’s inspection.

For repairs to a product damaged in shipment contact the Intel Product Service HOTLINE to obtain a return authorization number and further instructions (see section 5-2). A purchase order will be required to complete the repair. A copy of the purchase order should be submitted to the carrier with your claim.

2-3. INSTALLATION CONSIDERATIONS

The iSBC 303 Parity board is designed to mount on an ISBC 86/12 or ISBC 86/12A board with or without an ISBC 300 Multimodule RAM board. Installation considerations such as power, cooling, mounting and physical size requirements, are outlined in the following paragraphs.

2-4. POWER REQUIREMENTS

The board requires +5V (±0.25V) at 605 mA maximum. This power requirement does not include current for the Dynamic RAM Controller and Memory Latches as they are considered part of the base board power. All power is drawn from the host board through the mounting connectors.

2-5. COOLING REQUIREMENTS

The iSBC 303 Parity board dissipates 43.1 gram-calories/minute (0.174 BTU/minute) and adequate circulation of air must be provided to prevent a temperature rise above 55°C (131°F). If operation to 60°C is required, a minimum air flow of 200 linear feet/minute will be required.

2-6. PHYSICAL DIMENSIONS

Physical dimensions of the iSBC 303 Parity board are as follows:

a. Width: 6.096 cm (2.40 inches).
c. Height: 0.594 cm (0.234 inches) ISBC 303 Parity board only.
   1.82 cm (0.718 inches) ISBC 303 Parity board and ISBC base board.
   2.667 cm (1.05 inches) ISBC 303 Parity board, ISBC 300 Multimodule RAM
   board, and ISBC base board.
d. Weight: 70 grams (2.5 ounces)

2-7. CONNECTOR CONFIGURATION

Connector J2 provides the user interface to the base board. Table 2-1 lists the recommended mating shells and pins. The signals found on each pin of the J2 connector are listed in table 2-2 and the descriptions of the signal functions are also listed. Table 2-3 lists the DC characteristics of each of the signals on the J2 connector. Table 2-4 lists the AC characteristics of each of the signals on the J2 connector and figure 2-1 shows the timing of each of these signals.

2-8. JUMPER CONFIGURATION

The iSBC 303 Parity board includes three jumper-selectable options to allow the user to configure the board for his particular application. Table 2-5 summarizes these options and lists the grid reference locations of the jumpers as shown in figure 5-2 (schematic diagram). For convenience, all the jumper connections are made on connector J1.

Study table 2-5 carefully while making reference to figure 5-2. If the default (factory configuration) jumpers are appropriate for a particular function, no further action is required. If, however, a different configuration is required, reconfigure the jumpers as specified in table 2-5.
Table 2-1. Recommended J2 Mating Connector Components

<table>
<thead>
<tr>
<th>Shells</th>
<th>Pins</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Reeled</td>
</tr>
<tr>
<td>AMP 87456-4</td>
<td>86491-3</td>
</tr>
<tr>
<td>BERG 65043-033</td>
<td>47564</td>
</tr>
</tbody>
</table>

Table 2-2. Connector J2 Pin Assignments

<table>
<thead>
<tr>
<th>Pin</th>
<th>Mnemonic</th>
<th>Functional Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>2</td>
<td>INTR</td>
<td>Interrupt Request — Indicates that a maskable interrupt has occurred.</td>
</tr>
<tr>
<td>3</td>
<td>Reserved</td>
<td>Reserved</td>
</tr>
<tr>
<td>4</td>
<td>NMI</td>
<td>Nonmaskable Interrupt — Indicates that a nonmaskable interrupt has occurred.</td>
</tr>
<tr>
<td>5</td>
<td>LOW</td>
<td>Low Check Bit — Indicates the status of the low check bit.</td>
</tr>
<tr>
<td>6</td>
<td>NMIMASK</td>
<td>Nonmaskable Interrupt Enable — This signal is used to enable/disable the nonmaskable interrupt.</td>
</tr>
<tr>
<td>7</td>
<td>HI</td>
<td>High Check Bit — Indicates the status of the high check bit.</td>
</tr>
<tr>
<td>8</td>
<td>PFIN</td>
<td>Power Fail Interrupt — This externally generated signal may be OR’ed into the NMI interrupt logic to provide a power fail interrupt input to the NMI interrupt of the base board.</td>
</tr>
</tbody>
</table>

Table 2-3. DC Characteristics

<table>
<thead>
<tr>
<th>Signals</th>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Test Conditions</th>
<th>Min.</th>
<th>Max.</th>
<th>Units</th>
</tr>
</thead>
<tbody>
<tr>
<td>HI</td>
<td>Vol</td>
<td>Output Low Voltage</td>
<td>I_{OL} = 20 mA</td>
<td>0.5</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>LOW</td>
<td>Vol</td>
<td>Output High Voltage</td>
<td>I_{OH} = -1 mA</td>
<td>2.5</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>&amp;OH</td>
<td>Capacitive Load</td>
<td></td>
<td>15</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>INTR</td>
<td>Vol</td>
<td>Output Low Voltage</td>
<td>I_{OL} = 12 mA</td>
<td>0.5</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Vol</td>
<td>Output High Voltage</td>
<td>I_{OH} = 800 μA</td>
<td>2.5</td>
<td>V</td>
<td>pF</td>
</tr>
<tr>
<td></td>
<td>&amp;CL</td>
<td>Capacitive Load</td>
<td></td>
<td>15</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>NMI</td>
<td>Vol</td>
<td>Output Low Voltage</td>
<td>I_{OL} = 8 mA</td>
<td>0.4</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td></td>
<td>Vol</td>
<td>Output High Voltage</td>
<td>I_{OH} = 400 μA</td>
<td>2.4</td>
<td>V</td>
<td>pF</td>
</tr>
<tr>
<td></td>
<td>&amp;CL</td>
<td>Capacitive Load</td>
<td></td>
<td>15</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>NMIMASK</td>
<td>Vol</td>
<td>Output High Voltage</td>
<td>I_{OH} = -2.30 μA</td>
<td>2.4</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>IH</td>
<td>V_{IH}</td>
<td>Input Current at HIGH V</td>
<td>V_{IH} = 2.4V</td>
<td>-1.4</td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td>IL</td>
<td>V_{IL}</td>
<td>Input Current at LOW V</td>
<td>V_{IL} = 0.4V</td>
<td>40</td>
<td>μA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>&amp;CL</td>
<td>Capacitive Load</td>
<td></td>
<td>15</td>
<td>pF</td>
<td></td>
</tr>
<tr>
<td>PFIN</td>
<td>I_{IH}</td>
<td>Input Current at HIGH V</td>
<td>V_{IH} = 2.4V</td>
<td>-0.4</td>
<td>mA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>I_{IL}</td>
<td>Input Current at LOW V</td>
<td>V_{IL} = 0.5V</td>
<td>50</td>
<td>μA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>&amp;CL</td>
<td>Capacitive Load</td>
<td></td>
<td>15</td>
<td>pF</td>
<td></td>
</tr>
</tbody>
</table>

*Capacitive load values are approximations.
Table 2-4. AC Characteristics

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Minimum (ns)</th>
<th>Maximum (ns)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$t_1$</td>
<td></td>
<td>70</td>
<td>WE1/ high to INTR, HI, LOW clear</td>
</tr>
<tr>
<td>$t_2$</td>
<td></td>
<td>112</td>
<td>WE1/ high to NMI clear</td>
</tr>
<tr>
<td>$t_3$</td>
<td></td>
<td>104</td>
<td>NMIMASK high to NMI clear</td>
</tr>
<tr>
<td>$t_4$</td>
<td>30</td>
<td></td>
<td>NMIMASK pulse width</td>
</tr>
<tr>
<td>$t_5$</td>
<td>-400</td>
<td>72</td>
<td>DPRD/ high to INTR out</td>
</tr>
<tr>
<td>$t_6$</td>
<td>-390</td>
<td>80</td>
<td>DPRD/ high to NMI out</td>
</tr>
<tr>
<td>$t_7$</td>
<td>10 ms</td>
<td>81</td>
<td>Power up to first access</td>
</tr>
<tr>
<td>$t_8$</td>
<td>-391</td>
<td></td>
<td>DPRD/ high to HI, LOW out</td>
</tr>
</tbody>
</table>

Table 2-5. Jumper Options

<table>
<thead>
<tr>
<th>Jumper Installed</th>
<th>Function</th>
<th>Grid Ref.</th>
</tr>
</thead>
<tbody>
<tr>
<td>J1-1 to J1-2</td>
<td>Selects address 0000H.</td>
<td>12D7</td>
</tr>
<tr>
<td>J1-3 to J1-4</td>
<td>Enables the use of PFIN.</td>
<td>12B4</td>
</tr>
<tr>
<td>J1-3 to J1-5</td>
<td>Disables the use of PFIN.</td>
<td>12B4</td>
</tr>
<tr>
<td>J1-7 to J1-8</td>
<td>Inverts the NMIMASK function.</td>
<td>12B6</td>
</tr>
</tbody>
</table>

2.9. INSTALLATION PROCEDURE

The iSBC 303 Parity board is designed to be mounted atop the iSBC 86/12A board by way of socket pins that provide both the mechanical and electrical interface. The majority of the pins plug into IC sockets A70 (J1), A71 (J2), and A91 (J3) of the base board. The two write enable signals (WE1/ and WE2/) are provided via isolated socket pins J5 and J6 respectively. There are two configurations that must be considered when installing the iSBC 303 Parity Board. The first configuration that will be described is when the iSBC 303 Parity board is being mounted directly on the base board. The second configuration that will be described is when the iSBC 303 Parity board is being mounted on top of an iSBC 300 Multimodule RAM board.

The following steps explain how to install the iSBC 303 Parity board directly on the base board (iSBC 300 Multimodule RAM not installed).

Always turn off power before removing or installing any board.

1. Remove the base board from the backplane and place it on a soft surface (preferably a piece of foam), component side up.
2. Remove IC (8202) at A70 from the base board.
3. Remove IC's (74S373) at A71 and A91 from the base board.

NOTE

Save these IC's, they will be reinstalled at a later step.

4. Insert the iSBC 303 Parity board mating pins into socket A70 and other mating pins, orienting the board as shown in figure 2-2.
5. Ensure the mating pins are aligned and carefully press the iSBC 303 Parity board into place by applying pressure at U1 of the iSBC 303 Parity board.
6. Place a nylon spacer (use short spacers) between the base board and the iSBC 303 Parity board at one of the holes shown in figure 2-2.
7. Insert a screw (use short screws) from the solder side through the base board, the spacer, and the iSBC 303 Parity board.
8. Attach a nut and tighten finger tight.
9. Repeat steps 6 through 8 for the other two holes.
10. Tighten all three screws.

CAUTION

Do not overtighten screws as damage to the board could result.
Figure 2-1. User Interface Timing Relationship
11. Insert 8202 IC (removed in step 2) into location U1 on the iSBC 303 Parity board.

12. Insert the two 74S373 IC's (removed in step 3) into locations U2 and U10 on the iSBC 303 Parity board.

**CAUTION**

Ensure that the IC's are properly oriented in their sockets or they will be damaged when power is applied.

The following steps explain how to install the iSBC 303 Parity board on top of an iSBC 300 Multimodule RAM board that is installed on the base board.

**CAUTION**

Always turn off power before removing or installing any board.

1. Remove the base board (with the iSBC 300 Multimodule RAM board) from the backplane and place it on a soft surface (preferably a piece of foam), component side up.

2. Remove IC (8202) at location A1 on the iSBC 300 Multimodule RAM board.

3. Remove IC (74S373) at location A2 on the iSBC 300 Multimodule RAM board.

4. Remove IC (74S373) at location A11 on the iSBC 300 Multimodule RAM board.

**NOTE**

Save these IC's, they will be reinstalled at a later step.

5. Insert 40 pin spacer socket in location A1 on the iSBC 300 Multimodule RAM board.

6. Insert 20 pin spacer sockets in locations A2 and A11 on the iSBC 300 Multimodule RAM board.

7. Place a socket spacer pin on P5 on the iSBC 300 Multimodule RAM board.

8. Place a socket spacer pin on P6 on the iSBC 300 Multimodule RAM board.

9. Remove the three screws holding the iSBC 300 Multimodule RAM board in place (leave spacers in place).

10. Insert the iSBC 303 Parity board mating pins into socket A1 and other mating pins of the iSBC 300 Multimodule RAM board, orienting the board as shown in figure 2-3.

11. Ensure the mating pins are aligned and carefully press the iSBC 303 Parity board into place by applying pressure at U1 of the iSBC 303 Parity board.

12. Place a nylon spacer (use long spacers) between the iSBC 300 Multimodule RAM board and the iSBC 303 Parity board at one of the holes shown in figure 2-3.

13. Insert a nylon screw (use long screws) from the solder side through the base board, through the iSBC 300 Multimodule RAM board, through the spacer, and the iSBC 303 Parity board.

14. Attach a nut and tighten finger tight.

15. Repeat steps 12 through 14 for the other two holes.

16. Tighten all three screws.

**CAUTION**

Do not overtighten screws as damage to the board could result.

17. Insert 8202 IC (removed in step 3) into location U1 on the iSBC 303 Parity board.

18. Insert the two 74S373 IC's (removed in steps 3 and 4) into locations U2 and U10 on the iSBC 303 Parity board.

**CAUTION**

Ensure that the IC's are properly oriented in their sockets or they will be damaged when power is applied.
Figure 2-2. iSBC 303™ Parity Board Orientation

Figure 2-3. iSBC 303™ Parity Board and iSBC 300™ Multimodule RAM Board Orientation
3-1. INTRODUCTION

This chapter provides the programming information for the iSBC 303 Parity board.

3-2. PROGRAMMING CONSIDERATIONS

The four functions of the iSBC 303 board are controlled by a control byte that is stored in RAM. This control byte is written by the programmer any time the functions are to change or when the board is initialized. The on board address of the control port is selectable for either 0H (J1-2 to J1-1 jumpered) or 400H (J1-2 to J1-1 not jumpered) where the default address is 400H. This corresponds to address Base + 0 or Base + 400H for dual port access. Base is the lowest dual port RAM address as seen from the Multibus interface. If it is desired to access the control byte from the Multibus interface, there must be no protected RAM. (i.e., all base board memory must be available to the Multibus interface. Figure 3-1 shows the control byte format. Note that four simultaneous functions may be performed by writing one byte. On power-up, this control byte is cleared which clears and masks both interrupts, clears and masks the LED indicators, and places the parity logic in the odd parity mode. The RAM address corresponding to the control byte address is also written when a command is written. As a result a copy of the current command byte is always stored in RAM automatically. Note that on power up the command image in RAM is not initialized.

![Figure 3-1. Control Byte Format](image)
4-1. INTRODUCTION

This chapter provides a functional description and a circuit analysis of the iSBC 303 Parity board. Figure 4-1 is a simplified block diagram of the iSBC 303 Parity Board.

4-2. FUNCTIONAL DESCRIPTION

A brief description of the functional blocks of logic comprising the iSBC 303 Parity board is given in the following paragraphs. An operational circuit analysis is given beginning with paragraph 4-15.

4-3. PARITY GENERATOR/CHECKER

This block includes three major functions that are described in the following paragraphs.

4-4. PARITY MEMORY. The parity memory is the heart of the operation of the iSBC 303 board. It contains 64K bit of dynamic RAM divided into two 32K bit banks. Its purpose is to store one parity bit for each byte written on a memory write operation and to provide a parity check bit for each byte read during a memory read operation.

4-5. PARITY GENERATION. The parity generate mode is entered during a memory write cycle. The WR/ signal going active forces one input on each of the parity generate circuits U3 and U11 to go low. The input bits from the data bus latches are also input to the parity generate circuits. A parity bit is then generated and written into the parity memory at the completion of the memory write cycle.

Figure 4-1. iSBC 303™ Parity Board Block Diagram
4-6. PARITY CHECKER. The parity check mode is entered during a memory read cycle. In this mode WR/ is high (inactive) which enables one leg of each of the input ANDs to the parity check circuits U3 and U11. This allows the parity bit stored in memory to appear at one input of the parity check circuits. In addition, data from the data bus latches appears at the remaining inputs of the check circuits. The check circuits then produce a check bit which is latched by the error latches on the rising edge of CAS/. If the check bit that was latched was a high, it indicates an error and the corresponding error indicator (HIPAR or LOPAR) will be turned on.

4-7. MEMORY REFRESH CONTROL

The parity memory (U13, U14, U15, U16) is refreshed by an 8202 Dynamic RAM Controller (U1). This controller automatically refreshes the parity memory.

4-8. DATA BUS LATCHES

The data bus latches (U2, U10) latch the data from the base board data bus. They are under control of the base board.

4-9. COMMAND DECODE

The command decode circuitry is basically an address decoder and a 4-bit latch. The address bits from the address bus are applied to the address decoder. All the bits must be zero except for the AMA bit. The AMA bit is applied to U6 which acts as a programmable inverter. Depending on the address selection jumper (J1-1 - J1-2), the address selected will be 0H or 400H. The output of the decoder enables the 4-bit latch U5 on the rising edge of WE1 /. U5 latches the command data from the data bus (DM0-DM3). The output from the 4-bit latch determines the functions that are performed.

4-10. ERROR INTERRUPTS

There are two interrupt lines available to the base board. They are described in the following paragraphs.

4-11. INTR. The INTR error interrupt line indicates to the base board that a parity error was detected. It is designed to be used in conjunction with a base board interrupt that is maskable. Therefore no onboard mask is provided on the iSBC 303 Parity board. The INTR latch, once set, will remain set until it is cleared by a software command or power on reset.

4-12. NMI. The NMI error interrupt line indicates to the base board that a parity error was detected. It can also be jumpered to allow an external power fail interrupt to activate this circuit. It is designed to be used in conjunction with a base board interrupt that is nonmaskable. Therefore onboard mask circuitry is provided on the iSBC 303 Parity board. The NMI latch, once set, will remain set until it is cleared by a software command, power on reset, or by use of the mask pin.

4-13. VISUAL ERROR INDICATORS

Two LEDs are provided on the iSBC 303 Parity boards to indicate when a parity error has occurred. One LED indicates parity check errors from the high byte of data and the other indicates check errors from the low byte of data. The LED latches, when set, will remain set until cleared by a software command or power on reset.

4-14. ERROR INDICATOR SIGNALS

Two error indicator status signals are available to the base board. These signals can be checked by the base board when an error interrupt occurs. The two signals reflect the same information as the LEDs mounted on the board. The error indicator status latches, when set, will remain set until cleared by a software command or power on reset.

4-15. CIRCUIT ANALYSIS

The schematic diagram for the iSBC 303 Parity board is given in figure 5-2. The schematic diagram consists of two sheets, each of which includes grid coordinates. Signals that traverse from one sheet to another have a letter assigned in a box that appears at the source and the destination.

Both active-high and active-low signals are used. A signal mnemonic that ends with a virgule (e.g., PCS/) denotes that the signal is active low (<0.4V). Conversely, a signal mnemonic without a virgule (e.g., LOW) denotes that the signal is active high (>2.0V).

4-16. PARITY MEMORY

The parity memory consists of U13, U14, U15, and U16. U13 and U15 contain the parity bits for 0-32K of memory and U14 and U16 contain the parity bits for 33-64K of memory. The RAS/0 signal from the dynamic RAM controller (U1) selects U13 and U15 and RAS1/ selects U14 and U16.
4-17. PARITY GENERATION

When the WR/ signal goes active, it places a low signal on U8-5,10. This low on the inputs to U8 causes a low to be placed on one input of each of the parity generate circuits U3-4 and U11-4. The other inputs to the parity generate circuits come from data bus latches U2 and U10. If there are an odd number of bits on the input to U3, then the output of U3-5 will be low. If there are an even number of bits on the input to U3, then the output of U3-5 will be high. The same is true for U11. These outputs from the parity generation circuits are applied to the inputs of exclusive-OR gate U6. If the iSBC 303 Parity board has been programmed for odd parity and the inputs to U6-4,9 are low, the outputs of U6 will be low indicating odd parity. This low is written into the parity memory at the end of the memory write cycle.

4-18. PARITY CHECKER

During a read cycle the WR/ signal remains high (inactive) which enables one leg of each of the input ANDs (U8) to the parity check circuit. This allows the parity bit stored in memory (U13, U14, U15, U16) to appear at one input of the parity check circuits (U3, U11). In addition, data from the data bus latches appears at the remaining inputs of the check circuits. The check circuits then produce a check bit which is applied to one input of U6. If the iSBC 303 Parity board has been programmed for odd parity and the inputs to U6-4,9 are low, the outputs of U6 will be low indicating no parity error. If the output of U6-6 or U6-8 is high, it indicates an error and the U17 latches will be set. In addition, one of the U18 latches will be set to indicate that the error was on the high byte or the low byte.

4-19. DATA BUS LATCHES

The information on the data bus is latched into the data bus latches (U2, U10) when XACK/ goes high. The output of the data bus latches is enabled when DPRD/ goes low. XACK/ and DPRD/ are generated on the base board.

4-20. INTR INTERRUPT

If either the LOPAR or HIPAR signal on OR U9 pins 4 and 5 is high, latch U17-5 will be set when CAS/ goes high at the end of a read cycle. Latch U17-5 setting creates the INTR interrupt signal.

4-21. NMI INTERRUPT

If either the LOPAR or HIPAR signal on OR U9 pins 4 and 5 is high, latch U17-9 will be set when CAS/ goes high at the end of a read cycle if the latch is not masked by NMIMASK. The NMIMASK signal is controlled by the base board. If jumper J1-7 to J1-8 is not installed, NMIMASK going high will reset latch U17-9 and hold it reset until the signal goes low. Holding NMIMASK high prevents an NMI interrupt from being generated. If jumper J1-7 to J1-8 is installed, the NMIMASK signal functions are inverted.

4-22. HI/LO INDICATORS

When an INTR interrupt occurs, the value of LOPAR and HIPAR is cycled into latches U18. If either signal is high the latch will be set and the corresponding LED will be set. The outputs of U18 are also available to the base board for sensing which byte contained the parity error.

4-23. ADDRESS AND COMMAND DECODE

Address bits AM1-AM7 are decoded by U6, U12, and U4. The two addresses that are valid for the iSBC 303 Parity board are Base 0000H and Base 0400H. If address 0000H is to be used jumper J1-1 - J1-2 must be installed. When an address of all zeros is applied to the iSBC 303 Parity board and jumper J1-1 to J1-2 is installed, the output of U7-6 will go low and enable latch U5. If any address bit is not zero, the output of U7-6 will remain high and latch U5 will not be enabled. When jumper J1-1 to J1-2 is not installed, the AMA bit must be one to enable latch U5 (this corresponds to address 0400H). Exclusive OR U6 acts as an inverter when the jumper is not installed.

When latch U5 is enabled, it allows the command byte to be latched. The output from the command byte determines the conditions that the iSBC Parity board will operate under.
CHAPTER 5
SERVICE INFORMATION

5-1. INTRODUCTION

This chapter provides a list of replaceable parts, service diagrams, and service assistance instructions for the iSBC 303 Parity board.

5-2. DIAGNOSTIC TEST

The EVEN/ODD signal on the iSBC 303 Parity board may be used as a forced error signal for diagnostic purposes. To force an error, the EVEN/ODD signal must be inverted (with respect to the normal operating level), under program control, during a memory write. After the data has been written, the EVEN/ODD signal should be returned to its normal operating state. When the forced error location is subsequently read, a parity error should occur allowing a check of the parity circuitry.

Note that whenever a command is written to the iSBC Parity board, the corresponding RAM address is written including a parity bit. In the diagnostic mode when error forcing is complete, the EVEN/ODD signal must be returned to its normal state which invokes a memory write. This will force a bad parity bit at the command address. If the command address is subsequently read, a parity error will occur. Therefore, it is recommended that after exiting the diagnostic mode, a new command byte be written to the iSBC 303 Parity board to correct the bad parity bit.

In the diagnostic mode when forcing errors, any writes to the base board memory will generate a bad parity bit. This includes CALL's, PUSH's and any instructions which automatically perform writes that are hidden to the user. If after one of these instructions is executed, the user returns the EVEN/ODD bit to its normal state before the corresponding read (RET, POP, etc) a parity error will occur. Therefore, caution must be used when using these types of instructions in the diagnostic mode.

A suggested method of preventing this problem is to repeat the same programming steps with the parity set to its normal state.

5-3. REPLACEABLE PARTS

Table 5-1 provides a list of replaceable parts for the iSBC 303 Parity board. Table 5-2 identifies and locates the manufacturers specified in the MFR CODE column in table 5-1. Intel parts that are available on the open market are listed in the MFR CODE column as "COML"; every effort should be made to procure these parts from a local (commercial) distributor.

5-4. SERVICE DIAGRAMS

The iSBC 303 Parity board parts location diagram and schematic diagram are provided in figures 5-1 and 5-2, respectively. On the schematic diagram, a signal mnemonic that ends with a slash (e.g., PCS/) is active low. Conversely, a signal mnemonic without a slash (e.g., INTR) is active high.

5-5. SERVICE AND REPAIR ASSISTANCE

United States Customers can obtain service and repair assistance by contacting the Intel Product Service Hotline in Phoenix, Arizona. Customers outside the United States should contact their sales source (Intel Sales Office or Authorized Distributor) for service information and repair assistance.

Before calling the Product Service Hotline, you should have the following information available:

a. Date you received the product.
b. Complete part number of the product (including dash number). On boards, this number is usually silk-screened onto the board. On other MCSD products, it is usually stamped on a label.
c. Serial number of product. On boards, this number is usually stamped on the board. On other MCSD products, the serial number is usually stamped on a label.
d. Shipping & billing addresses.
e. If your Intel product warranty has expired, you must provide a purchase order number for billing purposes.
f. If you have an extended warranty agreement, be sure to advise the Hotline personnel of this agreement.
Use the following numbers for contacting the Intel Product Service Hotline:

**TELEPHONE**

All U.S. locations, except Alaska, Arizona, & Hawaii:

(800) 528 - 0595

All other locations: (602) 869 - 4600

**TWX NUMBER: 910 - 951 - 1330**

Always contact the Product Service Hotline before returning a product to Intel for repair. You will be given a repair authorization number, shipping instructions, and other important information which will help Intel provide you with fast, efficient service. If you are returning the product because of damage sustained during shipment or if the product is out of warranty, a purchase order is required before Intel can initiate the repair.

In preparing the product for shipment to the Repair Center, use the original factory packing material, if possible. If this material is not available, wrap the product in a cushioning material such as Air Cap TH - 240, manufactured by the Sealed Air Corporation, Hawthorne, N.J. Then enclose in a heavy duty corrugated shipping carton, and label "FRAGILE" to ensure careful handling. Ship only to the address specified by Product Service Hotline personnel.

### 5-6. INTERNAL SIGNALS

Internal board signals which traverse from one sheet to another in figure 5-2 are identified by a single alpha character within a box (e.g., C). The signal mnemonic is shown adjacent to the boxed character, along with the source or destination sheet number (e.g., SH 2, PCS/ B). Signals coming into the sheet are shown on the left side of the diagram. Conversely, signals leaving the sheet are shown on the right side.

To follow a signal from one sheet to another, read the sheet number and boxed character, then look for the same boxed character on the indicated sheet. For example, if you are going to trace the path of WE1/ when it exits sheet 2, the first step would be to turn to the indicated sheet. Since WE1/ will be entering sheet 1, as shown on sheet 2, look for the D symbol on the left side of the sheet. Notice that the inputs also list the source sheet number (sheet 2 in this example).

Each signal will keep the same boxed character throughout figure 5-2. This will enable you to trace the signal to any sheet with minimal effort.

The internal board signal mnemonics are listed and defined in table 5-3. The signals are listed according to boxed code alphabetical order.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>C1-4, 6-11, 13, 14</td>
<td>Cap., Cer, 0.10 µF, ±80 -20%, 50V</td>
<td>MA205E104ZAA</td>
<td>AVX</td>
<td>12</td>
</tr>
<tr>
<td>C5</td>
<td>Cap., Tant, 22 µF, ±10%, 15V</td>
<td>T110B226K015AS</td>
<td>KEM</td>
<td>1</td>
</tr>
<tr>
<td>C12</td>
<td>Cap., Tant, 10 µF, ±10%, 20V</td>
<td>T110B106K20AS</td>
<td>KEM</td>
<td>1</td>
</tr>
<tr>
<td>CR1</td>
<td>Diode, IN914B, 25W, 75V</td>
<td>IN4148</td>
<td>FAIR</td>
<td>1</td>
</tr>
<tr>
<td>CR2, 3</td>
<td>Diode, LED, RED</td>
<td>550-2406</td>
<td>DIALC</td>
<td>2</td>
</tr>
<tr>
<td>E1,4</td>
<td>Term, PCB, Turret switch</td>
<td>2106B</td>
<td>USECO</td>
<td>2</td>
</tr>
<tr>
<td>J1,2</td>
<td>Header, 8-pin</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R1-4</td>
<td>Res., Carb, 10K, 1/4W, ±5%</td>
<td>CB1035</td>
<td>AB</td>
<td>4</td>
</tr>
<tr>
<td>R5</td>
<td>Res., Carb, 100K, 1/4W, ±5%</td>
<td>CB1045</td>
<td>AB</td>
<td>1</td>
</tr>
<tr>
<td>R6,7</td>
<td>Res., Carb, 270 ohms, 1/4W, ±5%</td>
<td>CB2715</td>
<td>AB</td>
<td>2</td>
</tr>
<tr>
<td>U3,11</td>
<td>IC, 74S280, Odd/Even Parity Generator/Checker</td>
<td>SN74S280N</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>U4,12</td>
<td>IC, 7425, Positive NOR-Gate</td>
<td>SN7425N</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td>U5</td>
<td>IC, 74LS173, 4-Bit Register</td>
<td>SN74LS173N</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>U6</td>
<td>IC, 74S86, Exclusive OR-Gate</td>
<td>SN74S86</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>U7</td>
<td>IC, 74S86, Exclusive OR-Gate</td>
<td>SN74S86</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>U8</td>
<td>IC, 74LS08, Quad 2-Input AND Gate</td>
<td>SN74LS08</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>U9</td>
<td>IC, 74LS32, Quad 2-Input OR Gate</td>
<td>SN74LS32</td>
<td>TI</td>
<td>1</td>
</tr>
<tr>
<td>U13-16</td>
<td>IC, 2118, Dynamic RAM</td>
<td>2118</td>
<td>INTEL</td>
<td>4</td>
</tr>
<tr>
<td>U17,18</td>
<td>IC, 74S74, Dual D-Type Edge-Triggered Flip-Flop</td>
<td>SN74S74</td>
<td>TI</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>Socket Pin, Spc1</td>
<td>LSG-1AG-38-1</td>
<td>AUG</td>
<td>82</td>
</tr>
</tbody>
</table>

---

**Appendix D**
### Table 5-2. List of Manufacturer's Codes

<table>
<thead>
<tr>
<th>Mfr. Code</th>
<th>Manufacturer</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>AB</td>
<td>Allen-Bradley Co.</td>
<td>Highland Hts., OH</td>
</tr>
<tr>
<td>AUG</td>
<td>August Inc.</td>
<td>Attleboro, MA</td>
</tr>
<tr>
<td>AVX</td>
<td>AVX Ceramics</td>
<td>Myrtle Beach, SC</td>
</tr>
<tr>
<td>DIALC</td>
<td>Dialight</td>
<td>Brooklyn, NY</td>
</tr>
<tr>
<td>FAIR</td>
<td>Fairchild Ind. Prod. Div.</td>
<td>Commack, NY</td>
</tr>
<tr>
<td>INTEL</td>
<td>Intel Corp.</td>
<td>Santa Clara, CA</td>
</tr>
<tr>
<td>KEM</td>
<td>Kemet</td>
<td>Greenville, SC</td>
</tr>
<tr>
<td>TI</td>
<td>Texas Instruments, Inc.</td>
<td>Dallas, TX</td>
</tr>
<tr>
<td>USECO</td>
<td>Useco, Div., Litton Ind.</td>
<td>Van Nuys, CA</td>
</tr>
<tr>
<td>COML</td>
<td>Available from any commercial source</td>
<td>Order by description (OBD).</td>
</tr>
</tbody>
</table>

### Table 5-3. Glossary of Internal Signal Mnemonics

<table>
<thead>
<tr>
<th>Code</th>
<th>Signal Mnemonic</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>A</td>
<td>AM1-AMF</td>
<td>Memory Address Bits 1-F</td>
</tr>
<tr>
<td>B</td>
<td>PCS/</td>
<td>Protected Chip Select</td>
</tr>
<tr>
<td>C</td>
<td>DM0-DM3</td>
<td>Memory Bus data Bits 0-3</td>
</tr>
<tr>
<td>D</td>
<td>WE1/</td>
<td>Write Enable 1</td>
</tr>
<tr>
<td>F</td>
<td>LPAR</td>
<td>Low Parity Bit</td>
</tr>
<tr>
<td>G</td>
<td>RD/S1</td>
<td>Read/Status Bit 1</td>
</tr>
<tr>
<td>H</td>
<td>CAS/</td>
<td>Column Address Strobe</td>
</tr>
<tr>
<td>I</td>
<td>EVEN/ODD</td>
<td>Even/Odd Parity Selection</td>
</tr>
</tbody>
</table>
CAUTION: These schematic diagrams may have been revised. See “Service Information” chapter for details.
CAUTION: These schematic diagrams may have been revised. See "Service Information" chapter for details.
REQUEST FOR READER'S COMMENTS

Intel Corporation attempts to provide documents that meet the needs of all Intel product users. This form lets you participate directly in the documentation process.

Please restrict your comments to the usability, accuracy, readability, organization, and completeness of this document.

1. Please specify by page any errors you found in this manual.

____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________

2. Does the document cover the information you expected or required? Please make suggestions for improvement.

____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________

3. Is this the right type of document for your needs? Is it at the right level? What other types of documents are needed?

____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________

4. Did you have any difficulty understanding descriptions or wording? Where?

____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________
____________________________________________________________________________

5. Please rate this document on a scale of 1 to 10 with 10 being the best rating. ____________

NAME ___________________________________________ DATE ______________
TITLE __________________________________________
COMPANY NAME/DEPARTMENT _______________________
ADDRESS _______________________________________
CITY __________________________ STATE ______ ZIP CODE ________

Please check here if you require a written reply. □
WE'D LIKE YOUR COMMENTS . . .

This document is one of a series describing Intel products. Your comments on the back of this form will help us produce better manuals. Each reply will be carefully reviewed by the responsible person. All comments and suggestions become the property of Intel Corporation.

O.M.S. Technical Publications