

Radiation Hard MIL-STD-1750A Control Unit

Replaces June 1999 version, DS3565-4.0

DS3565-5.0 January 2000

The MA17502 Control Unit is a component of the MAS281 chip set. Other chips in the set include the MA17501 Execution Unit and the MA17503 Interrupt Unit. Also available is the peripheral MA31751 Memory Management Unit/Block Protection Unit. In conjunction these chips implement the full MIL-STD-1750A Instruction Set Architecture.

The MA17502 consisting of a microsequencer, a microcode storage ROM, and an instruction mapping ROM - controls all chip set operations. Table 1 provides brief signal definitions.

The MA17502 is offered in several speed and screening grades, and in dual in-line, flatpack or leadless chip carrier packaging. Screening options are described in this document. For availability of speed grades, please contact Dynex Semiconductor.

### **FEATURES**

- MIL-STD-1750A Instruction Set Architecture
- Full Performance Over Military Temperature Range
- 12-Bit Microsequencer
  - Instruction Prefetch
  - Pipelined Operation
  - Subroutine Capability
- On-Chip ROM
  - 2K x 40-Bit Microcode Store
  - 512 x 8-Bit Instruction Map
- MAS281 Integrated Built-In Self Test
- TTL Compatible System Interface
- Low Power CMOS/SOS Technology

### **1.0 SYSTEM CONSIDERATIONS**

The MA17502 Control Unit (CU) is a component of the Dynex Semiconductor MAS281 chip set. The other chips in the set are the MA17501 Execution Unit (EU) and the MA17503 Interrupt Unit (IU). Also available is the peripheral MA31751 Memory Management Unit/Block Protection Unit (MMU(BPU)). The Control Unit, in conjunction with these chips, implements the full MIL-STD-1750A Instruction Set Architecture. Figure 1 depicts the relationship between the chip set components.

### **BLOCK DIAGRAM**



The CU provides the microprogram storage and sequencing resources for the chip set. The EU provides the MAS281's system synchronizing and arithmetic/logic computational resources. The IU provides interrupt and fault handling resources, DMA interface control signals, and the three MIL-STD-1750A timers. The MMU/BPU may be configured to provide 1M-word memory management (MMU) and/or 1K-word memory block write protection (BPU) functions.



Figure 1: MAS281 Chip Set With Optional MA17504 and Support RAMs

| Signature   | I/O   | Definition                                         |
|-------------|-------|----------------------------------------------------|
| AD00 - AD15 | I     | External 16-Bit Address/Data Bus                   |
| CC00 - CC11 | I/O   | 12-Bit Microcode Address Bus                       |
| CLKPC       | I     | Precharge Clock                                    |
| CLK02       | I     | Phase 2 Clock                                      |
| CS          | I     | Chip Select                                        |
| HOLD        | I     | Hold Request Suspends Internal Processor Functions |
| ĪR          | I     | Interrupt Request                                  |
| M00 - M19   | I/O/Z | 20-Bit Microcode Bus                               |
| NC          | -     | No Connection                                      |
| PIF         | I     | Privileged Instruction Fault                       |
| RESET       | I     | Rest Indicates Device Initialization               |
| ROMONLY     | I     | Indicates if Control Unit to be Used as ROM Only   |
| T1          | I     | Branch or Jump Control                             |
| VDD         |       | Power (External), 5 Volts                          |
| GND         |       | Ground                                             |

Table 1: Signal Definitions

As shown in Figure 1, the MAS281 is the minimum processor configuration consisting of an Execution Unit, a Control Unit, and an Interrupt Unit. This configuration is capable of accessing a 64K-word address space. Addition of an MMU configured MA31751 allows access to a 1M-word address space. This can also be configured as a BPU to provide hardware support for 1K-word memory block write protection.

The CU, as with all components of the MAS281 chip set, is fabricated with CMOS/SOS process technology. Input and output buffers associated with signals external to the MAS281 are TTL compatible.

Detailed descriptions of the CU's companion chips are provided in separate data sheets. Additional discussions on chip set system considerations, interconnection details, and the Digital Avionics Instruction Set (DAIS) mix benchmarking analysis are provided in separate applications notes.

### **2.0 ARCHITECTURE**

The Control Unit consists of a microsequencer, an instruction mapping ROM, a microcode storage ROM, and various buses. Details of these components are shown in Figure 2 and are discussed below:

### 2.1 MICROSEQUENCER

The CU microsequencer is a 12-bit wide microcode address generator. Major features of the microsequencer include a microprogram counter (PC), a microprogram counter save register (PC Save), microcode address increment logic, instruction pipeline registers IA and IB, an iteration of loop counter, a next microcode address source multiplexer, and various pipelining latches. These features are represented in Figure 2.

The 12-bit microcode address width allows the microsequencer to access up to 4096 words of microcode. The MIL-STD-1750A instructions are implemented as sequences of microinstructions stored within the lower 2048 locations of this address space. The address for each microinstruction in a sequence is provided by the next microcode address source multiplexer. This multiplexer, under control of the CU control logic, select from one of six next address sources. Sequential, direct jump, conditional jump, and subroutine address generation modes are supported.

Sequential addressing is accomplished by providing a path from the output of the next microcode address multiplexer to an incrementer and back to the PC register input. Direct jumps are supported by routing a portion of the microinstruction to one of the next microcode address source multiplexer inputs. Conditional jumps are determined in the ALU of the Execution Unit which communicates the decision to the CU via the T1 signal. The T1 signal enables a portion of the microcode word to create the new address. Subroutine jumps are accomplished by loading the contents of the incremented PC register into the PC Save register and then performing a direct jump. Upon completion of the subroutine, the contents of the PC Save register are used as the next microcode address.

A new microinstruction sequence begins when an opcode residing in the IA or IB register is selected by the next microcode address source multiplexer and used as an address to simultaneously access both the CU's Instruction Mapping ROM and the Microcode Storage ROM. The instruction Mapping ROM access provides a pointer which is then used to update the microprogram counter (PC); the Microcode Storage ROM access provides the first microinstruction of the sequence. Remaining microinstructions in a sequence are accessed through the use of the four address generation modes discussed above.

Iterative microprogram operations are achieved through the use of the loop counter. The loop counter may be selectively loaded from either the AD bus or directly from microcode. This counter tracks the number of iterations remaining and, when appropriate, issues a completion signal (CZ). When an iterative operation is called for, the loop counter is loaded and the CU control logic repeats a particular microinstruction sequence, using the four address generation modes discussed above, until the CZ signal is received.

### 2.2 INSTRUCTION MAPPING ROM

The CU instruction mapping ROM provides 512 8-bit words of microcode instruction vector storage. The address space of this ROM is mapped into a portion of the microcode storage ROM's address space. Hence, both ROMs are accessed whenever the microcode address falls within this range. The eight bits from the instruction mapping ROM serve as-the lower eight bits of a 12-bit microcode address; the upper four bits are a hardwired constant. The 12-bit microcode address formed from the 4-bit constant and the mapping ROM's eight bits are loaded into the PC register of the microsequencer and serve as a means to access nonsequential microcode addresses within the address space allocated to both the instruction mapping and microcode storage ROMs.

#### 2.3 MICROCODE ROM

The CU microcode ROM provides 2K (2048) 40-bit words of storage capacity. All of the microcode required to implement the full MIL-STD-1750A Instruction Set Architecture (ISA) fits in one such ROM.

#### 2.4 BUSES

A 16-bit multiplexed Address/Data (AD) bus provides a communications path between the CU, the other components of the MAS281 chip set, the MA31751 MMU/BPU, and any other devices mapped into the chip set's address space. The CU receives MIL-STD-1750A instructions, accessed from system memory, over this bus and loads them into its instruction pipeline registers.

A 20-bit multiplexed Microcode (M) bus provides a pathway between the CU chip and the microcode decode logic on all other chips which are under CU microcode control. The 40-bit wide microinstructions from the CU's microcode ROM are multiplexed on chip as two 20-bit words and presented on the interchip M bus during alternate phases of CLK02N. Microcode bits 39 through 20 are placed on the M bus during the CLK02N low phase and bits 19 through 0 during the high phase of CLK02N. The M bus is bidirectional to permit microcode memory expansion.

A 12-bit microcode address (CC) bus is used to route microcode addresses from the next microcode address source multiplexer to the microcode and instruction mapping ROMs as shown in Figure 2.

### **3.0 INTERFACE SIGNALS**

All signal definitions are shown in Table 1. In addition, each of these functions is provided with Electrostatic Discharge (ESD) protection diodes. All unused inputs must be held to their inactive state via a connection to VDD or GND.

Throughout this data sheet, active low signals are denoted by either a bar over the signal name or by following the name with an "N" suffix. e.g. HOLDN. Referenced signals that are not found on the MA17502 are preceded by the originating chip's functional acronym in parentheses, e.g. (IU)DMAKN.

A description of each pin function, grouped according to functional interface, follows. The function acronym is presented first, followed by its definition, its type, and its detailed description. Function type is either input, output, high impedance (Hi-Z), or a combination thereof. Timing characteristics of each of the functions described are provided in Section 6.0.

### **3.1 POWER INTERFACE**

The power interface consists of a single 5V VDD connection and two common GND connections.

### 3.2 CLOCKS

The clock interface, discussed below, is the means by which the synchronous, microcoded operation of the MAS281 is driven.

### 3.2.1 Precharge Clock (CLKPCN)

Input. The MA17501 Execution Unit (EU), generates the CLKPCN signal for the Control Unit. The Control Unit uses this signal for most of its internal sequencing. During the low phase of CLKPCN, the internal M Bus is precharged to the high state to accelerate its response.

The normal CLKPCN period is defined by five OSC cycles (two cycles low and three cycles high). When a microcode branch is indicated by the EU, the low state of CLKPCN is extended to three OSC cycles. During execution of Interrupt Unit decoded XIO and microcode commands, the high state of CLKPCN is extended to four OSC cycles. Also, during external bus cycles, RDYN may be used to cause the EU to prolong the high state of CLKPCN to greater than three OSC cycles; this allows the MAS281 chip set to interface with slower external memory or input/output devices.

During DMA ((IU)DMAKN is low) or Hold ((EU)HLDAKN is low), CLKPCN will remain low until the CPU takes control again.

### 3.2.2 Phase 2 Clock (CLK02N)

Input. The MA17501 generates the CLK02N signal for the Control Unit. The CU then uses this signal, in conjunction with CLKPCN, to control the distribution of microcode on the M Bus. CLK02N is used to multiplex the 40-bit microcode instruction into two 20-bit words ( $\mu$ W1 and  $\mu$ W2). The high-to-low edge of CLK02N switches  $\mu$ W1 (bits 39 through 20) off the M Bus while switching  $\mu$ W2 (bits 19 through 0) onto the M Bus.

The normal CLK02N period is defined by five OSC cycles (one cycle low, three cycles high, one cycle low). When a microcode branch is indicated by the EU, the high state of CLK02N is extended to four cycles. During execution of Interrupt Unit decoded XIO and microcode commands, the trailing low state of CLK02N is extended to two OSC cycles. Also, during external bus cycles, RDYN may be used to cause the EU to prolong the CLK02N trailing low state to greater than one OSC cycle; this allows the MAS281 chip set to interface with slower external memory or inpuVoutput devices.

During DMA ((IU)DMAKN is low) or Hold ((EU)HLDAKN is low), CLKPCN will remain low until the CPU takes control again.

### 3.3 BUSES

The following is a discussion of the communication buses connecting the three-chip set. The AD Bus and M Bus are mainly operand transfer buses, while the CC Bus is strictly for providing microcode addresses to auxiliary CUs.

### 3.3.1 Address/Data Bus (AD Bus)

Input. These signals comprise the multiplexed address and data bus. During external bus operations, the AD bus accommodates the transfer of instructions, from memory and I/O ports, to the MA17502. During internal bus operations, the AD bus provides additional data to the Control Unit from the Execution Unit. AD00 is the most significant bit position and AD15 is the least significant bit position of both the 16-bit data and 16-bit address. A high on this bus corresponds to a logic 1 and a low corresponds to a logic 0. Information on the AD Bus is clocked into the CU by the high-to-low transition of CLKPCN.

### 3.3.2 Microcode Bus (M Bus)

Input/Output/Hi-z. The M Bus is the 20-bit multiplexed microcode bus. The 40-bit microcode instruction is multiplexed onto the M Bus as two 20-bit words ( $\mu$ W1 and  $\mu$ W2). The first half of the microcode word,  $\mu$ W1 (bits 39 through 20), is assured valid on the high-to-low transition of CLK02N and  $\mu$ W2 (bits 19 through 0) is assured valid on the high-to-low transition of CLKPCN. M00 corresponds to microcode bit 0 ( $\mu$ W1) or 20 ( $\mu$ W2) while M19 corresponds to microcode bit 19 ( $\mu$ W1) or 39 ( $\mu$ W2). A high level indicates a logic 1 and a low level indicates a logic 0. A high level on CS allows the Control Unit to distribute microcode over this bus, a low level places the bus in the high impedance state.

During DMA or Hold states, CLKPCN is held low, thus holding the internal M bus in the precharged state. Precharging the internal M Bus forces the 20 bits of the external M Bus low.

### 3.3.3 Microcode Address Bus (CC Bus)

Input/Output/Hi-Z. The CC bus is provided for future expansion and is left unconnected.

### **3.4 SEQUENCER CONTROL**

The following is a discussion of the microsequencer control input signals. These signals support chip set functions that require microcode branching based on the results of operations performed in the Execution or Interrupt Units.

#### 3.4.1 Interrupt Request (IRN)

Input. A low on this input directs the CU to service pending interrupt requests latched by the Interrupt Unit (IU). Upon completion of the currently executing MIL-STD-1750A instruction, the CU checks the IRN input. If IRN is low, then the CU sequencer will branch to the microcoded interrupt service routine; else the next MIL-STD-1750A instruction is mapped to its microcode routine. The microcoded interrupt service routine



Figure 2: MA17502 Control Unit Architecture

stores the processor state, retrieves the highest priority pending interrupt's service routine processor state, and vectors software execution to the user's interrupt service routine. IRN originates in the IU.

### 3.4.2 Privileged Instruction Fault (PIFN)

A low on this signal causes the CU to enable control of the DMA interface (located in the Interrupt Unit), abort the currently executing MIL-STD-1750A instruction and check the IRN input for a pending level 1 interrupt caused by the IU latching a memory protect (MPROEN), memory address (EXADEN), or Bus Time-out fault. PIFN originates in the IU.

### 3.4.3 Branch or Jump Control (T1)

Input. A high on this input directs the CU microcode address sequencer to branch execution to a nonsequential microcode address. This signal is under the control of the Execution Unit's ALU and its level is dependent on the outcome of the presently executing microcode instruction, e.g. conditional branch. T1 originates in the EU.

### **3.5 CONFIGURATION CONTROL**

The following inputs are provided for control of multiple CU systems. They allow for expansion of the microcode store to 4K 40-bit words.

### 3.5.1 ROM-Only (ROMONLYN)

Input. This signal is provided for future microcode expansion and must be pulled up to VDD.

### 3.5.2 Chip Select (CS)

Input. A high on this signal enables the CU to drive the 20bit external M Bus. This signal is provided for future microcode expansion and must be pulled up to VDD.

#### 3.6 CPU CONTROL

Grouped under this heading are signals that have CPUwide control of normal operation. Each of these has the ability to "freeze" the processor.

#### 3.6.1 Hold Request (HOLDN)

Input. A low on this input will suspend internal processor functions at the end of the currently executing MIL-STD1750A instruction. When this signal becomes active, the CU completes the currently executing MIL-STD-1750A instruction, then branches to the Hold microcode routine and enters the Hold state. The CU will resume normal operation by refilling the instruction pipeline registers (IA and IB) upon release of HOLDN.

#### 3.6.2 System Reset (RESET)

Input. A high on this input for a duration of at least one CLKPCN period will reset the MAS281 chip set by forcing the Control Unit to microcode address zero. The high-to-low transition of this input will cause the CU to begin executing the MAS281 initialisation sequence starting with the first instruction in microcode. Built-in Test (BIT) is performed as part of the initialisation sequence. At the conclusion of initialisation and successful execution of BIT, the MAS281 will be initialised as shown in Table 3.

### **4.0 OPERATING MODES**

The following discussions detail the MAS281 chip set operating modes from the perspective of the Control Unit. MAS281 operating modes involving the MA17502 include: (1) Initialisation, (2) Instruction Execution, (3) Interrupt Servicing, (4) DMA Support, and (5) HOLD Support.

### **4.1 INITIALISATION**

The MA17502 sequences the MAS281 chip set through the microcoded initialisation routine in response to a high pulse on the RESET input. This routine clears the chip set registers, disables and masks interrupts' reads the configuration register, resets the output discrete register (if applicable), initialises the MMU and BPU (if applicable), performs Built-in Test (BIT), raises the StartUp ROM Enable discrete, clears and starts timers A and B, resets the Trigger-Go counter, and loads the instruction pipeline. The initialisation sequence is contained in the first 33 locations of microcode ROM (an additional 14 locations contain the optional MMU and BPU initialisation code). Because the initialisation sequence clears the Execution Unit's Instruction Counter and Status Word (also the address and processor state copies stored in the MMU(BPU), if applicable), program execution begins with the instruction located at address zero (page zero). Table 2 provides a detailed breakdown of the initialisation sequence and Table 3 summarises the resulting initialised state.

BIT occupies 332 words of microcode storage ROM, and consists of five subroutines that exercise the internal circuitry of the MAS281, as outlined in Table 4. BIT begins by pulling the Normal Power-UP ((IU)NPU) output low; this is the first time after power-up that the state of NPU is guaranteed. If all five BIT subroutines execute successfully, NPU is raised high.

If any part of BIT fails, an error code identifying the failed subroutine is loaded into the Interrupt Unit Fault Register (via the AD Bus), BIT is aborted, and NPU is left in the low state. Table 4 defines the coding of the BIT results. (NPU is raised high through microcode control of the IU in conjunction with the (EU)INTREN signal. The BIT error codes are loaded in the IU Fault Register via the AD Bus under microcode control of the IU in conjunction with the (EU)INTREN signal.)

In the event of such a failure, the resulting chip set reset state is dependent on where in BIT the error occurred and may not be the same as that shown in Table 3. A BIT failure indication in the fault register sets the level 1 pending interrupt. Since initialisation disables and masks interrupts, the IRN input will remain high; thus the interrupt will not be serviced immediately.

The last action performed by the initialisation routine is to load the instruction pipeline. Instruction fetches start at memory location zero (page zero) from the Start-Up ROM (if implemented). Whether BIT passes or not, the processor will begin instruction execution at this point.

Note: To complete initialisation and pass BIT, interrupt and fault inputs must be high for the duration of the initialisation routine. Also, the Timers A and B must be clocked for BIT success.

|   | Label  | Cycle     |             |                                                                                                       |
|---|--------|-----------|-------------|-------------------------------------------------------------------------------------------------------|
| ļ | MAIN   | B1        | 1.          | Enable Control of DMAE Output signal                                                                  |
|   |        | P         | 2.          | -                                                                                                     |
|   |        | B1        | 3.          | Clear MAS281 Execution Unit Status Word (SW)                                                          |
|   |        |           |             | Clear Interrupt Mask (MK) (Internal I/O command, SKM, 2000H)                                          |
|   |        | B1        | 4.          | Clear Pending Interrupt Register (PI) and Fault Register (FT) (Internal I/O Command, CLIR, 2001H)     |
|   |        |           |             | Clear Instruction Counter (IC)                                                                        |
|   |        | P         | 5.          |                                                                                                       |
|   |        | B1        | 6.<br>-     | Disable Interrupts (Internal I/O Command, DSBL, 2003H)                                                |
|   |        | P<br>D1   | <i>/</i> .  | -<br>Clear MMU Status Word (Internal I/O Command W/SW/ 2005HJ) (Nate 1)                               |
|   |        |           | о.<br>О     | Clear Mino Status Word (Internal //O Command, WSW, 200EH) (Note T)                                    |
|   |        | R1        | 9.<br>10    | -<br>Disable DMA Access (Internal I/O Command DMAD 4007H)                                             |
|   |        | P         | 11.         |                                                                                                       |
|   |        | B1        | 12.         | Read Configuration Register (Internal I/O Command, RCW, 8400H, CONFWN Drops low per Figure            |
|   |        |           |             | 25, Section 5.0)                                                                                      |
|   |        | Р         | 13.         | -                                                                                                     |
|   |        | Р         | 14.         | -                                                                                                     |
|   |        | B2        | 15.         | <ul> <li>(If Output Discrete Register Present, then Continue; Else, Skip to 18)</li> </ul>            |
|   |        | P         | (16).       |                                                                                                       |
|   |        |           | (17).       | (If DDL present then Drench to DDL to less continue)                                                  |
|   |        | BZ<br>D   | 19.<br>20   | - (IT BPO present, then Branch to BPO; else, continue)                                                |
|   |        | B2        | 20.<br>21   | -<br>- (If MMU present, then Branch to MMU: Else, Continue)                                           |
|   |        | P         | 22.         | - (Setup Temporary Register to indicate No MMU Present)                                               |
|   |        | B2        | 23.         | - (Branch to MAS281 BIT)                                                                              |
|   |        | Р         | 24.         | -                                                                                                     |
|   |        | B1        | 25.         | Enable Start-Up ROM (Internal I/O Command, ESUR, 4004H; SURE Raises High per Figure 25,               |
|   |        |           |             | Section 5.0)                                                                                          |
|   |        | P         | 26.         |                                                                                                       |
|   |        | B1        | 27.         | Clear and Start Timer A (Internal I/O Command, OTA, 400AH)                                            |
|   |        | BI        | 28.         | Reset the Trigger-Go timer (Internal I/O Command, GO, 400BH)                                          |
|   |        | B1        | 29.<br>30   | -<br>Clear and Start Timer B (Internal I/O Command, OTB, 400EH)                                       |
|   |        | B2        | 31.         | - (Branch to Load Instruction Pipeline Routine)                                                       |
|   |        | M         | 32.         | Load data-In register (DI) and instruction Register A (IA) from [IC], Increment IC                    |
|   |        | М         | 33.         | Load Data-In Register (DI) and Instruction Register a (IA) from [IC] ([IA] Moves to IB), Increment IC |
|   |        |           |             | Map Instruction Register B (IB) into Microcode Routine                                                |
|   | BPU    | Р         | (1).        | •                                                                                                     |
|   |        | P         | (2).        | - (Set Loop to Clear Memory Protect RAM)                                                              |
|   |        | 1/0       | (3).        | Clear a Location in MPRAM (Internal I/O Command, LMP, 50XXH), Increment Address; Do 128 Times         |
|   | ммн    |           | (4).<br>(1) | - (Didituit Daux 10 20.)                                                                              |
|   |        | P         | (1). (2)    |                                                                                                       |
|   |        | P         | (3).        | - (Setup Loop to Load Instruction Page Registers (IPR) and Operand Page Registers (OPR) with          |
|   |        |           | (-)-        | Sequential Values of 0 to 255)                                                                        |
|   |        | Р         | (4).        | - /                                                                                                   |
|   |        | Р         | (5).        | -                                                                                                     |
|   |        | I/O       | (6).        | Load a Location in the IPR with the value of the Locatron Address (Internal I/O Command, WIPR,        |
|   |        |           | (-)         | 51XYH)                                                                                                |
|   |        | 1/0       | (7).        | Load a Location in the OPR Increment Loaded Value with the Value of the Location Address (Internal    |
|   |        |           | (0)         | I/O Command, WOPK, 52XYH)                                                                             |
|   |        |           | (0).<br>(0) | - (Increment OPR Address - Reneat Loop 1/ - 91256 Times)                                              |
|   |        | B2        | (10).       | - (Setup Temporary Register to Indicate MMU Present: Branch back to 23)                               |
| 1 |        |           |             |                                                                                                       |
|   | Notes: | 1. This c | peratio     | n is performed whether or not an MMU is present.                                                      |

1. This operation Is performed whether or not an MMU is present.

This operation is performed whether or not an MMU is present.
 "-" indicates internal CPU operation.
 Sequence numbers in "()" are performed only under the stated conditions.
 Each step enumerated above represents a single machine (SYNC) cycle of the type shown in the "Cycle" column. "P" indicates a 5 OSC cycle, 60% duty cycle, machine cycle. "I/O" and "M" indicate a 5 OSC cycle, 50% duty cycle, machine cycle. "B1" indicates a 6 OSC cycle 50% duty cycle machine cycle. "B2" indicates a 6 OSC cycle 66% duty cycle machine cycle.

Table 2: MAS281 Initialisation Sequence

| MAS281                         |                     |
|--------------------------------|---------------------|
| Instruction Counter (IC)       | Zeroed              |
| Status Word (EU and MMU) (SW)  | Zeroed              |
| Fault (FT)                     | Zeroed              |
| Pending Interrupt (PI)         | Zeroed              |
| Mask (MK)                      | Zeroed              |
| General Register File (RO R15) | Zeroed              |
| Interrupts                     | Disabled            |
| DMA Access                     | Disabled            |
| TimerA                         | Reset and Started   |
| Timer B                        | Reset and Started   |
| Trigger-Go Timer               | Reset and Started   |
| MMU                            |                     |
| Page Registers                 | Group Zero Enabled  |
| AL, W, E, Fields               | Zeroed              |
| PPA Field                      | Logical to Physical |
|                                | Мар                 |
| BPU                            |                     |
| Write Protect                  | Zeroed              |
| Global Memory Protect          | Enabled             |
| Table 3: Initialisati          | ion State           |

| BIT | Test<br>Coverage                                                                             | BIT Fail Codes<br>(FT <sub>13, 14,15</sub> ) | Cycles |
|-----|----------------------------------------------------------------------------------------------|----------------------------------------------|--------|
| 1   | Microcode Sequencer<br>IB Register Control<br>Barrel Shifter<br>Byte Operations and<br>Flags | 100                                          | 221    |
| 2   | Temporary Registers<br>(T0 - T7)<br>Microcode Flags<br>Multiply<br>Divide                    | 101                                          | 166    |
| 3   | Interrupt Unit<br>MK, PI, FT<br>Enable/Disable<br>Interrupts                                 | 111                                          | 214    |
| 4   | Status Word Control<br>User Flags<br>General Registers<br>(R0 - R15)                         | 110                                          | 154    |
| 5   | Timer A<br>Timer B                                                                           | 111                                          | 763    |
|     | BIT Pass/Fail<br>Overhead                                                                    | -                                            | 26     |

Note: BIT pass is indicated by all zeros in FT bits 13, 14 and 15

Table 4: Built In Test (BIT) Summary

### **4.2 INSTRUCTION EXECUTION**

The MIL-STD-1750A microcoded instruction subroutines are stored in 1255 locations of microcode storage ROM. The Control Unit receives instructions from memory, via the AD Bus, through the instruction pipeline registers IA and IB. When the previous instruction or special process (Interrupts or Hold) has been completed, the new instruction residing in register IB is selected by the next microcode address source multiplexer. A 4-bit hardwired constant, appended by the instruction opcode, is then used as the first address of a microcode sequence which distributes the required control to execute the instruction. The microsequencer generates the remaining microcode addresses necessary to complete the sequence as described in Section 2.0 of this data sheet entitled, "Architecture".

Upon completion of the current instruction, the CU will accept the next instruction in the program unless an interrupt, DMA, or Hold request is received. The interrupt and Hold request share a common branch point in microcode. If an interrupt and Hold request are both pending at the conclusion of the MIL-STD-1750A instruction microcode routine, the Hold request has priority and is serviced first. Upon release of the Hold state, the first instruction will execute even if the interrupt is still pending; when this instruction is complete the interrupt will be serviced (assuming the HOLDN input has not been

driven low during execution of this instruction). Interrupt, DMA, and Hold support are explained in more detail in following sections.

### **4.3 DIRECT MEMORY ACCESS**

Direct Memory Access (DMA) is controlled by the Execution Unit (EU) in concert with the Interrupt Unit DMA interface. The CU supports DMA by suspending processor control upon completion of the current machine cycle. If DMA is enabled ((UI)DMAE signal, high) a DMA request ((IU)DMARN input, low) to the MAS281 causes the IU to acknowledge with DMAKN, low. When the EU receives the DMAKN (DMA Acknowledge) signal from the IU, the CU clocks are suspended (CLKPCN, low; CLK02N, high) halting the MAS281's microcode sequencing. Microinstruction execution remains suspended until DMARN is removed. When DMARN is removed, microcode execution resumes where DMARN had interrupted it.

#### **4.4 INTERRUPT HANDLING**

Interrupts are handled by the interrupt Unit (IU) and communicated to the CU via the IRN input. The CU checks the status of the IRN (Interrupt Request) signal after the completion of each MIL-STD-1750A microcode instruction sequence. If the IRN signal is low, the CU initiates interrupt handling, otherwise the CU processes a new instruction.

IU interrupt handling is controlled by the CU through three microcode bits - M04, M05, and M06. Upon receipt of the IRN signal and after completion of the currently executing instruction, the CU branches to a microcoded interrupt handling routine. The microprogram sequence supplies microcoded control to the IU for reading the highest priority pending interrupt vector code, which also clears this pending interrupt.

Due to the similarity of interrupt and hold request handling by the CU, if a Hold and interrupt request are pending at the end of an instruction sequence the Hold has priority and will be serviced.

#### **4.5 HOLD SUPPORT**

The CU accepts a Hold request in much the same way as an interrupt request. After the completion of each MIL-STD-1750A microcode instruction sequence, the CU checks the status of the HOLDN signal. If the HOLDN signal is low, a microcoded sequence suspends further internal processing functions; otherwise, the CU processes a new instruction or services interrupt requests (Hold requests have priority over interrupt requests).

The Control Unit responds to an active HOLDN signal, upon completion of the currently executing instruction, but branching to a microprogrammed sequence of instructions that suspends all internal operations. This sequence of microinstructions allows the processor to resume instruction execution at the point HOLDN was accepted when the CU regains control of the processor. The MAS281 remains in the Hold state until HOLDN is pulled high (if the Hold state was reached through the hardware interface, HOLDN) or HOLDN is pulsed low (if the Hold state was reached through software, BPT instruction). HOLDN should be synchronised to AS falling.

### **5.0 SOFTWARE CONSIDERATIONS**

The MAS281 chip set implements the full MIL-STD-1750A instruction set. Table 6a gives a brief listing of this instruction set and provides performance data for each instruction. Table 6b provides a summary of the I/O commands implemented in MAS281 and MA31751 MMU/BPU hardware. A complete description of this instruction set is provided in MIL-STD-1705A (Notice 1). The register set available to the software programmer is depicted in Figure 3. A discussion of data types, addressing modes, and benchmarking considerations fol lows.

### **5.1 DATA TYPES**

The MAS281 chip set supports 16-bit fixed-point single precision, 32-bit fixed-point double-precision, 32-bit floating-point, and 48-bit extended-precision floatingpoint data types. Figure 4 depicts the formats of these data types.

All numerical data is represented in two's complement form. Floating-point numbers are represented by a fractional two's complement mantissa with an 8-bit two's complement exponent. The MAS281 expects all floating point operands to be normalised. If they are not normalised, the results from an instruction are not defined.

|                                        | P0                       |  |
|----------------------------------------|--------------------------|--|
|                                        | RU                       |  |
|                                        | R1                       |  |
|                                        | R2                       |  |
|                                        | R3                       |  |
|                                        | R4                       |  |
|                                        | R5                       |  |
|                                        | R6                       |  |
|                                        | R7                       |  |
|                                        | R8                       |  |
|                                        | R9                       |  |
|                                        | R10                      |  |
|                                        | R11                      |  |
|                                        | R12                      |  |
|                                        | R13                      |  |
|                                        | R14                      |  |
|                                        | R15                      |  |
| ······································ | Status Word (SW)         |  |
|                                        | Instruction Counter (IC) |  |
|                                        | Fault Register (FT)      |  |
|                                        | Pending Interrupt (PI)   |  |
|                                        | Mask Register (MK)       |  |
|                                        | Timer A                  |  |
|                                        | Timer B                  |  |
|                                        | Configuration Register   |  |

Memory Fault Status (MFS)

Figure 3: Register Set Model

### **5.2 ADDRESSING MODES**

The MAS281 chip set supports the eight addressing modes specified in MIL-STD-1750A. These addressing modes are shown in Figure 5 and are defined below.

### 5.2.1 Register Direct (R)

The register specified by the instruction (RB) contains the required operand.

### 5.2.2 Memory Direct (D,DX)

Memory Direct (without indexing) is an addressing mode in which the instruction contains the memory address (A) of the required operand. In Memory Direct (indexed), the memory address of the required operand is specified by the sum of the contents of an index register (RX) and the instruction address field (A). Registers R1 through R15 may be specified for indexing.

### 5.2.3 Memory Indirect (I,IX)

Memory Indirect (without indexing) is an addressing mode in which the memory address (A) specified by the instruction contains the address of the required operand. In Memory Indirect (pre-indexed), the sum of the contents of a specified index register (RX) and the instruction address field (A) is the address of the address of the required operand. Registers R1 through R15 may be specified for indexing.

#### 5.2.4 Immediate Long (IM)

There are two formats that implement Immediate Long Addressing; one allows indexing and one does not. For the indexable format, if the specified index register (RX) is not equal to zero, the contents of RX are added to the immediate field to form the required operand, otherwise, the immediate field contains the required operand .

### 5.2.5 Immediate Short (IS)

In this mode the required 4-bit operand is contained within the 16-bit instruction. The Immediate Short addressing mode accommodates two formats; one which interprets the contents of the immediate field as positive data and the other which interprets the contents of the immediate field as negative data.

### 5.2.6 Immediate Short Positive (ISP)

The immediate operand is treated as a positive integer between 1 and 16.

### 5.2.7 Immediate Short Negative (ISN)

The immediate operand is treated as a negative integer between 1 and 16. Its internal form is a two's complement, sign-extended 16-bit number.

### 5.2.8 Instruction Counter Relative (ICR)

This addressing mode is used for 16-bit branch instructions. The contents of the instruction counter minus two (the address of the current instruction) is added to the sign-extended 8-bit displacement field (D) within the instruction. This sum then points to the memory address to which control may be transferred if a branch is to be taken.



#### Figure 4: Data Formats

### 5.2.9 Base Relative (B)

Byte

There are two formats which implement Base Relative Addressing; one allows indexing and one does not. For the nonindexable form the contents of the instruction specified base register (BR = BR' + 12) is added to the 8-bit displacement field (DU) of the 16-bit instruction. For the indexable form, the sum of the contents of a specified index register (RX) and a specified base register (BR = BR' + 12) is the address of the required operand. Registers R1 through R15 may be specified for indexing and the base register may be R12 through R15.

| Mode              | Format                   |                                                                            |
|-------------------|--------------------------|----------------------------------------------------------------------------|
| 1. Register Direc | ct 0 7 8 11 12 15        |                                                                            |
| "R"               | OC RA RB                 |                                                                            |
| 2. Memory Dire    | ect 0 7 8 11 12 15 16    | 31                                                                         |
| -                 | OC RA RX                 | A                                                                          |
| "D"               | RX = 0 (Non-Indexed)     |                                                                            |
| "DX"              | RX ≠ 0 (Indexed)         |                                                                            |
| 3. Memory Indir   | rect 0 7 8 11 12 15 16   | 31                                                                         |
|                   | OC RA RX                 | Α                                                                          |
| "   "             | RX = 0 (Non-Indexed)     |                                                                            |
| "IX"              | RX ≠ 0 (Indexed)         |                                                                            |
| 4. Immediate Lo   | ong <u>0 78111215</u> 16 | 31                                                                         |
| a. Not Index      | xable OC RA OCX          | 1                                                                          |
| "IM"              |                          |                                                                            |
| h indexable       |                          | 31                                                                         |
| "IM"              |                          | B                                                                          |
| "IMX"             | $RX \neq 0$ (indexed)    |                                                                            |
| E Immodiato Ch    |                          | end:                                                                       |
| 5. Immediate Sr   |                          | - Operation Code                                                           |
|                   |                          | = Destination Register                                                     |
|                   | 0 7 8 11 12 15 RX        | = Source Register<br>= Index Register                                      |
| b. Negative       | OC RA I A                | <ul> <li>Address (Logical)</li> <li>Extension to Operation Code</li> </ul> |
| "ISN"             |                          | = Immediate Data                                                           |
| 6. IC Relative    | 0 7 8 15 BR'             | = Base Register Reference                                                  |
| "ICR"             | OC D DU S1, S            | = Displacement (Positive)<br>52 = Special Code                             |
| 7. Base Relative  | e 0 5 6 7 8 15           |                                                                            |
| a. Not index      | xable OC BR' DU          |                                                                            |
| "B"               | BR' = BR-12              |                                                                            |
|                   | 0 5 6 7 8 11 12 15       |                                                                            |
| b. Indexable      | e OC BR' OCX RX          |                                                                            |
| "B"               | RX = 0 (Non-Indexed)     |                                                                            |
| "BX"              | RX ≠ 0 (Indexed)         |                                                                            |
| 8. Special        | 0 7 8 11 12 15           |                                                                            |
| "S"               | OC 51 52                 |                                                                            |
|                   |                          |                                                                            |

### Figure 5: Addressing Modes

### 5.2.10 Special (S)

This addressing mode is applicable to instructions that do not follow the above formats.

### **5.3 BENCHMARKING**

Table 6a defines the number and type of machine cycles associated with each MIL-STD-1750A instruction. This information may be used when benchmarking MAS281 performance. The Digital Avionics Instruction Set (DAIS) mix, which defines a typical frequency of occurrence for MIL-STD-1750A instructions, is used here for this purpose.

One problem with the DAIS mix, however, is that it does not reflect the impact of data dependencies on system performance. For example, a multiplication in which one operand is zero may be performed much faster than one with two non-zero operands. Also, the DAIS mix does not specify such time consuming operations as normalization and alignment.

Realistic benchmarks must therefore take both an instruction mix and data dependencies into account. To this end, machine cycle counts in Table 6a which have data dependencies are annotated with either an "a" suffix to reflect an average number of machine cycles (where each of several possibilities is equally likely) or with a "wa" suffix to reflect a weighted average number of machine cycles (where some data possibilities are more likely than others). Weighted averages are only applicable to floating-point operations. Weighted averages provided in Table 6a, based on the Sweeney (IBM Systems Journal, Vol. 4, No. 1, 1965) guidelines, take a wide range of data dependencies into consideration. Normalization and alignment operations are also represented. Table 5 defines MAS281 throughput, at various frequencies and wait states, for the DAIS mix using Sweeney data dependencies.

It should be noted that using the Sweeney guidelines is a conservative approach to benchmarking. If best case assumptions are made and such operations as normalization and alignment are not considered, MAS281 performance figures are approximately 50% higher than those indicated in Table 5.

|                  | Number of Moit States in |       |       |       |       |  |  |  |
|------------------|--------------------------|-------|-------|-------|-------|--|--|--|
|                  |                          | 0     | 1     | 2     | 3     |  |  |  |
|                  | 10                       | 297.4 | 279.3 | 263.4 | 249.1 |  |  |  |
| MHz              | 15                       | 446.0 | 419.0 | 395.0 | 373.7 |  |  |  |
| f <sub>osc</sub> | 20                       | 594.7 | 558.7 | 526.7 | 498.2 |  |  |  |
|                  | 25                       | 743.4 | 698.3 | 658.4 | 622.8 |  |  |  |

Memory Access Cycle

Table 5: Throughput (KIPS)

### 5.4 INSTRUCTION SUMMARY

|                                                |                                                |                                                      |                                                      | Cycles*                         |                                      |                                 |
|------------------------------------------------|------------------------------------------------|------------------------------------------------------|------------------------------------------------------|---------------------------------|--------------------------------------|---------------------------------|
| Operation                                      | Op Code/Ext                                    | Mnemonic                                             | Format                                               | М                               | Р                                    | В                               |
| LOAD/STORE                                     |                                                |                                                      |                                                      |                                 |                                      |                                 |
| Single Precision Load                          | 81<br>0X<br>4X 0<br>82<br>83<br>80<br>85<br>84 | LR<br>LB<br>LBX<br>LISP<br>LISN<br>L<br>LI M<br>LI M | R<br>B<br>BX<br>ISP<br>ISN<br>D,DX<br>IM,IMX<br>I,IX | 1<br>2<br>1<br>1<br>3<br>2<br>4 | 0<br>1<br>1<br>0<br>0<br>0<br>0<br>1 | 0<br>0<br>0<br>0<br>0<br>0<br>0 |
| Double-Precision Load                          | 87<br>0X<br>4X 1<br>86<br>88                   | DLR<br>DLB<br>DLBX<br>D L<br>DLI                     | R<br>B<br>BX<br>D,DX<br>I,IX                         | 1<br>3<br>4<br>5                | 2<br>1<br>2<br>0<br>1                | 0<br>0<br>0<br>0                |
| Single-Precision Store                         | 0X<br>4X 2<br>90<br>94                         | STB<br>STBX<br>ST<br>STI                             | B<br>BX<br>D,DX<br>I,IX                              | 2<br>2<br>3<br>4                | 2<br>2<br>1<br>1                     | 0<br>0<br>0<br>0                |
| Store a Non-Negative<br>Constant               | 91<br>92                                       | STC<br>STCI                                          | D,DX<br>I,IX                                         | 3<br>4                          | 1<br>1                               | 0<br>0                          |
| Double-Precision Store                         | 0X<br>4X 3<br>96<br>98                         | DSTB<br>DSTX<br>DST<br>DSTI                          | B<br>BX<br>D,DX<br>I,IX                              | 3<br>3<br>4<br>5                | 2<br>2<br>0<br>1                     | 0<br>0<br>0<br>0                |
| Load Multiple Registers                        | 89                                             | LM                                                   | D,DX                                                 | 3 + n                           | 1                                    | 1                               |
| Store Multiple Registers                       | 99                                             | STM                                                  | D,DX                                                 | 3 + n                           | 1                                    | 1                               |
| INTEGER ARITHMETIC                             |                                                |                                                      |                                                      |                                 |                                      |                                 |
| Single-Precision IntegerAdd                    | A1<br>1X<br>4X 4<br>A2<br>A0<br>4A 1           | AR<br>AB<br>ABX<br>AISP<br>A<br>AIM                  | R<br>B<br>BX<br>ISP<br>D,DX<br>IM                    | 1<br>2<br>1<br>3<br>2           | 1<br>2<br>2<br>1<br>1<br>1           | 0<br>0<br>0<br>0<br>0           |
| Increment Memory by a<br>Positive Integer      | A3                                             | INCM                                                 | D,DX                                                 | 4                               | 1                                    | 0                               |
| Single-Precision Absolute<br>Value of Register | A4                                             | ABS                                                  | R                                                    | 1                               | 1.5                                  | 1a                              |
| Double-Precision Absolute<br>Value of Register | A5                                             | DABS                                                 | R                                                    | 1                               | 2.5                                  | 1a                              |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists.

Table 6a: Instruction Summary

|                                                          |                                      |                                       |                                   | Cycles*               |                                           |                                      |
|----------------------------------------------------------|--------------------------------------|---------------------------------------|-----------------------------------|-----------------------|-------------------------------------------|--------------------------------------|
| Operation                                                | Op Code/Ext                          | Mnemonic                              | Format                            | М                     | Р                                         | в                                    |
| Double-Precision Integer<br>Add                          | A7<br>A6                             | DAR<br>DA                             | R<br>D,DX                         | 1<br>4                | 3<br>1                                    | 0<br>0                               |
| Single Precision Integer<br>Subtract                     | B1<br>1X<br>4X 5<br>B2<br>B0<br>4A 2 | SR<br>SBB<br>SBBX<br>SISP<br>S<br>SIM | R<br>B<br>BX<br>ISP<br>D,DX<br>IM | 1<br>2<br>1<br>3<br>2 | 1<br>2<br>1<br>1                          | 0<br>0<br>0<br>0<br>0                |
| Decrement Memory by a Positive Integer                   | B3                                   | DECM                                  | D,DX                              | 4                     | 1                                         | 0                                    |
| Single Precision Negate<br>Register                      | B4                                   | NEG                                   | R                                 | 1                     | 1                                         | 0                                    |
| Double-Precision Negate<br>Register                      | B5                                   | DNEG                                  | R                                 | 1                     | 3                                         | 0                                    |
| Double-Precision Integer<br>Subtract                     | B7<br>B6                             | DSR<br>DS                             | R<br>D,DX                         | 1<br>4                | 3<br>1                                    | 0<br>0                               |
| Single Precision Integer<br>Multiply with 16-Bit Product | C1<br>C2<br>C3<br>C0<br>4A 4         | MSR<br>MISP<br>MISN<br>MS<br>MSIM     | R<br>ISP<br>ISN<br>D,DX<br>IM     | 1<br>1<br>3<br>2      | 6.5<br>7.5<br>7.5<br>6.5<br>6.5           | 4a<br>4a<br>4a<br>4a<br>4a           |
| Single Precision Integer<br>Multiply with 32-Bit Product | C5<br>1X<br>4X 6<br>C4<br>4A 3       | MR<br>MB<br>MBX<br>M<br>MIM           | R<br>B<br>BX<br>D, DX<br>IM       | 1<br>2<br>2<br>3<br>2 | 5<br>7<br>7<br>5<br>5                     | 3<br>3<br>3<br>3<br>3                |
| Double-Precision Integer<br>Multiply                     | C7<br>C6                             | DMR<br>DM                             | R<br>D,DX                         | 1<br>4                | 41<br>40                                  | 4.5a<br>4.5a                         |
| Single Precision Integer<br>Divide with 16-Bit Dividend  | D1<br>D2<br>D3<br>D0<br>4A 6         | DVR<br>DISP<br>DISN<br>DV<br>DVIM     | R<br>ISP<br>ISN<br>D,DX<br>IM     | 1<br>1<br>3<br>2      | 20.25<br>20<br>20.5<br>20.25<br>20.25     | 5.5a<br>5.5a<br>5.5a<br>5.5a<br>5.5a |
| Single Precision Integer<br>Divide with 32-Bit Dividend  | D5<br>1 X<br>4X 7<br>D4<br>4A 5      | DR<br>DB<br>DBX<br>D<br>DIM           | R<br>R<br>BX<br>D,DX<br>IM        | 1<br>2<br>2<br>3<br>2 | 21.75<br>22.75<br>22.75<br>21.75<br>22.75 | 6.5a<br>6.5a<br>6.5a<br>6.5a<br>6.5a |
| Double-Precision Integer<br>Divide                       | D7<br>D6                             | DDR<br>DD                             | R<br>D,DX                         | 1<br>4                | 79.5<br>77.5                              | 5.5a<br>5.5a                         |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists.

Table 6a (continued): Instruction Summary

|                                |                                |                                     |                            | Cycles*          |                       |                       |
|--------------------------------|--------------------------------|-------------------------------------|----------------------------|------------------|-----------------------|-----------------------|
| Operation                      | Op Code/Ext                    | Mnemonic                            | Format                     | М                | Р                     | В                     |
| LOGICAL                        |                                |                                     |                            |                  |                       |                       |
| Inclusive Logical OR           | E1<br>3X<br>4X F<br>E0<br>4A 8 | ORR<br>ORB<br>ORBX<br>OR<br>ORIM    | R<br>B<br>BX<br>D,DX<br>IM | 1<br>2<br>3<br>2 | 0<br>1<br>1<br>0<br>0 | 0<br>0<br>0<br>0<br>0 |
| Logical AND                    | E3<br>3X<br>4X E<br>E2<br>4A 7 | ANDR<br>ANDB<br>ANDX<br>AND<br>ANDM | R<br>B<br>BX<br>D,DX<br>IM | 1<br>2<br>3<br>2 | 0<br>1<br>1<br>0<br>0 | 0<br>0<br>0<br>0      |
| Exclusive Logical OR           | E5<br>E4<br>4A 9               | XORR<br>XOR<br>XORM                 | R<br>D,DX<br>IM            | 1<br>3<br>2      | 0<br>0<br>0           | 0<br>0<br>0           |
| Logical NAND                   | E7<br>E6<br>4A B               | NR<br>N<br>NIM                      | R<br>D,DX<br>IM            | 1<br>3<br>2      | 1<br>1<br>1           | 0<br>0<br>0           |
| Set Bit                        | 51<br>50<br>52                 | SBR<br>SB<br>SBI                    | R<br>D,DX<br>I,IX          | 1<br>4<br>5      | 0<br>1<br>2           | 0<br>0<br>0           |
| Reset Bit                      | 54<br>53<br>55                 | RBR<br>RB<br>RBI                    | R<br>D,DX<br>I,IX          | 1<br>4<br>5      | 1<br>1<br>2           | 0<br>0<br>0           |
| Test Bit                       | 57<br>56<br>58                 | TBR<br>TB<br>TBI                    | R<br>D, DX<br>I,IX         | 1<br>3<br>4      | 0<br>0<br>1           | 0<br>0<br>0           |
| Test and Set Bit               | 59                             | TSB                                 | D,DX                       | 4                | 0                     | 2                     |
| Set Variable Bit in Register   | 5A                             | SVBR                                | R                          | 1                | 0                     | 1                     |
| Reset Variable Bit in Register | 5C                             | RVBR                                | R                          | 1                | 1                     | 1                     |
| Test Variable Bit in Register  | 5E                             | TVBR                                | R                          | 1                | 0                     | 1                     |
| Store Register Through Mask    | 97                             | SRM                                 | D,DX                       | 4                | 3                     | 0                     |
| ВҮТЕ                           |                                |                                     |                            |                  |                       |                       |
| Load From Upper Byte           | 8B                             | LUB                                 | D,DX                       | 3                | 0                     | 0                     |
| Load From Lower Byte           | 8C                             | LLB                                 | D,DX                       | 3                | 1                     | 0                     |
| Store Into Upper Byte          | 9B<br>9D                       | STUB<br>SUBI                        | I,IX<br>D,DX<br>I, IX      | 4<br>4<br>5      | 2<br>1<br>3           | 0<br>0                |
| Store Into Lower Byte          | 9C<br>9E                       | STLB<br>SLBI                        | D,DX<br>I,IX               | 4<br>5           | 1<br>2                | 0<br>0                |
| Exchange Bytes in Register     | EC                             | XBR                                 | S                          | 1                | 0                     | 1                     |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists.

Table 6a (continued): Instruction Summary

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                              |                                                                                                               |                                                                                             | Cycles*                                          |                                                                         |                                                                        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------------------------|
| Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Op Code/Ext                                                                                  | Mnemonic                                                                                                      | Format                                                                                      | М                                                | Р                                                                       | в                                                                      |
| COMPARE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                              |                                                                                                               |                                                                                             |                                                  |                                                                         |                                                                        |
| Single-Precision Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | F1<br>3X<br>4X C<br>F2<br>F3<br>F0<br>4A A                                                   | CR<br>CB<br>CBX<br>CISP<br>CISN<br>C<br>CIM                                                                   | R<br>B<br>BX<br>ISP<br>ISN<br>D,DX<br>IM                                                    | 1<br>2<br>1<br>1<br>3<br>2                       | 0<br>1<br>1<br>0<br>0<br>0                                              | 0<br>0<br>0<br>0<br>0<br>0                                             |
| Compare Between Limits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | F4                                                                                           | CBL                                                                                                           | D,DX                                                                                        | 4                                                | 2.75                                                                    | 1.75a                                                                  |
| Double-Precision Compare                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | F7<br>F6                                                                                     | DCR<br>DC                                                                                                     | R<br>D,DX                                                                                   | 1<br>4                                           | 2<br>0                                                                  | 0<br>0                                                                 |
| JUMP/BRANCH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                              |                                                                                                               |                                                                                             |                                                  |                                                                         |                                                                        |
| Jump on Condition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 70<br>71                                                                                     | JCI<br>JCI                                                                                                    | D,DX<br>I,IX                                                                                | 2<br>3                                           | 0.5<br>0.5                                                              | 1a<br>1a                                                               |
| Jump to Subroutine<br>Subtract One and Jump<br>Branch Unconditionally<br>Branch if Equal to (zero)<br>Branch if Less than (zero)<br>Branch to Executive<br>Branch if Less than or Equal to (Zero)<br>Branch if Greater than (Zero)<br>Branch if Not Equal to (Zero)<br>Branch if Greater than or Equal to (Zero)                                                                                                                                                                                                                                              | 72<br>73<br>74<br>75<br>76<br>77<br>78<br>79<br>7A<br>7B                                     | JS<br>SOJ<br>BR<br>BEZ<br>BLT<br>BEX<br>BLE<br>BGT<br>BNZ<br>BGE                                              | D,DX<br>D,DX<br>ICR<br>ICR<br>ICR<br>S<br>ICR<br>ICR<br>ICR<br>ICR                          | 2<br>2<br>1.5<br>1.5<br>1.5<br>1.5<br>1.5<br>1.5 | 2<br>2.5<br>1<br>1<br>12<br>1<br>1<br>1                                 | 0<br>1a<br>0<br>1a<br>1a<br>1a<br>1a<br>1a                             |
| SHIFT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                              |                                                                                                               |                                                                                             |                                                  |                                                                         |                                                                        |
| Shift Left Logical<br>Shift Right Logical<br>Shift Right Arithmetic<br>Shift Left Cyclic<br>Double Shift Left Logical<br>Double Shift Right Logical<br>Double Shift Right Arithmetic<br>Double Shift Left Cyclic<br>Shift Logical, Count in Register<br>Shift Arithmetic, Count in Register<br>Shift Cyclic, Count in Register<br>Double Shift Logical, Count in Register<br>Double Shift Arithmetic, Count in Register<br>Double Shift Arithmetic, Count in Register<br>Double Shift Arithmetic, Count in Register<br>Double Shift Cyclic, Count in Register | 60<br>61<br>62<br>63<br>65<br>66<br>67<br>68<br>67<br>68<br>6A<br>6B<br>6C<br>6D<br>6E<br>6F | SLL<br>SRL<br>SRA<br>SLC<br>DSLL<br>DSRL<br>DSRA<br>DSLC<br>SLR<br>SAR<br>SCR<br>DSLR<br>DSLR<br>DSAR<br>DSCR | R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R<br>R | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1   | 1<br>1<br>1<br>3<br>2<br>2<br>3<br>1<br>1.5<br>1<br>2.25<br>3.19<br>3.5 | 0<br>0<br>0<br>0<br>0<br>0<br>3<br>3.50a<br>3.25a<br>4a<br>4.94a<br>3a |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists. *Table 6a (continued): Instruction Summary* 

|                                                                |             |                 |                | Cycles*                       |                                 |             |
|----------------------------------------------------------------|-------------|-----------------|----------------|-------------------------------|---------------------------------|-------------|
| Operation                                                      | Op Code/Ext | Mnemonic        | Format         | м                             | Р                               | В           |
| CONVERT                                                        |             |                 |                |                               |                                 |             |
| Convert Floating-Point to 16-Bit<br>Integer                    | E8          | FIX             | R              | 1                             | 4.25                            | 4.5a        |
| Convert 16-Bit Integer to Floating-<br>Point                   | E9          | FLT             | R              | 1                             | 3                               | 2a          |
| Convert Extended-Precision<br>Floating-Point to 32-Bit Integer | EA          | EFIX            | R              | 1                             | 12.25                           | 6.25a       |
| Convert 32-Bit Integer to<br>Extended-Precision Floating-Point | EB          | EFLT            | R              | 1                             | 7.5                             | 3.5a        |
| STACK                                                          |             |                 |                |                               |                                 |             |
| Stack IC and Jump to Subroutine                                | 7E          | SJS             | D,DX           | 4                             | 3                               | 0           |
| Unstack IC and return from Subroutine                          | 7F          | URS             | S              | 3                             | 1                               |             |
| Pop Multiple registers off the Stack                           | 8F          | РОРМ            | S              | 2.5 + n                       | 2.25 + n                        | 4.25a       |
| Push Multiple Registers onto the Stack                         | 9F          | PSHM            | S              | (n=0.13)<br>1 + n<br>(n=0.15) | (1-0-13)<br>4.5 + n<br>(n=0.15) | 2a          |
| I/O (See I/O Command Summary)                                  |             |                 |                | (11=0-13)                     | (11-0-13)                       |             |
| Execute I/O<br>Vectored I/O                                    | 48<br>49    | XIO**<br>VIO**  | IM,IMX<br>D,DX | 3<br>-                        | 3.583<br>-                      | 6.277a<br>- |
| SPECIAL                                                        |             |                 |                |                               |                                 |             |
| Built-In Function Call                                         | 4F          | BIF             | S              |                               |                                 |             |
| Move Multiple Words, Memory-to-<br>Memory                      | 93          | MOV             | S              | 1 + 4n                        | 1 + 3n                          | 1 + 2na     |
| Exchange Words in Registers                                    | ED          | XWR             | R              | 1                             | 2                               | 0           |
| Load Status                                                    | 7D<br>7C    | LST**<br>LSTI** | D,DX<br>I,IX   | 8<br>9                        | 2<br>2                          | 3<br>4      |
| No Operation                                                   | FF          | NOP             | S              | 1                             | 2                               | 2           |
| Break Point                                                    | FF          | BPT             | S              | 3                             | 4                               | 4           |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles). \*\* Privileged instruction. a = average if more than one alternative exists.

Table 6a (continued): Instruction Summary

|                                                |                        |                          |                      | Cycles*          |                                      |                                                     |
|------------------------------------------------|------------------------|--------------------------|----------------------|------------------|--------------------------------------|-----------------------------------------------------|
| Operation                                      | Op Code/Ext            | Mnemonic                 | Format               | М                | Р                                    | В                                                   |
| FLOATING-POINT                                 |                        |                          |                      |                  |                                      |                                                     |
| Extended-Precision Floating-<br>Point Load     | 8A                     | EFL                      | D,DX                 | 5                | 0                                    | 1                                                   |
| Extended-Precision Floating-<br>Point Store    | 9A                     | EFST                     | D,DX                 | 5                | 0                                    | 1                                                   |
| Floating-Point Absolute Value of Register      | AC                     | FABS                     | R                    | 1                | 1 .75                                | 3.25a                                               |
| Floating-Point Negate Register                 | BC                     | FNEG                     | R                    | 1                | 3.25                                 | 3.75a                                               |
| Floating-Point Compare                         | F9<br>3X<br>4X D<br>F8 | FCR<br>FCB<br>FCBX<br>FC | R<br>B<br>BX<br>D,DX | 1<br>2<br>2<br>3 | 2.75<br>2.75<br>2.75<br>1.75         | 2.875wa<br>2.875wa<br>2.875wa<br>2.875wa<br>2.875wa |
| Extended-Precision Floating-<br>Point Compare  | FB<br>FA               | EFCR<br>EFC              | R<br>D,DX            | 1<br>4.25a       | 3.25<br>2.75                         | 2.875wa<br>2.875wa                                  |
| Floating-Point Add                             | A9<br>2X<br>4X 8<br>A8 | FAR<br>FAB<br>FABX<br>FA | R<br>B<br>BX<br>D,DX | 1<br>3<br>3<br>4 | 7.625<br>6.625<br>6.625<br>5.625     | 8.25wa<br>8.25wa<br>8.25wa<br>8.25wa<br>8.25wa      |
| Extended-Precision Floating-<br>Point Add      | AB<br>AA               | EFAR<br>EFA              | R<br>D,DX            | 1<br>5           | 21.3125<br>19.3125                   | 10.5625wa<br>10.5625wa                              |
| Floating-Point Subtract                        | B9<br>2X<br>4X 9<br>B8 | FSR<br>FSB<br>FSBX<br>FS | R<br>B<br>BX<br>D,DX | 1<br>3<br>3<br>4 | 8.625<br>7.625<br>7.625<br>6.625     | 8.625wa<br>8.625wa<br>8.625wa<br>8.625wa            |
| Extended-Precision Floating-<br>Point Subtract | BB<br>BA               | EFSR<br>EFS              | R<br>D,DX            | 1<br>5           | 23.0625<br>21.0625                   | 11.8125wa<br>11.8125wa                              |
| Floating-Point Multiply                        | C9<br>2X<br>4X A<br>C8 | FMR<br>FMB<br>FMBX<br>FM | R<br>B<br>BX<br>D,DX | 1<br>3<br>3<br>4 | 12.75a<br>12.75a<br>12.75a<br>11.75a | 6.25wa<br>6.25wa<br>6.25wa<br>6.25wa                |
| Extended-Precision Floating-<br>point Multiply | CB<br>CA               | EFMR<br>EFM              | R<br>D,DX            | 1<br>5           | 59.75<br>57.75                       | 6.25wa<br>6.25wa                                    |
| Floating-Point Divide                          | D9<br>2X<br>4X B<br>D8 | FDR<br>FDB<br>FDBX<br>FD | R<br>B<br>BX<br>D,DX | 1<br>3<br>3<br>4 | 31.5<br>30. 5<br>30.5<br>29.5        | 32.75wa<br>32.75wa<br>32.75wa<br>32.75wa            |
| Extended-Precision Floating-<br>Point Divide   | DB<br>DA               | EFDR<br>EFD              | R<br>D,DX            | 1<br>5           | 102.625<br>100.625                   | 47.875wa<br>47.875wa                                |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists, wa = weighted average favouring one or more possible alternatives.

Table 6a (continued): Instruction Summary

### 5.5 INTERNAL I/O COMMAND SUMMARY

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | •                                                                                                                                                                            |                                                                                                                                                        | Cycles*                                                                                     |                                           |                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-------------------------------------------|---------------------------------------------------------------------------------------------|
| Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Command<br>Code (Hex)                                                                                                                                                        | Mnemonic                                                                                                                                               | М                                                                                           | Р                                         | В                                                                                           |
| Implemented in MAS281                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                              |                                                                                                                                                        |                                                                                             |                                           |                                                                                             |
| Set Fault Register<br>Set Interrupt Mask<br>Clear Interrupt request<br>Enable Interrupts<br>Disable Interrupts<br>Reset Pending Interrupt<br>Set Pending Interrupt Register<br>Reset Normal Power Up Discrete<br>Write Status Word<br>Enable Start-Up ROM<br>Disable Start-Up ROM<br>Direct Memory Access Enable<br>Direct Memory Access Disable<br>Ti mer A Start<br>Ti mer A Halt<br>Output Timer A<br>Reset Trigger-Go<br>Timer B Start<br>Timer B Halt<br>Output Timer B | 0401<br>2000<br>2001<br>2002<br>2003<br>2004<br>2005<br>200A<br>200E<br>4004<br>4005<br>4006<br>4007<br>4008<br>4007<br>4008<br>4009<br>400A<br>400B<br>400C<br>400D<br>400E | SFR<br>SMK<br>CLIR<br>ENBL<br>DSBL<br>RPI<br>SPI<br>RNS<br>WSW<br>ESUR<br>DSUR<br>DSUR<br>DMAE<br>DMAD<br>TAS<br>TAH<br>OTA<br>GO<br>TBS<br>TBH<br>OTB | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3     | 9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9<br>9 |
| Read Configuration Word<br>Read Fault Register Without Clear<br>Read Interrupt Mask<br>Read Pending Interrupt Register<br>Read Status Word<br>Read and Clear Fault Register<br>Input Timer A<br>Input Timer B                                                                                                                                                                                                                                                                | 8400<br>8401<br>A000<br>A004<br>A00E<br>A00F<br>C00A<br>C00E                                                                                                                 | RCW<br>RFR<br>RMK<br>RPIR<br>RSW<br>RCFR<br>ITA<br>ITB                                                                                                 | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2<br>2                                         | 2<br>2<br>2<br>1<br>2<br>2<br>2<br>2<br>2 | 4<br>4<br>4<br>4<br>4<br>4<br>4                                                             |
| Implemented in BPU                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                              |                                                                                                                                                        |                                                                                             |                                           |                                                                                             |
| Memory Protect Enable<br>Load Memory Protect RAM<br>Read Memory Protect RAM                                                                                                                                                                                                                                                                                                                                                                                                  | 4003<br>50XX<br>D0XX                                                                                                                                                         | MPEN<br>LMP<br>RMP                                                                                                                                     | 2<br>2<br>2                                                                                 | 4<br>4<br>3                               | 8<br>8<br>3                                                                                 |
| Implemented in MMU                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                              |                                                                                                                                                        |                                                                                             |                                           |                                                                                             |
| Write Instruction Page Register<br>Write Operand Page Register<br>Read Memory Fault Status<br>Read Instruction Page Register<br>Read Operand Page Register                                                                                                                                                                                                                                                                                                                   | 51XY<br>52XY<br>A00D<br>D1XY<br>D2XY                                                                                                                                         | WIPR<br>WOPR<br>RMFS<br>RIPR<br>ROPR                                                                                                                   | 2<br>2<br>2<br>2<br>2                                                                       | 4<br>4<br>3<br>3<br>3                     | 8<br>8<br>3<br>3<br>3                                                                       |

\* M = memory, P = processor (5 OSC cycles), B = processor (6 OSC cycles), a = average if more than one alternative exists.

Table 6b: Internal I/O Command Summary

### **6.0 TIMING CHARACTERISTICS**

This section provides the detailed timing specifications for the MA17502. Figure 6 depicts the test load used to obtain timing data. Figures 7 through 9 depict the timing waveforms associated with various MA17502 signals. Table 7 provides values for parameters specified in the timing waveforms. All timing values provided in Table 7 are valid over the full military temperature range (-55°C to +125°C), and are measured from 50% point to 50% point (50% of VDD supply voltage, unless otherwise specified). Crosshatching in Figure 7 indicates either a "don't care" or indeterminate state.



Figure 6: Test Load

| Subgroup | Definition                                                |
|----------|-----------------------------------------------------------|
| 1        | Static characteristics specified in Table 9 at +25°C      |
| 2        | Static characteristics specified in Table 9 at +125°C     |
| 3        | Static characteristics specified in Table 9 at -55°C      |
| 7        | Functional tests at +25°C                                 |
| 8a       | Functional tests at +125°C                                |
| 8b       | Functional tests at -55°C                                 |
| 9        | Switching characteristics specified in Table 7b at +25°C  |
| 10       | Switching characteristics specified in Table 7b at +125°C |
| 11       | Switching characteristics specified in Table 7b at -55°C  |

Table 7a: Definition of Subgroups

| No. | Parameter                               | Test Condition <sup>(1) (2)</sup> | Min | Max | Units |
|-----|-----------------------------------------|-----------------------------------|-----|-----|-------|
| 1   | CLKPC ↑ to Microword 1 Valid            | Load 1                            | -   | 95  | ns    |
| 2   | CLK02 $\downarrow$ to Microword 2 Valid | Load 1                            | -   | 41  | ns    |
| 3   | Microword 1 after CLK02 $\downarrow$    | Load 1                            | 5   | -   | ns    |
| 4   | Microword 2 after CLKPC $\downarrow$    | Load 1                            | 25  | -   | ns    |
| 5   | AD Bus to CLKPC $\downarrow$            | -                                 | 10  | -   | ns    |
| 6   | T1 to CLKPC ↑                           | -                                 | 20  | -   | ns    |
| 7   | PIF to CLKPC ↑                          | -                                 | 20  | -   | ns    |
| 8   | IR to CLKPC ↑                           | -                                 | 20  | -   | ns    |
| 9   | HOLD to CLKPC $\downarrow$              | -                                 | 15  | -   | ns    |
| 10  | RESET to CLKPC $\downarrow$             | -                                 | 15  | -   | ns    |
| 11  | AD Bus after CLKPC $\downarrow$         | -                                 | 15  | -   | ns    |
| 12  | HOLD after CLKPC $\downarrow$           | -                                 | 15  | -   | ns    |
| 13  | RESET after CLKPC $\downarrow$          | -                                 | 15  | -   | ns    |
| 14  | T1, PIF, IR after CLKPC $\downarrow$    | -                                 | 0   | -   | ns    |

Mil-Std-883, Method 5005, Subgroup 9, 10, 11

Notes: 1. TA =  $+25^{\circ}$ C,  $-55^{\circ}$ C and  $+125^{\circ}$ C tested at VDD = 4.5V and 5.5V.

2. Unless otherwise noted: VIL  $\ge$  0.0V, VIHTTL  $\le$  4.0V; timing measured from 50% to 50% point.

Table 7b: Timing Parameter Values



Figure 7: Basic Timing



Figure 8: RESET Timing



Figure 9: HOLD Timing

| Parameter               | Min  | Max                  | Units |
|-------------------------|------|----------------------|-------|
| Supply Voltage          | -0.5 | 7                    | V     |
| Input Voltage           | -0.3 | V <sub>DD</sub> +0.3 | V     |
| Current Through Any Pin | -20  | +20                  | mA    |
| Operating Temperature   | -55  | 125                  | °C    |
| Storage Temperature     | -65  | 150                  | °C    |

### 7.0 ABSOLUTE MAXIMUM RATINGS

**Note:** Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these conditions, or at any other condition above those indicated in the operations section of this specification, is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Table 8: Absolute Maximum Ratings

### 8.0 DC ELECTRICAL CHARACTERISTICS

|                   |                                                  |                                                      | Total Dose Radiation Not<br>Exceeding 3x10 <sup>5</sup> Rad(Si) |     |                    |       |
|-------------------|--------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------------|-----|--------------------|-------|
| Symbol            | Parameter                                        | Conditions                                           | Min                                                             | Тур | Max                | Units |
| V <sub>DD</sub>   | Supply Voltage                                   | V <sub>SS</sub> = 0                                  | 4.5                                                             | 5.0 | 5.5                | V     |
| VIHC              | CMOS Input High Voltage (Note 1)                 | -                                                    | V <sub>DD</sub> -1                                              | -   | -                  | V     |
| V <sub>ILC</sub>  | CMOS Input Low Voltage (Note 1)                  | -                                                    | -                                                               | -   | V <sub>SS</sub> +1 | V     |
| V <sub>IHT</sub>  | TTL Input High Voltage (Note 2)                  | -                                                    | 2.0                                                             | -   | -                  | V     |
| V <sub>ILT</sub>  | TTL Input Low Voltage (Note 2)                   | -                                                    | -                                                               | -   | 0.8                | V     |
| V <sub>OHC</sub>  | CMOS Output High Voltage (Note 1)                | $I_{OH} = -1.4 mA, V_{DD} = 4.5 V$                   | 4.0                                                             | -   | -                  | V     |
| V <sub>OLC</sub>  | CMOS Output Low Voltage (Note 1)                 | $I_{OL} = 2mA$ , $V_{DD} = 5.5V$                     | -                                                               | -   | 0.5                | V     |
| I <sub>IL</sub>   | Input Leakage Current (Note 3)                   | $V_{\text{DD}}$ = 5.5V, $V_{\text{IN}}$ = 0V or 5.5V | -                                                               | -   | ±10                | μA    |
| I <sub>oz</sub>   | Output Leakage Current (Note 3)                  | $V_{DD}$ = 5.5V, $V_O$ = 0V or 5.5V                  | -                                                               | -   | ±50                | μA    |
| I <sub>IPU</sub>  | CS or ROMONLYN Input Pull-up<br>Current (Note 4) | $V_{DD} = 5.5V,$<br>CS or ROMONLYN = 0V              | -                                                               | -   | -300               | μΑ    |
| I <sub>DDOP</sub> | Operating Supply Current                         | V <sub>DD</sub> = 5.5V,<br>CLKPCN = CLK02N = 4MHz    | -                                                               | 25  | 35                 | mA    |
| I <sub>DDST</sub> | Static Supply Current                            | $V_{DD} = 5.5V$ ,<br>CLKPCN = CLK02N = 0MHz          | -                                                               | 5   | 10                 | mA    |

 $V_{DD}$  = 5V±10%, over full operating temperature range.

Mil-Std-883, Method 5005, Subgroup 1, 2, 3

**Notes:** 1. The following signals are CMOS compatible:

a) CMOS inputs: CS, ROMONLYN, T1, IRN, PIFN, CLK02N and CLKPCN

b) CMOS I/O signals: Microcode bus (M00-M19) and Microcode address bus (CC00-CC11)

2. The following signals are TTL compatible:

a) TTL inputs: Address/Data Bus (AD00-AD15), RESET and HOLDN

3. Worst case at  $T_A = +125^{\circ}C$ , guaranteed but not tested at  $T_A = -55^{\circ}C$ 

4. CS and ROMONLYN inputs are provided for future microcode expansion and have internal pullup resistors. These signals should be high for normal operation.

Table 9: DC Electrical Characteristics

### 9.0 PACKAGING INFORMATION

| Def |       | Millimetres |       | Inches |            |       |
|-----|-------|-------------|-------|--------|------------|-------|
| Rei | Min.  | Nom.        | Max.  | Min.   | Nom.       | Max.  |
| A   | -     | -           | 5.715 | -      | -          | 0.225 |
| A1  | 0.38  | -           | 1.53  | 0.015  | -          | 0.060 |
| b   | 0.35  | -           | 0.508 | 0.014  | -          | 0.020 |
| С   | 0.229 | -           | 0.36  | 0.009  | -          | 0.014 |
| D   | -     | -           | 82.04 | -      | -          | 3.230 |
| е   | -     | 2.54 Typ.   | -     | -      | 0.100 Typ. | -     |
| e1  | -     | 22.86 Typ.  | -     | -      | 0.900 Typ. | -     |
| н   | 4.71  | -           | 5.38  | 0.185  | -          | 0.212 |
| Ме  | -     | -           | 23.4  | -      | -          | 0.920 |
| Z   | -     | -           | 1.27  | -      | -          | 0.050 |
| W   | -     | -           | 1.53  | -      | -          | 0.060 |

XG413



Figure 10a: 64-Pin Ceramic DIL - Package Style C



Figure 10b: Pin Assignments

| Bof | Millimetres |      |       | Inches |       |       |
|-----|-------------|------|-------|--------|-------|-------|
| Kei | Min.        | Nom. | Max.  | Min.   | Nom.  | Max.  |
| A   | 1.905       | -    | 2.21  | 0.075  | -     | 0.087 |
| b1  | -           | 0.51 | -     | -      | 0.020 | -     |
| D   | 18.08       | -    | 18.62 | 0.712  | -     | 0.733 |
| E   | 18.08       | -    | 18.62 | 0.712  | -     | 0.733 |
| е   | -           | 1.02 | -     | -      | 0.040 | -     |
| Z   | 1.40        | -    | 1.78  | 0.055  | -     | 0.070 |

XG493



Figure 11a: 64-Pad Leadless Chip Carrier - Package Style L



Figure 11b: Pin Assignments

#### Millimetres Inches Ref Min. Nom. Max. Min. Nom. Max. Α -2.72 -0.107 --A1 1.83 2.24 0.072 0.088 -b 0.41 0.51 0.016 0.020 --0.20 0.30 0.008 0.012 С --0.960 D1, D2 23.88 24.51 0.940 -е -2.54 -0.050 -j1 1.02 0.040 ----0.51 0.020 j2 ----L 10.16 10.54 0.400 0.415 --Ζ 1.65 2.16 0.065 0.085 --XG540 A A1 ċ D1 – j1 **∤** Z ŧ. C Ī Pin 1 D2 Top View - -٢ C ī ٢ j2

Figure 12a: 68-Lead Topbraze Flatpack - Package Style F



Figure 12b: Pin Assignments

### **10.0 RADIATION TOLERANCE**

#### **Total Dose Radiation Testing**

For product procured to guaranteed total dose radiation levels, each wafer lot will be approved when all sample devices from each lot pass the total dose radiation test.

The sample devices will be subjected to the total dose radiation level (Cobalt-60 Source), defined by the ordering code, and must continue to meet the electrical parameters specified in the data sheet. Electrical tests, pre and post irradiation, will be read and recorded.

Dynex Semiconductor can provide radiation testing compliant with Mil-Std-883 method 1019 Ionizing Radiation (total dose) test.

| Total Dose (Function to specification)*      | 3x10 <sup>5</sup> Rad(Si)             |
|----------------------------------------------|---------------------------------------|
| Transient Upset (Stored data loss)           | 1x10 <sup>11</sup> Rad(Si)/sec        |
| Transient Upset (Survivability)              | >1x10 <sup>12</sup> Rad(Si)/sec       |
| Neutron Hardness (Function to specification) | >1x10 <sup>15</sup> n/cm <sup>2</sup> |
| Single Event Upset**                         | <1x10 <sup>-10</sup> Errors/bit day   |
| Latch Up                                     | Not possible                          |

\* Other total dose radiation levels available on request

\*\* Worst case galactic cosmic ray upset - interplanetary/high altitude orbit

Table 10: Radiation Hardness Parameters

### **11.0 ORDERING INFORMATION**





HEADQUARTERS OPERATIONS **DYNEX SEMICONDUCTOR LTD** Doddington Road, Lincoln. Lincolnshire. LN6 3LF. United Kingdom. Tel: 00-44-(0)1522-500500 Fax: 00-44-(0)1522-500550

DYNEX POWER INC.

Unit 7 - 58 Antares Drive, Nepean, Ontario, Canada K2E 7W6. Tel: 613.723.7035 Fax: 613.723.1518 Toll Free: 1.888.33.DYNEX (39639)

#### http://www.dynexsemi.com

### e-mail: power\_solutions@dynexsemi.com

CUSTOMER SERVICE CENTRES France, Benelux, Italy and Spain Tel: +33 (0)1 69 18 90 00. Fax: +33 (0)1 64 46 54 50 North America Tel: 011-800-5554-5554. Fax: 011-800-5444-5444 UK, Germany, Scandinavia & Rest Of World Tel: +44 (0)1522 500500. Fax: +44 (0)1522 500020 SALES OFFICES France, Benelux, Italy and Spain Tel: +33 (0)1 69 18 90 00. Fax: +33 (0)1 64 46 54 50 Germany Tel: 07351 827723 North America Tel: (613) 723-7035. Fax: (613) 723-1518. Toll Free: 1.888.33.DYNEX (39639) / Tel: (831) 440-1988. Fax: (831) 440-1989 / Tel: (949) 733-3005. Fax: (949) 733-2986. UK, Germany, Scandinavia & Rest Of World Tel: +44 (0)1522 500500. Fax: +44 (0)1522 500020 These offices are supported by Representatives and Distributors in many countries world-wide. © Dynex Semiconductor 2000 Publication No. DS3565-5 Issue No. 5.0 January 2000 TECHNICAL DOCUMENTATION – NOT FOR RESALE. PRINTED IN UNITED KINGDOM

#### **Datasheet Annotations:**

Dynex Semiconductor annotate datasheets in the top right hard corner of the front page, to indicate product status. The annotations are as follows:-

Target Information: This is the most tentative form of information and represents a very preliminary specification. No actual design work on the product has been started.

**Preliminary Information:** The product is in design and development. The datasheet represents the product as it is understood but details may change. **Advance Information:** The product design is complete and final characterisation for volume production is well in hand.

This publication is issued to provide information only which (unless agreed by the Company in writing) may not be used, applied or reproduced for any purpose nor form part of any order or contract nor to be regarded as a representation relating to the products or services concerned. No warranty or guarantee express or implied is made regarding the capability, performance or suitability of any product or service. The Company reserves the right to alter without prior notice the specification, design or price of any product or service. Information concerning possible methods of use is provided as a guide only and does not constitute any guarantee that such methods of use will be satisfactory in a specific piece of equipment. It is the user's responsibility to fully determine the performance and suitability of any equipment using such information and to ensure that any publication or data used is up to date and has not been superseded. These products are not suitable for use in any medical products whose failure to perform may result in significant injury or death to the user. All products and materials are sold and services provided subject to the Company's conditions of sale, which are available on request.