This manual describes the two board that make up a Model 50, the 2050 base board and the 2051 expansion board.

The 2050 Board is a single board workstation computer. It provides on a single, triple height eurocard all components of a high-performance engineering/scientific workstation: processor, memory, virtual memory management, display subsystem, networking, serial I/O, system bus interface, and various system utilities. The processor is based on a 10 Mhz 68010 CPU, extended with the Sun-2 multiprocess virtual memory management. The 2050 board contains one to four megabytes of memory with zero wait state access. Main memory is equipped with byte parity error detection.

The 2051 Board is an optional memory expansion board that provides an additional one to four megabytes of main memory. It also provides a slot for an optional input/output expansion board, such as a floating point processor.
Table of Contents

1. Data Sheet
   1.1. Features
      1.1.1. Processor
      1.1.2. Display
      1.1.3. I/O
      1.1.4. Other Features
   1.2. Introduction
   1.3. Sun-2 Architecture Overview
   1.4 2050 Board Block Diagram
   1.5. Sun-2 MMU Overview
   1.6. 2050 Board Floor Plan
   1.7. 2051 Board Floor Plan
   1.8. Specification Summary
      1.8.1. CPU
      1.8.2. Memory
      1.8.3. Memory Management Unit
      1.8.4. Display Subsystem
      1.8.5. Ethernet Interface
      1.8.6. Serial I/O Ports
      1.8.7. Other Features
      1.8.8. Diagnostic Features
   1.9. VME-bus Specification
      1.9.1. Master Capabilities
      1.9.2. Slave Capabilities
      1.9.3. System Controller Capabilities
      1.9.4. Power Monitor Capabilities
      1.9.5. Environmental Characteristics
      1.9.6. Power Characteristics
      1.9.7. Physical Characteristics

2. User Guide
   2.1. Programming
   2.2. MMU Implementation
   2.3. Physical Address Assignments
   2.4. Interrupt Assignments
   2.5. Performance Data
      2.5.1. CPU Speed
      2.5.2. Video Memory Access Time
      2.5.3. P1-Bus Access Times
      2.5.4. DVMA Access Time
      2.5.5. P1-Bus Reset
   2.6. Connectors
      2.6.1. J603: Serial Port A
      2.6.2. J604: Serial Port B
# Table of Contents

2.6.3. J605: Keyboard/Mouse 14
2.6.4. J700: Ethernet 15
2.6.5. J1800: Video 15

2.7. Jumper
- 2.7.1. Configuration Jumpers 16
- 2.7.2. Permanent Jumpers, 2050 Board 17
- 2.7.3. Permanent Jumpers, 2051 Board 18

3. Theory of Operations 19

3.1. Conventions 19
- 3.1.1. Schematics 19
- 3.1.2. Signal Conventions 19
- 3.1.3. Component Conventions 20
- 3.1.4. State Diagrams 20

3.2. Major Blocks 21

3.3. Power 21

3.4. Initialization 21

3.5. Clock Oscillators 22

3.6. Derived Clocks 22

3.7. CPU 23
- 3.7.1. Reset 23
- 3.7.2. Special Cycles 23
- 3.7.3. DTACK 23
- 3.7.4. BERR 24
- 3.7.5. Address Error Cycles 24
- 3.7.6. 68010 Cycle to Memory 24
- 3.7.7. 68010 Write Cycle to Video Memory, Best Case 25
- 3.7.8. 68010 Cycle to I/O 25

3.8. DVMA Logic 26
- 3.8.1. Overview 26
- 3.8.2. DVMA Cycles 27
- 3.8.3. DVMA Arbitration Cycle 28
- 3.8.4. DVMA Cycle, Synchronous Memory 28
- 3.8.5. DVMA Cycle, Memory Refresh 29

3.9. I/O-Bus 30

3.10. MMU and MMU Space Devices 31
- 3.10.1. Overview 31
- 3.10.2. Decoding 31
- 3.10.3. MMU Operation 31

3.11. I/O Devices 32
- 3.11.1. Overview 32
- 3.11.2. Decoding 32
- 3.11.3. PROMs 32
- 3.11.4. Timer 32
- 3.11.5. Keyboard/Mouse 32
- 3.11.6. Serial Communication Controller 33
- 3.11.7. Ethernet Control Register 33
<table>
<thead>
<tr>
<th>Section</th>
<th>Title</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>3.11.8</td>
<td>Data Ciphering Processor</td>
<td>34</td>
</tr>
<tr>
<td>3.11.9</td>
<td>68010 Address Load to DCP</td>
<td>34</td>
</tr>
<tr>
<td>3.11.10</td>
<td>68010 Read/Write to DCP, Best Case</td>
<td>34</td>
</tr>
<tr>
<td>3.12</td>
<td>P2-Bus Interface</td>
<td>35</td>
</tr>
<tr>
<td>3.12.1</td>
<td>Introduction</td>
<td>35</td>
</tr>
<tr>
<td>3.12.2</td>
<td>P2 Signals</td>
<td>35</td>
</tr>
<tr>
<td>3.12.3</td>
<td>P2-Bus Cycle</td>
<td>36</td>
</tr>
<tr>
<td>3.12.4</td>
<td>Parity Error Logic</td>
<td>37</td>
</tr>
<tr>
<td>3.13</td>
<td>Ethernet Interface</td>
<td>38</td>
</tr>
<tr>
<td>3.13.1</td>
<td>Overview</td>
<td>38</td>
</tr>
<tr>
<td>3.13.2</td>
<td>Ethernet Data Link Controller</td>
<td>39</td>
</tr>
<tr>
<td>3.13.3</td>
<td>Ethernet DVMA Cycle</td>
<td>39</td>
</tr>
<tr>
<td>3.13.4</td>
<td>Ethernet Phase Lock Loop Decoder - U701</td>
<td>40</td>
</tr>
<tr>
<td>3.13.5</td>
<td>Ethernet Transceiver Interface - J700</td>
<td>40</td>
</tr>
<tr>
<td>3.14</td>
<td>VME Bus Interface</td>
<td>41</td>
</tr>
<tr>
<td>3.14.1</td>
<td>VME Bus Utility Functions</td>
<td>42</td>
</tr>
<tr>
<td>3.14.2</td>
<td>VME Arbiter and Requestor</td>
<td>42</td>
</tr>
<tr>
<td>3.14.3</td>
<td>VME Master Interface</td>
<td>42</td>
</tr>
<tr>
<td>3.14.4</td>
<td>68010 Cycle to VME Bus, Currently Busmaster</td>
<td>43</td>
</tr>
<tr>
<td>3.14.5</td>
<td>68010 Cycle to VME Bus, Not Currently Busmaster</td>
<td>44</td>
</tr>
<tr>
<td>3.14.6</td>
<td>VME Slave Interface</td>
<td>44</td>
</tr>
<tr>
<td>3.14.7</td>
<td>VME Interrupt Handler</td>
<td>45</td>
</tr>
<tr>
<td>3.14.8</td>
<td>68010 Rerun Cycles</td>
<td>46</td>
</tr>
<tr>
<td>3.14.9</td>
<td>Rerun, VME Deadlock Case</td>
<td>46</td>
</tr>
<tr>
<td>3.14.10</td>
<td>Rerun, VME Rerun Case</td>
<td>46</td>
</tr>
<tr>
<td>3.15</td>
<td>Memory</td>
<td>48</td>
</tr>
<tr>
<td>3.15.1</td>
<td>Introduction</td>
<td>48</td>
</tr>
<tr>
<td>3.15.2</td>
<td>Memory Interface</td>
<td>50</td>
</tr>
<tr>
<td>3.15.3</td>
<td>Memory Organization</td>
<td>50</td>
</tr>
<tr>
<td>3.15.4</td>
<td>Memory RAM and Bank Decoding</td>
<td>50</td>
</tr>
<tr>
<td>3.15.5</td>
<td>Memory Section Decoding</td>
<td>50</td>
</tr>
<tr>
<td>3.15.6</td>
<td>Memory Drivers</td>
<td>51</td>
</tr>
<tr>
<td>3.16</td>
<td>Video</td>
<td>52</td>
</tr>
<tr>
<td>3.16.1</td>
<td>Overview</td>
<td>52</td>
</tr>
<tr>
<td>3.16.2</td>
<td>Video Memory and Addressing</td>
<td>53</td>
</tr>
<tr>
<td>3.16.3</td>
<td>Video Memory Controller</td>
<td>53</td>
</tr>
<tr>
<td>3.16.4</td>
<td>Video State Machine</td>
<td>55</td>
</tr>
<tr>
<td>3.16.5</td>
<td>Video Interface to P2-Bus</td>
<td>56</td>
</tr>
<tr>
<td>3.16.6</td>
<td>P2-Bus Address Decoding</td>
<td>56</td>
</tr>
<tr>
<td>3.16.7</td>
<td>P2-Bus Request Generation</td>
<td>56</td>
</tr>
<tr>
<td>3.16.8</td>
<td>P2-Bus Interface Timing</td>
<td>57</td>
</tr>
<tr>
<td>3.16.9</td>
<td>Video Controller</td>
<td>58</td>
</tr>
<tr>
<td>3.16.10</td>
<td>Horizontal State Machine</td>
<td>58</td>
</tr>
<tr>
<td>3.16.11</td>
<td>Horizontal State Machine Timing Diagram</td>
<td>58</td>
</tr>
<tr>
<td>3.16.12</td>
<td>Vertical State Machine</td>
<td>58</td>
</tr>
<tr>
<td>3.16.13</td>
<td>Vertical State Machine Timing Diagram</td>
<td>59</td>
</tr>
<tr>
<td>3.16.14</td>
<td>Video Interrupt Logic</td>
<td>59</td>
</tr>
</tbody>
</table>
3.16.15. Video Clock and Shifter 60
List of Figures

<table>
<thead>
<tr>
<th>Figure</th>
<th>Description</th>
<th>Page</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-1</td>
<td>Sun 2050 Board Architecture</td>
<td>4</td>
</tr>
<tr>
<td>1-2</td>
<td>Sun-2 Memory Management</td>
<td>5</td>
</tr>
<tr>
<td>1-3</td>
<td>Sun 2050 Board Floor Plan</td>
<td>6</td>
</tr>
<tr>
<td>1-4</td>
<td>Sun 2051 Board Floor Plan</td>
<td>7</td>
</tr>
<tr>
<td>3-1</td>
<td>DVMA Controller</td>
<td>26</td>
</tr>
<tr>
<td>3-2</td>
<td>Ethernet Interface</td>
<td>38</td>
</tr>
<tr>
<td>3-3</td>
<td>VME Interface</td>
<td>41</td>
</tr>
<tr>
<td>3-4</td>
<td>Memory Interface</td>
<td>49</td>
</tr>
<tr>
<td>3-5</td>
<td>Memory Interface</td>
<td>52</td>
</tr>
</tbody>
</table>
1. Data Sheet

1.1. Features

1.1.1. Processor

- 32-bit VLSI CPU
- 10 MHz operation with no wait states to main memory
- 1M Bytes (64K) or 1/2/3/4M Bytes (256K) of main memory
- 1M Bytes (64K) or 1/2/3/4M Bytes (256K) of expansion memory
- multiprocessing demand paging virtual memory management
- 16M bytes virtual address space per process
- optional DES encryption processor

1.1.2. Display

- dual-ported 128K Bytes video memory
- 1152 by 900 pixel display resolution
- 67 Hz non-interlaced video refresh

1.1.3. I/O

- integral Ethernet interface transfers directly into memory
- two programmable serial I/O ports with full modem control
- two additional serial interfaces for keyboard and mouse

1.1.4. Other Features

- VME System Bus Interface
- DVMA (direct virtual memory access) from VME Bus
- five programmable 16-bit timers
- 32K to 128K Bytes EPROM
- extensive self-diagnostic capabilities
- triple-height Eurocard form factor
1.2. Introduction

The Sun-2050 Board is a high-performance implementation of the Sun-2 architecture on a single 400mm by 366.67mm Eurocard. The board includes the CPU, virtual memory management, optional processor enhancements, one to four megabytes of main memory with parity error detection, a high-resolution display subsystem, integral Ethernet and RS-423 interfaces, and a dual-ported interface to the VME-bus.

The processor is based on the Motorola 68010 32-bit VLSI CPU, extended with the Sun-2 virtual memory management unit (MMU). The processor executes from main memory at 10 MHz without wait states. The MMU was specifically optimized to support the demand paging requirements of the the 4.2 BSD version of the Unix (TM) operating system. It provides multiple, simultaneous process contexts with up to 16 megabyte virtual memory space each. In addition, the MMU provides separate address spaces for the system and for the user.

The Sun 2050 board contains 1M Bytes (64K RAM) to 4M Bytes (256K RAM) of main memory. With the Sun 2051 memory expansion board, another 1M Bytes (64K) to 4M Bytes (256K) of main memory can be added. 64K and 256K RAMs can be intermixed between the 2050 board and the 2051 board, and overall memory can be expanded in 1M Bytes increments. Memory is equipped with byte parity error detection.

Integral to the Sun-2050 Board is a high-resolution bitmap display subsystem featuring a 1152 by 900 pixel display area and non-interlaced, 67 Hz refresh. The display is refreshed out of a dedicated, dual-ported 128K Bytes video memory, which is logically part of main memory.

The Sun-2 Single Board workstation includes an integral Ethernet interface. This interface uses a VLSI Ethernet controller that features high-performance frame handling and extensive diagnostic capabilities. Ethernet packets are directly transferred in and out of main memory through the use of direct virtual memory access (DVMA).

For serial I/O, two highly programmable serial communication channels are provided featuring software programmable baud rates from 75 Baud to 10.2 K baud and supporting asynchronous, synchronous, or bit-stuffing protocols. Two additional ports are provided for keyboard and mouse interfaces.

The Sun-2050 Board includes a bidirectional interface to the VME Bus with master and slave capabilities. The board provides 24-bit address and 16-bit data transfer capabilities in both directions. It also implements system controller functions such as arbitration, interrupt handling, reset, and power monitoring.

Other features of the board include an optional DES encryption processor, programmable timers, and an identification PROM providing software-readable serial number and Ethernet address.

The board also includes extensive facilities for software and hardware diagnostics. Among them are a bus-error register, a diagnostic display for displaying error messages, a watchdog timer for automatic restart, and powerup self-tests.
1.3. Sun-2 Architecture Overview

The 2050 Board implements a Sun-2 architecture machine. The complete specification of the architecture is contained in the Sun-2 Architecture Manual. The following is a brief overview of the architecture and its implementation on the 2050 Board.

The Sun-2 architecture is divided into three spaces: the CPU space, MMU space, and Device space.

The CPU space comprises the central processing unit (the "CPU") together with coprocessors, such as the floating point coprocessor, and DVM masters, such as the Ethernet interface.

The MMU space is the core of the Sun-2 architecture. It includes the Sun-2 memory management unit (the "MMU") as well as all other Sun-2 architecture extensions to the CPU, such as the bus error register, the system enable register, the diagnostic register, and the ID-PROM. The ID-PROM contains a unique serial number and configuration data for a particular implementation of the architecture.

The Device space of the Sun-2 architecture defines what devices exist in the architecture and how they are accessed. These devices include main memory, the system bus, and I/O devices.

All CPU accesses to device space pass through the MMU and thus are translated and protected in an identical fashion. In addition, direct memory accesses by I/O devices also pass through the memory management and thus operate in a fully protected environment.
1.4. 2050 Board Block Diagram

Figure 1-1 illustrates how the CPU, MMU, and devices are interconnected on the 2050 Board.

The CPU sends out a virtual address that is translated by the MMU into a physical address. The CPU, Ethernet Interface, and VME Slave Interface arbitrate for and share the virtual address bus on the left side of the MMU. The VME Master Interface, Main Memory, Video Memory, and I/O Devices are addressed with physical addresses on the right side of the MMU.
1.5. Sun-2 MMU Overview

The Sun-2 Memory Management Unit provides address translation, protection, sharing, and memory allocation for multiple processes executing on the CPU.

The memory management consists of a context register, a segment map, and a page map. Virtual addresses from the processor are translated into intermediate addresses by the segment map and then into physical addresses by the page map.

The memory management uses a page size of 2K Bytes and a segment size of 32K Bytes (giving 16 pages per segment). Up to 8 contexts can be mapped concurrently. The maximum virtual address space for each context is 16M Bytes.

Figure 1-2 shows how virtual addresses are translated into physical ones.

---

**Context Register**

(3) (3) (9) (4) (11)

user # sys # segment # page # Byte #

**Segment Map**

(8)

pmeg #

**Page Map**

(1) (6) (3) (2) (8) (12)

V P Type S Reserved Physical Address

V = Valid Bit
P = Protection (rwrxrwx)
S = Statistics (acc/mod)

Type = 0: Main Memory
Type = 1: Input/Output
Type = 2: VME 0-8 MB
Type = 3: VME 8-16 MB

---

Figure 1-2: Sun-2 Memory Management
1.6. 2050 Board Floor Plan

Figure 1.3 gives an overview of layout of the 2050 Board, which is the main CPU board.

![Board Floor Plan Diagram]

The connectors on the backplane of the board are called the P1, P2, and P3 connectors. The P1 Connector carries the VME Bus, also referred to as the P1-Bus. The P2 Connector serves for the memory expansion bus, or the P2-Bus. The P3 Connector powers the board.

The connector on the input/output side of the board are, in sequence from top to bottom: (J605) Keyboard/Mouse Connector, (J603) Serial Port A, (J604) Serial Port B, (J700) Ethernet Port, and (J1800) Video Connector.
1.7. 2051 Board Floor Plan

Figure 1-4 gives an overview of layout of the 2051 Board, which is the memory expansion board.

![Diagram of 2051 Board Floor Plan]

The connectors on the backplane of the board are called the P1, P2, and P3 connectors. The P1 Connector carries the VME Bus, also referred to as the P1-Bus. The P2 Connector serves for the memory expansion bus, or the P2-Bus. The P3 Connector powers the board.

The piggy-back connectors on the board provide for expansion with one input/output board, i.e., a floating point processor board. The connector at the lower left of the board provides an interface from the input/output board to the outside.
1.8. Specification Summary

1.8.1. CPU

- M68010 CPU, 10 MHz

1.8.2. Memory

- 1M Bytes (64K) or 1/2/3/4M Bytes (256K) of main memory
- 1M Bytes (64K) or 1/2/3/4M Bytes (256K) of expansion memory
- high-speed, no-wait state operation
- transparent hardware memory refresh
- byte parity error detection

1.8.3. Memory Management Unit

- Sun-2 memory management unit
- two-level, multiprocess virtual memory management
- full support for demand paging
- 16M Bytes virtual address space per process
- separate address spaces for supervisor and user
- valid, accessed, and modified tags to assist paging algorithms
- separate read, write, and execute tags for user and supervisor accesses

1.8.4. Display Subsystem

- dedicated dual-ported video memory
- 1152 by 900 display format
- 100 MHz video clock
- 67 Hz non-interlaced video refresh

1.8.5. Ethernet Interface

- VLSI Ethernet controller (82586)
- digital phase decoder
- packets transferred directly in and out of main memory
- extensive diagnostic capabilities

1.8.6. Serial I/O Ports

- two programmable serial I/O ports
- based on synchronous communication controller (8530)
- software programmable baud rates (75 baud to 19.2 kilobaud)
- asynchronous, synchronous, and bit-stuffing protocols
- two serial ports for keyboard and mouse
1.8.7. Other Features

- VME System bus interface
- DVMA (direct virtual memory access) from VME Bus
- optional DES encryption processor (AMD 9518)
- up to 128K Bytes EPROM (27128, 27256, 27512)
- live programmable 16-bit timers (AMD 9513)
- software interrupt capability
- software readable identification PROM (storing serial number and other information)

1.8.8. Diagnostic Features

- diagnostic LED display
- bus error register
- watchdog reset timer
- bus timeout timer

1.9. VME-bus Specification

1.9.1. Master Capabilities

- Data Bus Size: D16 MASTER 16-bit/8-bit data
- Address Bus Size: A24 MASTER 24-bit/16-bit addresses
- Timeout Option: TOUT(100 USEC) 100 microsecond timeout period
- Sequential Access: None
- Interrupt Handler: IH(1-7) STAT Level 1 through 7, jumperable
- Requestor Option: ROR R(3) Release on Request, level 3

1.9.2. Slave Capabilities

- Data Bus Size: D16 SLAVE 16-bit/8-bit data
- Address Bus Size: A24 SLAVE 24-bit-only addresses
- Sequential Access: None
- Interrupter Options: None

1.9.3. System Controller Capabilities

- Clock Option: SYSCLK 16 MHz, jumperable
- Arbiter Option: ONE Bus Request Level 3 Only
- Note: The 2050 Board must be the System Controller in a VME System.
1.9.4. Power Monitor Capabilities

- ACFAIL Option: ACFAIL asserted when VCC < 4.5V
- SYSRESET Option: SYSRESET asserted during CPU Reset
- SYSFAIL Option: SYSFAIL not used

1.9.5. Environmental Characteristics

- Operating Temperature: 10 - 55°C
- Humidity: 0 - 90%, non-condensing

1.9.6. Power Characteristics

- 12 Amp max at +5 Volt + 5%
- 0.5 Amp max at +12 Volt + 5%
- 0.5 Amp max at -12 Volt + 5%

1.9.7. Physical Characteristics

- Height: 356.67 mm (14.44")
- Width: 400.00 mm (15.75")
- Depth: 40.64 mm (1.6")
- Weight: 1788 g (64 oz)
2. User Guide

2.1. Programming

The 2050 Board implements the Sun-2 Architecture, Machine Type 2. The full architecture is documented in the Sun-2 Architecture Manual and no attempt is made to repeat this information here. However, this section does describe the features specific to this implementation of the architecture.

2.2. MMU Implementation

The MMU of this machine type implements a page number field of 12 bits. It thus supports a physical address of 23 bits, capable of addressing 8M Bytes. The other physical address bits, in the page map are not implemented. When read, those bits not implemented remain undefined.

2.3. Physical Address Assignments

<table>
<thead>
<tr>
<th>Type</th>
<th>Address</th>
<th>Device</th>
<th>Wait States</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>23-bit</td>
<td>Memory Bus</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[0x000000]</td>
<td>Physical Memory 1..8M Bytes</td>
<td>0</td>
</tr>
<tr>
<td>1</td>
<td>23-bit</td>
<td>I/O Bus</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[0x000000]</td>
<td>BW-Video Memory</td>
<td>1 Write, 4..8 Read</td>
</tr>
<tr>
<td></td>
<td>[0x020000]</td>
<td>Video Control Register</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F0000]</td>
<td>EPROM</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F0800]</td>
<td>Ethernet Interface</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F1000]</td>
<td>Encryption Processor</td>
<td>2..8</td>
</tr>
<tr>
<td></td>
<td>[0x7F1800]</td>
<td>Keyboard/Mouse Interface</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F2000]</td>
<td>Serial Port</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F2800]</td>
<td>Timer</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F3000]</td>
<td>Reserved</td>
<td>2</td>
</tr>
<tr>
<td></td>
<td>[0x7F3800]</td>
<td>Reserved</td>
<td>2</td>
</tr>
<tr>
<td>2</td>
<td>23-bit</td>
<td>PCI-Bus or System Bus</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[0x000000]</td>
<td>0..8M Bytes VME 24-bit address 1 + device access time</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>23-bit</td>
<td>PCI-Bus or System Bus</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[0x000000]</td>
<td>8..16M Bytes VME 24-bit access 1 + device access time</td>
<td></td>
</tr>
<tr>
<td></td>
<td>[0x7F0000]</td>
<td>64K Bytes VME 16-bit address 1 + device access time</td>
<td></td>
</tr>
</tbody>
</table>

Accesses to the VME Bus incur an additional 2 wait states access time if the 2050 board is not currently bus master.
2.4. Interrupt Assignments

The following table summarizes the interrupt level assignments for the devices that have been described in this manual. All these interrupts are auto vectored.

<table>
<thead>
<tr>
<th>Level</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>7</td>
<td>TIMER1</td>
</tr>
<tr>
<td>6</td>
<td>Serial Port</td>
</tr>
<tr>
<td>5</td>
<td>TIMER2...5</td>
</tr>
<tr>
<td>4</td>
<td>VIDEO</td>
</tr>
<tr>
<td>3</td>
<td>Ethernet or system enable register EN.INT3</td>
</tr>
<tr>
<td>2</td>
<td>System enable register EN.INT2</td>
</tr>
<tr>
<td>1</td>
<td>System enable register EN.INT1</td>
</tr>
</tbody>
</table>

In addition, the VME-bus can cause vectored interrupts on all levels. Individual VME-bus interrupt levels can be disabled with jumpers.

2.5. Performance Data

2.5.1. CPU Speed

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>CPU clock cycle</td>
<td>101.72 nsec (9.8304 MHz)</td>
</tr>
<tr>
<td>CPU basic cycle</td>
<td>406.90 nsec</td>
</tr>
</tbody>
</table>

2.5.2. Video Memory Access Time

Read accesses are unbuffered and will cause 4 to 8 wait states. Write accesses to the video memory are buffered. However, subsequent read or write accesses will have to wait until the video memory has completed the requested operation. Write accesses to the video memory via the copy mode will cause the same behavior as direct write accesses.

2.5.3. P1-Bus Access Times

This section describes the access times of the P1-Bus. The time to complete a P1-Bus access consists of three elements: overhead, the cost of P1-Bus acquisition if the 2050 Board is not currently P1-Bus master, and the actual access time of the P1-Bus device.

The total number of wait states for a P1-Bus access can be computed by the following formula:

\[ 1 \text{ WS (overhead)} + 2 \text{ WS (bus acquisition time if board does not have bus mastership and bus is idle)} + \text{access time of P1-Bus device divided by the clock period of the CPU rounded up to the nearest integer number.} \]
2.5.4. DVMA Access Time

DVMA cycles from the P1-Bus are serviced after the current CPU cycle completes and after pending memory refresh cycles are executed. Thus DVMA cycles exhibit a variable access time that ranges from 0.7 microseconds in the best case to 1.5 microseconds worst case with an average of about 1.0 microseconds.

After a DVMA cycle has executed, a CPU cycle will start before another DVMA cycle is granted. This means that the cycle time for DVMA is one DVMA cycle plus at least one CPU cycle. Thus the DVMA cycle time will be in the range of 1.1 to 1.9 microseconds with an average of 1.4 microseconds, as long as the DVMA master can generate transfers at this rate.

2.5.5. P1-Bus Reset

The 2050 Board can be configured either as a P1-Bus Reset Master or Slave.

As a P1-Bus Reset Master, the 2050 Board issues Reset to the VME Bus. Power-On Reset, Watchdog Reset, and 68010 Reset will all assert P1-Bus Reset. Other P1-Bus devices may also assert P1-Bus Reset, but this will have no effect on the on-board CPU and devices.

As a P1-Bus Reset Slave, the 2050 Board receives Reset from the VME Bus, but does not drive Reset to the VME Bus. The VME Bus Reset has the same effect as an on-board power-on-reset.
2.6. Connectors

This section documents the pinout of all the connectors used on the Sun 2050 board.

### 2.6.1. J603: Serial Port A

<table>
<thead>
<tr>
<th>PIN</th>
<th>SIGNAL</th>
<th>PIN</th>
<th>SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>---</td>
<td>14</td>
<td>---</td>
</tr>
<tr>
<td>2</td>
<td>TXDA[+]</td>
<td>15</td>
<td>DBA[]</td>
</tr>
<tr>
<td>3</td>
<td>RXDA[+]</td>
<td>16</td>
<td>---</td>
</tr>
<tr>
<td>4</td>
<td>RTSB[+]</td>
<td>17</td>
<td>DBA[]</td>
</tr>
<tr>
<td>5</td>
<td>CTSB[+]</td>
<td>18</td>
<td>---</td>
</tr>
<tr>
<td>6</td>
<td>DSRA[+]</td>
<td>19</td>
<td>---</td>
</tr>
<tr>
<td>7</td>
<td>GND</td>
<td>20</td>
<td>DTRB[+]</td>
</tr>
<tr>
<td>8</td>
<td>DCDA[+]</td>
<td>21</td>
<td>---</td>
</tr>
<tr>
<td>9</td>
<td>---</td>
<td>22</td>
<td>---</td>
</tr>
<tr>
<td>10</td>
<td>---</td>
<td>23</td>
<td>---</td>
</tr>
<tr>
<td>11</td>
<td>---</td>
<td>24</td>
<td>DBA[]</td>
</tr>
<tr>
<td>12</td>
<td>---</td>
<td>25</td>
<td>VEE</td>
</tr>
<tr>
<td>13</td>
<td>---</td>
<td>---</td>
<td>---</td>
</tr>
</tbody>
</table>

### 2.6.2. J604: Serial Port B

<table>
<thead>
<tr>
<th>PIN</th>
<th>SIGNAL</th>
<th>PIN</th>
<th>SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>---</td>
<td>14</td>
<td>---</td>
</tr>
<tr>
<td>2</td>
<td>TXDB[+]</td>
<td>15</td>
<td>DBB[+]</td>
</tr>
<tr>
<td>3</td>
<td>RXDB[+]</td>
<td>16</td>
<td>---</td>
</tr>
<tr>
<td>4</td>
<td>RTSB[+]</td>
<td>17</td>
<td>DBB[+]</td>
</tr>
<tr>
<td>5</td>
<td>CTSB[+]</td>
<td>18</td>
<td>---</td>
</tr>
<tr>
<td>6</td>
<td>DSRB[+]</td>
<td>19</td>
<td>---</td>
</tr>
<tr>
<td>7</td>
<td>GND</td>
<td>20</td>
<td>DTRB[+]</td>
</tr>
<tr>
<td>8</td>
<td>DCDB[+]</td>
<td>21</td>
<td>---</td>
</tr>
<tr>
<td>9</td>
<td>---</td>
<td>22</td>
<td>---</td>
</tr>
<tr>
<td>10</td>
<td>---</td>
<td>23</td>
<td>---</td>
</tr>
<tr>
<td>11</td>
<td>---</td>
<td>24</td>
<td>DBB[+]</td>
</tr>
<tr>
<td>12</td>
<td>---</td>
<td>25</td>
<td>VEE</td>
</tr>
<tr>
<td>13</td>
<td>---</td>
<td>---</td>
<td>---</td>
</tr>
</tbody>
</table>

### 2.6.3. J605: Keyboard/Mouse

<table>
<thead>
<tr>
<th>PIN</th>
<th>SIGNAL</th>
<th>PIN</th>
<th>SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>RXD0[+]</td>
<td>9</td>
<td>GND</td>
</tr>
<tr>
<td>2</td>
<td>GND</td>
<td>10</td>
<td>VCC</td>
</tr>
<tr>
<td>3</td>
<td>TXD0[+]</td>
<td>11</td>
<td>VCC</td>
</tr>
<tr>
<td>4</td>
<td>GND</td>
<td>12</td>
<td>VCC</td>
</tr>
<tr>
<td>5</td>
<td>RXD1[+]</td>
<td>13</td>
<td>---</td>
</tr>
<tr>
<td>6</td>
<td>GND</td>
<td>14</td>
<td>VCC</td>
</tr>
<tr>
<td>7</td>
<td>TXD1[+]</td>
<td>15</td>
<td>VCC</td>
</tr>
<tr>
<td>8</td>
<td>GND</td>
<td>---</td>
<td>---</td>
</tr>
</tbody>
</table>
### 2.6.4. J700: Ethernet

<table>
<thead>
<tr>
<th>PIN</th>
<th>SIGNAL</th>
<th>PIN</th>
<th>SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>-----</td>
<td>9</td>
<td>E.COL-</td>
</tr>
<tr>
<td>2</td>
<td>E.COL+</td>
<td>10</td>
<td>E.TXD-</td>
</tr>
<tr>
<td>3</td>
<td>E.TXD+</td>
<td>11</td>
<td>-----</td>
</tr>
<tr>
<td>4</td>
<td>-----</td>
<td>12</td>
<td>E.RXD-</td>
</tr>
<tr>
<td>5</td>
<td>E.RXD+</td>
<td>13</td>
<td>+12V</td>
</tr>
<tr>
<td>6</td>
<td>GND</td>
<td>14</td>
<td>-----</td>
</tr>
<tr>
<td>7</td>
<td>VCC</td>
<td>15</td>
<td>-----</td>
</tr>
</tbody>
</table>

### 2.6.5. J1800: Video

<table>
<thead>
<tr>
<th>PIN</th>
<th>SIGNAL</th>
<th>PIN</th>
<th>SIGNAL</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>VIDEO+</td>
<td>6</td>
<td>VIDEO-</td>
</tr>
<tr>
<td>2</td>
<td>-----</td>
<td>7</td>
<td>GND</td>
</tr>
<tr>
<td>3</td>
<td>HSYNC</td>
<td>8</td>
<td>GND</td>
</tr>
<tr>
<td>4</td>
<td>VSYNC</td>
<td>9</td>
<td>GND</td>
</tr>
<tr>
<td>5</td>
<td>-----</td>
<td>15</td>
<td>-----</td>
</tr>
</tbody>
</table>
2.7. Jumpers

This section describes all the jumpers used on the board. In the following listing, each group of jumpers denotes exclusive combinations. That means, within each group only one jumper combination may be active at a time.

2.7.1. Configuration Jumpers

These jumpers allow configuration of the 2050 Board for specific applications. Default Jumpers are marked with an asterisk (*).

<table>
<thead>
<tr>
<th>LABEL</th>
<th>PINS</th>
<th>DESCRIPTION IN/OUT</th>
</tr>
</thead>
<tbody>
<tr>
<td>J702</td>
<td>1-2</td>
<td>Enable/Disable 5 Volt to Ethernet</td>
</tr>
<tr>
<td>J704</td>
<td>1-2</td>
<td>Level 2/Level 1 Ethernet Transceiver</td>
</tr>
<tr>
<td>J600</td>
<td>1-2</td>
<td>Enable/Disable VME Interrupt Level 1</td>
</tr>
<tr>
<td>J600</td>
<td>3-4</td>
<td>Enable/Disable VME Interrupt Level 2</td>
</tr>
<tr>
<td>J600</td>
<td>5-6</td>
<td>Enable/Disable VME Interrupt Level 3</td>
</tr>
<tr>
<td>J600</td>
<td>7-8</td>
<td>Enable/Disable VME Interrupt Level 4</td>
</tr>
<tr>
<td>J600</td>
<td>9-10</td>
<td>Enable/Disable VME Interrupt Level 5</td>
</tr>
<tr>
<td>J600</td>
<td>11-12</td>
<td>Enable/Disable VME Interrupt Level 6</td>
</tr>
<tr>
<td>J600</td>
<td>13-14</td>
<td>Enable/Disable VME Interrupt Level 7</td>
</tr>
<tr>
<td>J900</td>
<td>1-2</td>
<td>DVMA Address Comparator A20=0/1</td>
</tr>
<tr>
<td>J900</td>
<td>3-4</td>
<td>DVMA Address Comparator A21=0/1</td>
</tr>
<tr>
<td>J900</td>
<td>5-6</td>
<td>DVMA Address Comparator A22=0/1</td>
</tr>
<tr>
<td>J900</td>
<td>7-8</td>
<td>DVMA Address Comparator A23=0/1</td>
</tr>
<tr>
<td>J900</td>
<td>9-10</td>
<td>Enable/Disable VME Arbiter</td>
</tr>
<tr>
<td>J900</td>
<td>11-12</td>
<td>Enable/Disable VME Reset Master</td>
</tr>
<tr>
<td>J900</td>
<td>13-14</td>
<td>Enable/Disable VME Reset Slave</td>
</tr>
<tr>
<td>J900</td>
<td>15-16</td>
<td>Enable/Disable VME System Clock</td>
</tr>
<tr>
<td>J1600</td>
<td>1-2</td>
<td>Video Register Sense Bit 0</td>
</tr>
<tr>
<td>J1600</td>
<td>3-4</td>
<td>Video Register Sense Bit 1</td>
</tr>
<tr>
<td>J1600</td>
<td>5-6</td>
<td>Video Register Sense Bit 2</td>
</tr>
<tr>
<td>J1600</td>
<td>7-8</td>
<td>Video Register Sense Bit 3</td>
</tr>
</tbody>
</table>
2.7.2. Permanent Jumpers, 2050 Board

The following jumpers are factory installed and are normally not modified. Those installed normally are indicated with an asterisk (*).

<table>
<thead>
<tr>
<th>LABEL</th>
<th>PINS</th>
<th>DESCRIPTION IN/OUT</th>
</tr>
</thead>
<tbody>
<tr>
<td>J200</td>
<td>1-2</td>
<td>Enable/Disable UART Clock</td>
</tr>
<tr>
<td>J200</td>
<td>3-4</td>
<td>10/12 MHZ CPU operation</td>
</tr>
<tr>
<td>J200</td>
<td>5-6</td>
<td>12/10 MHZ CPU operation</td>
</tr>
<tr>
<td>J200</td>
<td>7-8</td>
<td>Reserved</td>
</tr>
<tr>
<td>J200</td>
<td>9-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>J200</td>
<td>11-12</td>
<td>Enable/Disable Ethernet Clock</td>
</tr>
<tr>
<td>J200</td>
<td>13-14</td>
<td>Enable/Disable Memory Refresh</td>
</tr>
<tr>
<td>J200</td>
<td>15-16</td>
<td>Enable/Disable Timeouts</td>
</tr>
<tr>
<td>J500</td>
<td>1-2</td>
<td>PROM TYPE = 27128</td>
</tr>
<tr>
<td>J500</td>
<td>3-4</td>
<td>PROM TYPE = 27256 or 27512</td>
</tr>
<tr>
<td>J500</td>
<td>5-6</td>
<td>PROM TYPE = 27128 or 27128</td>
</tr>
<tr>
<td>J500</td>
<td>7-8</td>
<td>PROM TYPE = 27512</td>
</tr>
<tr>
<td>J1201</td>
<td>1-2</td>
<td>Enable/Disable 2nd megabyte (256K RAM)</td>
</tr>
<tr>
<td>J1201</td>
<td>3-4</td>
<td>Enable/Disable 3/4 megabyte (256k RAM)</td>
</tr>
<tr>
<td>J1201</td>
<td>5-6</td>
<td>64K/256K RAMs</td>
</tr>
<tr>
<td>J1201</td>
<td>7-8</td>
<td>256K/64K RAMs</td>
</tr>
<tr>
<td>J1201</td>
<td>9-10</td>
<td>64K/256K RAMs</td>
</tr>
<tr>
<td>J1201</td>
<td>11-12</td>
<td>256K/64K RAMs</td>
</tr>
<tr>
<td>J1201</td>
<td>13-14</td>
<td>64K/256K RAMs</td>
</tr>
<tr>
<td>J1201</td>
<td>15-16</td>
<td>256K/64K RAMs</td>
</tr>
<tr>
<td>J1600</td>
<td>9-10</td>
<td>Reserved</td>
</tr>
<tr>
<td>J1600</td>
<td>11-12</td>
<td>Reserved</td>
</tr>
<tr>
<td>J1600</td>
<td>13-14</td>
<td>10/12 MHZ CPU operation</td>
</tr>
<tr>
<td>J1600</td>
<td>15-16</td>
<td>12/10 MHZ CPU operation</td>
</tr>
<tr>
<td>J1801</td>
<td>1-2</td>
<td>Enable/Disable 100 MHZ Video Clock</td>
</tr>
</tbody>
</table>

The jumper positions for different PROM sizes are summarized in the table below.

<table>
<thead>
<tr>
<th>PROM</th>
<th>JUMPER</th>
<th>JUMPERED PINS</th>
</tr>
</thead>
<tbody>
<tr>
<td>27128</td>
<td>J600</td>
<td>1-2 and 5-6</td>
</tr>
<tr>
<td>27256</td>
<td>J600</td>
<td>3-4 and 5-6</td>
</tr>
<tr>
<td>27512</td>
<td>J600</td>
<td>3-4 and 7-8</td>
</tr>
</tbody>
</table>
2.7.3. Permanent Jumpers, 2051 Board

On the memory expansion board, there are jumpers for different memory sizes. The jumpers are factory installed and are normally not modified. For a 1 megabyte base board, the jumpers for the memory expansion board are as follows, organized by memory size on memory expansion board:

<table>
<thead>
<tr>
<th>SIZE</th>
<th>JUMPER</th>
<th>JUMPERED PINS</th>
</tr>
</thead>
<tbody>
<tr>
<td>1 MB</td>
<td>J2200</td>
<td>3-4</td>
</tr>
<tr>
<td>2 MB</td>
<td>J2200</td>
<td>3-4, 5-6</td>
</tr>
<tr>
<td>2 MB</td>
<td>J2200</td>
<td>3-4, 5-6</td>
</tr>
<tr>
<td>3 MB</td>
<td>J2200</td>
<td>3-4, 5-6, 7-8</td>
</tr>
<tr>
<td>3 MB</td>
<td>J2200</td>
<td>3-4, 5-6, 7-8</td>
</tr>
<tr>
<td>4 MB</td>
<td>J2200</td>
<td>3-4, 5-6, 7-8, 9-10</td>
</tr>
<tr>
<td>4 MB</td>
<td>J2200</td>
<td>3-4, 5-6, 7-8, 9-10</td>
</tr>
</tbody>
</table>

In addition, the 2051 Board has a jumper block for the daisy chained VME-bus grant lines and the VME-bus interrupt acknowledge chain. These jumpers are installed in systems that need to daisy-chain those VME-bus signals.

<table>
<thead>
<tr>
<th>JUMPER</th>
<th>PINS</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>J2100</td>
<td>1-2</td>
<td>BUS GRANT 0</td>
</tr>
<tr>
<td>J2100</td>
<td>3-4</td>
<td>BUS GRANT 1</td>
</tr>
<tr>
<td>J2100</td>
<td>5-6</td>
<td>BUS GRANT 2</td>
</tr>
<tr>
<td>J2100</td>
<td>7-8</td>
<td>BUS GRANT 3</td>
</tr>
<tr>
<td>J2100</td>
<td>15-16</td>
<td>IACK CHAIN</td>
</tr>
</tbody>
</table>
3. Theory of Operations

This chapter describes the theory of operations of the 2050 Board and the conventions that are used in the schematics.

3.1. Conventions

This section describes the conventions employed in the schematics and the documentation of this board. The discussion assumes that the reader has a working knowledge of digital electronics and has access to descriptions of the components used on the board.

3.1.1. Schematics

The schematics is contained in the file with extension "PRE". The suffix of the schematics file names reflects the drawing page number.

3.1.2. Signal Conventions

Whenever possible, standard drawing conventions are employed. Signal flow is shown from left to right, and top to bottom.

Both active-high and active-low signals are used. A signal name that is followed by a minus ("- ") indicates that the signal is asserted active low (<0.4V), e.g. OE-. Conversely, a signal that is not followed by a minus is an active high signal (>2.0V).

For signals with multiple meanings or synonyms, the synonyms are listed separated by a slash "/". For example, the signal name for a read-write signal that is active low for write is "READ/WRIT*".

Signals that are part of busses are indicated by a common prefix followed by a number. For example, a 16 bit data bus might be labelled "D0", "D1", "D2", and so on to "D15". A group of signals that are part of a signal vector are denoted by a common prefix separated by the suffix with ".". For example, all P1 signals start with the prefix "P1.".

Connector signals are distinguished by a suffix of "[]" with an optional string enclosed inside the square brackets identifying the connector name.
3.1.3. Component Conventions

Components are identified by component name (e.g. 74LS00), component location (e.g. U100), and properties if required (e.g. 100-Ohm).

Component names (also referred to as Body Name in the wirelist) indicate the type of component being used. The component name is derived from the "generic" or industry standard name. Component names are translated into Diptypes that specify the physical component associated with the component name. There is only one diptype for components that are sections of the same physical package (e.g. four 74LS00 gates form one 74LS00 diptype). Diptypes are translated by the parts list into manufacturer codes and part names.

Component locations provide a unique designator for the component. They are chosen to indicate the schematics page on which the component is located. For example, component U100 is most likely positioned on page 1. Component locations consist of one letter followed by one to four digits. The letter indicates the type of component and is one of:

<table>
<thead>
<tr>
<th>Letter</th>
<th>Component Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>C</td>
<td>Standard Capacitor</td>
</tr>
<tr>
<td>D</td>
<td>Diode</td>
</tr>
<tr>
<td>K</td>
<td>Electrolytic Capacitor</td>
</tr>
<tr>
<td>L</td>
<td>Inductance</td>
</tr>
<tr>
<td>X</td>
<td>Decoupling Capacitor</td>
</tr>
<tr>
<td>J</td>
<td>Jumper or Connector</td>
</tr>
<tr>
<td>R</td>
<td>Resistor</td>
</tr>
<tr>
<td>S</td>
<td>Single-in-line component</td>
</tr>
<tr>
<td>U</td>
<td>Dual-in-line component</td>
</tr>
</tbody>
</table>

Location labels are cross-indexed in the wirelist into diptype and component names and locations on the schematics.

Component Properties help to further specify a generic component. Three types of properties are used:

<table>
<thead>
<tr>
<th>Property</th>
<th>Meaning</th>
<th>Example Interpretation</th>
</tr>
</thead>
<tbody>
<tr>
<td>:</td>
<td>Value Specification</td>
<td>:10-UF This capacitor has a value of 10 UF</td>
</tr>
<tr>
<td>#</td>
<td>Reference</td>
<td>#A500 This part is referred as part A500</td>
</tr>
<tr>
<td>+</td>
<td>Additive Property</td>
<td>+S40 Add a 40-pin socket to this component</td>
</tr>
</tbody>
</table>

3.1.4. State Diagrams

State Diagrams are drawn to the following conventions:

1. Left to right with incrementing state numbers along the horizontal axis.
2. Signal transitions represent the actual logic levels of the named signal.
3. Signals are represented without propagation delays.
3.2. Major Blocks

The major logic blocks are:

- Power
- Initialization
- Clocks
- CPU
- IO-Bus Interface
- MMU
- I/O Devices
- P2-Bus Interface
- Memory
- Video Subsystem
- Ethernet Interface

3.3. Power

*Reference: Schematics Page 19*

The 2050 Board uses +5V for all of its onboard logic. It also requires a +12V for the Ethernet transceiver and a -5V for the RS423 drivers and the Video ECL circuitry. The -5V is generated from the -12V supply by on-board regulator [LM337:U137]. Signal [-5VH] connects to the UART connectors pin 25 to terminate that line.

3.4. Initialization

*Reference: Schematics Page 19*

The 2050 Board includes a power-on/power-off reset generator that provides an accurate reset pulse. The circuit uses a dual comparator [LM393:U133], a 1.2 Volt reference voltage [LM355:R101], charge capacitor [K:K100], and resistor network [R:R100..R107].

The first comparator forms a power-on reset generator by comparing the voltage from the charge capacitor with the reference. This comparator asserts its output until the voltage across the charge capacitor corresponds to a VCC of 4.5 Volt. The second comparator forms a power-off reset generator by comparing the +5V supply with the reference. This comparator asserts its output when the +5V supply voltage is below 4.5 Volt without the charge delay incurred by the first comparator. The output of both comparators is wire ORed so that signal power-on-reset [POR] is active when either comparator asserts its output.
3.5. Clock Oscillators

*Reference: Schematics Page 2*

The 2050 Board has 4 independent clock oscillators on board. They are:

- 10-MHz CPU clock and constant clock (19.6608 MHz) [K1114A:U200].
- 12-MHz CPU clock (24.0000 MHz) [K1114A:U201].
- Ethernet clock and VME system clock (16.0000 MHz) [K1114A:U202].
- Video clock (100.0000 MHz) [K1114A:U1800].

In addition, the Ethernet PLL [MB502:U701] features its own crystal oscillator with a frequency of 100 MHz. All clock oscillators have disconnect jumper for ATE test purposes. The 12-MHz CPU Clock is installed only if the board is configured for that frequency.

3.6. Derived Clocks

The system clock is the particular CPU clock for which the board is configured divided by two in flipflops [74F74:U203-0]. Counter [74LS590:U211] divides the system clock into clocks for the data ciphering processor, the timeout counter, and the refresh clock. Counter [74LS393:U212-1] divides the constant clock [C.514] into clock [C.204] for the UART and the Timer.

The clock strobes [C.S4, C.S5, ETC] are derived from transitions on the system clock and enabled with processor address strobe [P.AS] as illustrated in the figure below for a 12-state cycle.

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C.S4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>C.S5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.DTACK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.7. CPU

Reference: Schematics Page 1

3.7.1. Reset

CPU Reset is generated by PAL [P16R4:U109] under three conditions:

- **Power-On-Reset:** The power-on-reset generator asserts [POR] that causes PAL [P16R4:U109] to assert processor reset.
- **External Reset:** If the 2050 Board is configured as a reset slave, then VME System Reset [P1:SYSR] asserts RESIN that causes PAL [P16R4:U109] to assert processor reset.
- **Watchdog Reset:** If the CPU halts it asserts [P.HALT]. In this case, PAL [P16R4:U109] automatically generates processor reset to continue processing.

3.7.2. Special Cycles

In the discussion below, reference will be made to *special cycles*. A special cycle is one in which the 68010 function code is neither program or data. Special cycles include CPU space cycles (FC = 7) and MMU space cycles (FC = 3). Supervisor program fetches in Boot state, which are forced to read from the Boot PROM, are also treated as special cycles.

Special cycles are recognized in PAL [P16L8:U101] and cause signal [Q.SPECIAL] to be asserted. [Q.SPECIAL] inhibits the assertion of [Q.CAS] in flipflop [74F74:U204], inhibits the assertion of [P.BERR] in PAL [P16L8:U103], and selects signal [SPWAIT] as source for DTACK in selector [74F151:U118]. Thus during special cycles no bus errors can occur, and the source for the [DTACK] is [SPWAIT].

3.7.3. DTACK

The CPU uses a number of handshake signals to generate the timing required by the devices it is accessing. The following table gives the source of the DTACK for the different page types and special cycles.

<table>
<thead>
<tr>
<th>Condition</th>
<th>Device</th>
<th>Source of DTACK</th>
</tr>
</thead>
<tbody>
<tr>
<td>TYPE=0</td>
<td>Main Memory</td>
<td>CS4 <em>(READ + P2.WAIT)</em></td>
</tr>
<tr>
<td>TYPE=1</td>
<td>Video Memory</td>
<td>CS7 * P2.WAIT</td>
</tr>
<tr>
<td>TYPE=1</td>
<td>I/O</td>
<td>CS7 * P2.WAIT</td>
</tr>
<tr>
<td>TYPE=2</td>
<td>VME</td>
<td>P1.DTACK</td>
</tr>
<tr>
<td>TYPE=3</td>
<td>VME</td>
<td>P1.DTACK</td>
</tr>
<tr>
<td>FC=6 A BOOT</td>
<td>EPROM</td>
<td>CS7</td>
</tr>
<tr>
<td>FC=3</td>
<td>MMU Access</td>
<td>CS7</td>
</tr>
<tr>
<td>FC=7 A=19</td>
<td>Breakpoint</td>
<td>Internal</td>
</tr>
<tr>
<td>FC=7 A=LOCAL</td>
<td>Autovector</td>
<td>Internal</td>
</tr>
<tr>
<td>FC=7 A=LOCAL</td>
<td>VME Interrupt</td>
<td>P1.DTACK</td>
</tr>
</tbody>
</table>

The handshaking is implemented with selector [74F151:U118] in conjunction with PAL [A101 = P16L8:U101] and PAL [A106 = P16L8:U106].
3.7.4. BERR

Bus error can occur under the following conditions:

- Invalid Page Entry
- Protection Error
- Parity Error Lower Byte
- Parity Error Upper Byte
- VME Bus Error
- Timeout

These error conditions, together with signal [Q.SPECIAL] are ORed in gate [74ALS30:U130] asserting [Q.ERROR]. Whenever [Q.ERROR] is active it disables all read-write strobes by disabling strobe decoder [74F138:U400] and I/O decoder [LS2521:U403].

If [Q.ERROR] occurs in a non-special 68010 cycle, three things happen. First, PAL [A103=16L8:U103] asserts [Q.BERR] after state [C.55], thereby aborting the current cycle. Second, the PAL generates [O.BERRCLK] which latches the error condition into the bus error register [ALS534:U511]. Third, the PAL clears the parity error flipflops [74F74:U42-] with signal [O.PARCLR] in case they were set.

3.7.5. Address Error Cycles

During address error cycles, the 68010 asserts address strobe but no data strobes. The effect of this is that a normal cycle is executed; however, since no data strobes are active no read or write strobes are asserted via decoder [74F138:U400]. The statistic bits in the MMU are updated on address error cycles.

3.7.6. 68010 Cycle to Memory

68010 cycles to memory execute normally without wait states by asserting DTACK at state 4. The only exception to this is write cycles to memory that are shadowed to the video memory (in video copy mode). In that case, signal [P2.WAIT] will delay subsequent write cycles until it is deasserted, indicating that the video memory is ready to accept additional write requests.

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>C:100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:DS- (READ)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:DS- (WRITE)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.7.7. 68010 Write Cycle to Video Memory, Best Case

68010 write cycles to video memory generate DTACK at state 5, causing 1 wait state. Cycles will be longer if a previous video memory cycle has not completed yet.

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. DS- (READ)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. DS- (WRITE)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

3.7.8. 68010 Cycle to I/O

68010 Cycles to I/O generate DTACK at state 9, causing 2 wait states. Cycles to the data ciphering processor use special timing described in the data ciphering chip section.

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RD/WR. I0-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P. DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.8. DVMA Logic

Reference: Schematics Page 2, Motorola 68010 Data Sheet.

3.8.1. Overview

The DVMA Controller takes requests from DVMA devices, obtains the processor bus from the 68010, and performs a read/write cycle for the device, generating appropriate function codes and strobes.

The DVMA Devices in their order of priority are:

- Refresh
- Ethernet
- VME-bus

Figure 3-1 shows how the DVMA Controller and Strobe Generator interface to the 68010.

![Diagram of DVMA Logic](image-url)

**Figure 3-1: DVMA Controller**
3.8.2. DVMA Cycles

DVMA requests are posted in the request flipflops [74F74:U207-0, U207-1, U203-1] with the rising edge of the signals [R.REF, E.AS, X.DMA], respectively. The request flipflops are reset by signals [R.DMAEN, E.CLR, X.DMAEN] respectively.

Posted DVMA requests are synchronized with register [74F374:U213] before entering the DVMA controller PAL [P16R8:U214]. The DVMA controller PAL prioritizes the incoming requests, issues a bus request to the 68010 [S.BR], then waits for the 68010 to release the processor bus by watching 68010 bus grant [P.BG] and the end of 68010 address strobe [P.AS], before asserting the DVMA enable corresponding to the request.

In addition, the DVMA controller PAL generates a DMA-cycle signal [S.DMA] that enables the tri-state buffers in the DVMA strobe PAL [P16L8:U215] to drive the function codes [P.FCO..2], address strobe [P.AS], and data strobes [P.UDS, P.LDS] and Ethernet read/write strobes [E.WE, E.OE]. Function Codes, data strobes, and device codes are asserted as follows:

<table>
<thead>
<tr>
<th>DVMA</th>
<th>DMA</th>
<th>LDS</th>
<th>UDS</th>
<th>FC</th>
<th>Space</th>
</tr>
</thead>
<tbody>
<tr>
<td>REFRESH</td>
<td>3</td>
<td>0</td>
<td>0</td>
<td>7</td>
<td>CPU Space</td>
</tr>
<tr>
<td>ETHERNET</td>
<td>2</td>
<td>1</td>
<td>5</td>
<td></td>
<td>System Data</td>
</tr>
<tr>
<td>EXTERNAL</td>
<td>1</td>
<td>X.LDS</td>
<td>X.UDS</td>
<td>5</td>
<td>System Data</td>
</tr>
</tbody>
</table>

Address strobe [P.AS] is asserted one state after [S.DMA], being enabled by signal [S.ASON] that is one clock cycle delayed from [S.DMA]. Address strobe is terminated with [S.ASOFF] from the DVMA controller PAL. [S.ASOFF] is asserted on refresh cycles when [S.ASIN] is received, and for all other cases when signal [O.S7] was received, indicating normal completion, or signal [S.ERR] indicating timeout. Since [O.S7] is derived from the bus handshake signal [P.DTACK] the DVMA controller is able to perform transfers to asynchronous bus devices.
### 3.8.3. DVMA Arbitration Cycle

Arbitration occurs concurrently with ongoing bus activity. The 68010, after receiving a bus request [P.BR.] issues a bus grant [P.BG.]. When the DVMA controller sees bus grant and address strobe [P.AS] deasserted, it acquires the bus and asserts the DMA Enable.

<table>
<thead>
<tr>
<th>DVMA-State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X.DMAREQ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.DMAREQ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.BR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.BG</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.BGIN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.ASIN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X.DMAEN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 3.8.4. DVMA Cycle, Synchronous Memory

<table>
<thead>
<tr>
<th>S-State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X.DMAEN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.ASIN</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q.DS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q.S</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>68010_O</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>68010_AS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.8.5. DVMA Cycle, Memory Refresh

Memory refresh requests are generated every 12.8 microseconds by a low-to-high transition of output [C.12800] of synchronous counter [74LS590:U211]. This transition sets signal [R.DMAREQ] in flipflop [74F74:U207-0], which in turn is synchronized in register [74F374:U213] and causes a refresh cycle in DVMA controller [P16R8:U214]. During the refresh cycle [R.DMAEN] is asserted which output enablers refresh counter [74LS590:U210] and with its trailing edge advances the refresh counter to its next state. The refresh counter drives address lines [P.A02..09] which constitute the row-address refresh addresses of the RAM chips. During refresh cycles, both banks of memory are enabled. This is done via PAL [P16L8:U106] asserting both [G.BANK0, G.BANK1] causing the RAS generation logic to assert both [P2.RAS0, P2.RAS1].

Refresh cycles are shorter than other DVMA cycles in that they only last for eight states. This is shown in the timing diagram below.

<table>
<thead>
<tr>
<th>S-State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>R.DMAEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S.ASIN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q.0S-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Q.57</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.BACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>68010_0-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>68010_AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.9. I/O-Bus

Reference: Schematics Page 1

The I/O data bus [I0.000..15] connects to the following devices:

- all input/output devices,
- all MMU devices, and
- the VME data port.

The I/O data bus is connected to processor data bus [P.000..15] via bidirectional transceivers [1008:u110, u111]. These bus buffers are enabled via PAL [P1664:u102] as follows. The I/O bus is driven from the processor data bus on all processor write cycles and all DVMA read cycles. The processor data bus is driven from the I/O-bus on all DVMA write cycles and all processor read cycles from I/O devices, MMU devices, and VME Bus.
3.10. MMU and MMU Space Devices

Reference: Schematics Page 3

3.10.1. Overview

The MMU consists of user context register [LS2518:U300], system context register [LS2518:U301], user/system context multiplexor [74F158:U302], segment map RAM [2168:U303, U304], and page map RAM [2168:U305 through U310].

Other MMU space devices are the bus error register [ALS334:U511], the system enable register [ALS554:U511] with feedback [ALS244:U512], the diagnostic register [ALS327:U514] with LEDs [LED4:J515, J516], and the ID PROM [P5X8:U510].

3.10.2. Decoding

The MMU and MMU space devices are accessed via decoders [ALS138:U322, U323, U324]. Decoder [ALS138:U324] is the read decoder, decoder [ALS138:U323] is the upper byte write decoder, and decoder [ALS138:U322] is the lower byte write decoder. All MMU space devices are connected to the lower byte.

3.10.3. MMU Operation

During a normal address translation cycle, the processor system function code [P.FC2] selects between the user [P.FC2 = 0] and supervisor [P.FC2 = 1] context. The selected context value, together with address lines [P.A16..23] index the segment map RAM which produces a page-map-entry-group [IA16..23]. The page-map-entry-group, in conjunction with address lines [P.A11..15] index the page map RAM, producing as its output the valid bit [VALID], protection codes [PROTO..5], type field [TYPE0..1], accessed bit [ACC], modified bit [MOD], and mapped address lines [MA11..22].

The protection field is checked with decoder [74F151:U315]. If the protection bit corresponding to the state of the read/write line [O.R/W] on the processor function codes [P.FC1, P.FC2] is not set, then output [PROTERR] will be asserted.

The accessed and modified bits are updated on all non-special cycles. For this operation, the current value of the type field, which is in the same nibble as the accessed and modified bit, is latched into register [ALS374:U316] with clock [C.SS].

The actual update starts with [C.SS] and ends with [C.S7]. During this time, PAL [P16L8:U103] asserts both [WR.UPDATE], which turns on write enable to RAM [2168:U307], and [WR.STAT] which output enables register [ALS374:U316] with the new data to be written into RAM [2168:U307].
3.11. I/O Devices

Reference: Schematics Page 4, 5, 6, 7

3.11.1. Overview

Input/Output devices comprise the PROMs, the Ethernet Control Register, the Keyboard/Mouse UART, the Serial Communication Controller, and the Timer chip. All input/output devices connect to the IO-Bus.

3.11.2. Decoding

Input/output devices are selected with a MMU type field of 1 [TYPE1 = 0], [TYPE0 = 1], and address lines [MA16..22] all ones. This condition is decoded with comparator [LS2521:U403] in conjunction with gate [74F32:U433-3] producing signal [CE.IO].

[CE.IO] disables the P1/P2-Bus decoder [74F138:U400] and in conjunction with [Q.R-/W] enables I/O read decoder [ALS138:U401] and in conjunction with [Q.R/W] I/O write decoder [ALS138:U402]. Both the I/O read and write decoder decode mapped address lines [MA11..13] to select one of eight possible devices.

3.11.3. PROMs

Since the PROMs are larger than a single 2K page, they are addressed directly with the low-order bits of the non-translated (virtual) address from the CPU, [P.A01..A14]. The PROMs are constantly chip enabled with CE tied to ground. The PROMs are output-enabled with signal [OE.PROM] generated in PAL [P16L8:U101] during boot cycles [BOOT = 1, FC = 6] and during read-PROM cycles [RD.PROM = 1].

3.11.4. Timer

Timer chip [AM9513:U504] provides five 16-bit timers. The timer is driven by a 4.9152 MHz input clock [C.204], generated from the 19.6608 MHz clock oscillator [K1114A:U200] via binary counter [74LS393:U212], independent of the CPU clock.

Gate input 1 of the timer chip is wired to the timer [FOUT] signal. Output [OUT1] is connected to interrupt request 7 [IRQ7], and outputs [OUT2..5] drive interrupt request 5 [IRQ5] via open-collector inverters [74LS05:U505].

3.11.5. Keyboard/Mouse

The serial keyboard/mouse UART [8530:U600] are implemented with a SCC (serial communication controller). The SCC features two high-speed, highly programmable serial channels with built-in baud-rate generators. The clock input to the SCC is a 4.9152 MHz input clock [C.204], independent of the CPU clock.

The serial lines to and from the keyboard/mouse are driven and received via inverters [74LS04:U608, U610].
3.11.6. Serial Communication Controller

The RS-423 UARTS [8530:U601] are implemented with the same type SCC as the keyboard/mouse interface.

Serial port A occupies channel A of the UART, in conjunction with inverter [74LS04:U608], driver [26LS20:U609], and receiver [26LS32:U606].

Serial port B occupies channel B of the UART, in conjunction with inverter [74LS04:U610], driver [26LS29:U611], and receiver [26LS32:U607].

Receiver [26LS32:U615] is shared between channel A and B for synchronous UART applications. Purpose of resistors [R4.91P:560] is to provide RS-232 compatible fail-safe line termination.

3.11.7. Ethernet Control Register

3.11.8. Data Ciphering Processor

Reference: Schematics Page 5

The Data Ciphering Processor [9518:US056] has special timing requirements implemented by PAL [P16E8:US057]. One requirement of the DCP is that its data strobe [MDS] may only be deasserted 20-70 nsec after trailing edge of its clock [C.400]. Other requirements of the DCP are long hold times on data and read/write; those are achieved by turning off the DCP data strobe early before the end of the cycle. The state diagrams below illustrate these timings.

3.11.9. 68010 Address Load to DCP

3.11.10. 68010 Read/Write to DCP, Best Case
3.12. P2-Bus Interface

Reference: Schematics Page 4, 10, 11.

3.12.1. Introduction

The P2-Bus is the internal bus which interconnects the CPU to main memory, the video memory, and expansion memory. Going off-board, the P2-Bus is brought out on connector [P96:P1102], pins 1 through 32 and 65 through 96.

3.12.2. P2 Signals

The P2-Bus consists of a number of address lines, bidirectional data lines, parity lines, timing signals, enable signals, and a handshake line.

Address Lines, Data Lines, Read/Write Line, and Handshake Line:

<table>
<thead>
<tr>
<th>P2 Signal</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>P2.A00.Z3</td>
<td>Address Lines (24)</td>
</tr>
<tr>
<td>P2.D00.15</td>
<td>Data Lines (16)</td>
</tr>
<tr>
<td>P2.DIL. DIU</td>
<td>Parity from CPU to Memory (2)</td>
</tr>
<tr>
<td>P2.DOL. DOU</td>
<td>Parity from Memory to CPU (2)</td>
</tr>
<tr>
<td>P2.R/W</td>
<td>Read/Write Strobe</td>
</tr>
<tr>
<td>P2.WAIT</td>
<td>Negative Handshake</td>
</tr>
</tbody>
</table>

Control Signals:

<table>
<thead>
<tr>
<th>P2 Signal</th>
<th>Description</th>
<th>Asserted on</th>
</tr>
</thead>
<tbody>
<tr>
<td>P2.RAS</td>
<td>Row-Address-Strobe</td>
<td>C.S3</td>
</tr>
<tr>
<td>P2.RAS0</td>
<td>Row-Address-Strobe 0</td>
<td>C.S3 ^ P.A01 v C.S3 ^ REFRESH</td>
</tr>
<tr>
<td>P2.RAS1</td>
<td>Row-Address-Strobe 1</td>
<td>C.S3 ^ P.A01 v C.S3 ^ REFRESH</td>
</tr>
<tr>
<td>P2.CAS</td>
<td>Column-Address-Strobe</td>
<td>C.S4 ^ -Q.SPEC</td>
</tr>
<tr>
<td>P2.RD</td>
<td>P2-Bus Read Strobe</td>
<td>C.S5 ^ -ERROR ^ -CE.IO ^ -TYPE1</td>
</tr>
<tr>
<td>P2.WEU</td>
<td>P2-Bus Write Strobe</td>
<td>C.S5 ^ -ERROR ^ -CE.IO ^ -TYPE1</td>
</tr>
<tr>
<td>P2.WEL</td>
<td>P2-Bus Write Strobe</td>
<td>C.S5 ^ -ERROR ^ -CE.IO ^ -TYPE1</td>
</tr>
</tbody>
</table>

The memory control signals [Q.RAS, Q.RAS0, Q.RAS1, Q.CAS, Q.WEL and Q.WEU] are generated centrally on the CPU side of the P2-Bus.

RAS is generated by and-or gates [74F64:U218] in conjunction with inverter [74F04:U922]. [Q.RAS] is asserted when processor address strobe is active (P.AS = 1) and the clock is low (C.100 = 0). This is the case at the beginning of processor state 3. After RAS is first asserted, it is latched via inverter [74F04:U922] until the later of [C.S7] or [P.AS] being deasserted. [Q.RAS0, Q.RAS1] have the same timing as [Q.RAS] except they are only asserted if [Q.BANK0, Q.BANK1] are asserted, respectively.

CAS is generated by flipflop [74F74:U204-1]. It is asserted at time [C.S4] on non-special cycles [Q.SPECIAL = 0]. [CAS] is inhibited during special cycles because the column address is not guaranteed to be stable during memory management updates and thus would cause invalid decoding in memory.

The upper and lower write enable to memory, [P2.WEU, P2.WEL] are generated in decoder [74F130:U400] in conjunction with gates [74F32:U433-1, U433-2]. The write strobes are asserted with [C.S5] and data strobe [Q.DS] active, with no error condition [Q.ERROR] present. They are turned off.
with the processor upper and lower data strobe, [P.UDS, P.LDS].

Accesses to the P2-Bus are decoded in decoder [F138:U400]. A read or write reference to the P2-Bus [RD.P2, WR.P2] is generated when: the page type is 0 or 1 [TYPE1 = 0], data strobe is asserted [D.S = 1], no bus error condition exists [Q.ERROR = 0], clock state 5 is asserted [C.S5 = 1], and the reference is not to an I/O Device [CE.IO = 0].

3.12.3. P2-Bus Cycle

The timing of a P2-Bus cycle is illustrated in the figure below for a standard memory write cycle followed by a memory read cycle.

During read-modify-write cycles, processor address strobe and thus [Q.RAS] and [Q.CAS] stay asserted for the entire length of the cycle.

Note that both [P2.RAS] and [P2.CAS] are asserted before the page map type field is decoded and before the protection field is evaluated. Thus [P2.CAS] indicates a valid address, but not necessarily a valid reference. Only the read/write strobes qualify a reference.

The timing shown above applies to main memory read cycles and main memory write cycles that do not have the negative handshake [P2.WAIT] asserted. Accesses to video memory are similar to main memory read cycles, except that signal [P2.WAIT] is active. [P2.WAIT] is asserted by the video memory interface when it needs to delay the completion of the current cycle. On read cycles to video memory, [P2.WAIT] is asserted to delay the current cycle until valid read data is available. On write cycles to the video memory, [P2.WAIT] is asserted whenever the video memory is completing a buffered operation and is thus not yet ready to accept a new cycle. The same mechanism is used for write operations to main memory shadowed by video memory (video copy mode).
3.12.4. Parity Error Logic

Reference: Schematics Page 4

The Parity Error Logic generates parity for memory write operations and checks parity for memory read operations. Note that the parity error logic is only used for memory accesses (page type 0). It is not used for any other cycles, such as video memory cycles (page type 1).

On writes, parity is generated with parity generators [74F280:U420, U421]. When signal [EN.PARGEN] is asserted, odd parity is generated and stored in memory. Odd parity means that the sum of all data bits and the parity bit is odd.

On reads, parity is checked with parity checkers [74F280:U422, U423]. If the even output of the parity checkers is true, then a parity error has occurred. This parity error information is clocked into the parity flipflops [74F74:U424-0, U424-1] on memory read cycles [TYPE0=0, RD.P2 = 1] with the leading edge of [C.S7], delayed by two inverter delays [74F04:U404-3, U404-4].

The parity error flipflops are self-latching. This means that they remain set until they are cleared by signal [O.PARCLR]. The parity error flipflops remain cleared if parity checking is disabled [EN.PARERR = 0].

The outputs of the parity error flipflops [PARERRL, PARERRU] are ORed with the other bus error conditions in gate [74LS30:U130]. This generates signal [O.ERROR] which in turn generates bus error [O.BERR] to the 68010 via PAL [P16L8:U103].

Parity errors are different from other bus errors in that they cannot abort the 68010 cycle in which they occur. This is because they are only detected at the end of a read cycle, after a point at which the 68010 can abort the current cycle. The parity error flipflops provide the function of latching parity errors until they are recognized by the CPU.

In order to recognize the bus error caused by a pending parity error, the 68010 must execute a "non-special" cycle [O.SPECIAL = 0]. Under this condition, PAL [P16L8:U103] generates signal [O.BERRCLK] which clocks the parity error flipflop state into the bus error register [ALS534:U511] and signal [O.PARCLR] which clears the parity error flipflops.

Parity generation and checking can be disabled for testing purposes. To initialize parity in main memory, all of memory needs to be written with parity generation enabled. When signal [EN.PARGEN] is not asserted, then even parity is generated. This allows the parity error function to be tested.
3.13. Ethernet Interface


3.13.1. Overview

The Ethernet Interface is built around the Intel 82586 VLSI Ethernet Controller (U700) and the Fujitsu MB502 Phase Lock Loop Decoder (U701), as shown in Figure 3-2. The Ethernet Control Register (ALS273:U716, ALS244:U717) controls the overall operation of the Ethernet interface.

![Diagram of Ethernet Interface](image)

**Figure 3-2: Ethernet Interface**

3.13.2. Ethernet Data Link Controller

The Intel 82586 Ethernet Data Link Controller is configured as follows: Maximum Mode (MN/MX = 0), asynchronous ready (READY = 0), directly enabled (HLDA = HOLD), and always clear to send (CTS = 0). The 82586 receives an 8 MHz clock from flipflop (74F74:U713). Pullup (R9-SIP:S700) supports the VOH-level required by the 82586. For a complete description of this part, refer to the Intel 82586 Data Sheet.
3.13.3. Ethernet DVMA Cycle

When the Ethernet controller wants to access main memory, it asserts [E.RD] or write control [E.WR]. Ethernet read and write controls [74LS00:U715-3] to generate Ethernet data strobe [E.DS]. The leading [E.DS] then sets the Ethernet DVMA request flipflop [74F74:U207-1], request [E.HOLD], ANDed with Ethernet error inactive [E.ERR-] in gate [E.REC] to the DVMA Arbiter latch [74F374:U213]. This will cause the bus from the CPU until the 82586 drops [E.HOLD].

Ethernet Data Strobe is also clocked via [74F74:U713-0] at the next Ethernet clock [E.C.125] to generate Ethernet address strobe [E.AS] address strobe latches the 24-bit Ethernet address into the Ethernet a, u703, u704) to generate Processor Address (P.A01 THROUGH P.A23) when enable [E.DMAEN]. In addition, Ethernet write control [E.WR] is latched generate Processor Read/Write strobe (P.R/W-) when enabled.

At this point, the Ethernet has requested a DVMA cycle and is waiting a write cycle (Ethernet to Memory), the DVMA controller will enable the [ALS244:U707. U708] with Ethernet output enable [E.OE]. On a read cycle, DVMA controller will latch the data read from memory into the [ALS373:U705, U706] at the trailing edge of Ethernet write enable [E.WE] are output enabled by Ethernet read-1 [E.RD1] to the Ethernet controller in the diagram below.

The Ethernet read and write buffers are byte swapped between the Ethernet data bus. This means that the processor data bits 0..7 are con 8..15 and vice versa.

If a bus error is encountered during an Ethernet DVMA cycle, the Ethernet [ALS74:U719-1] causing the Ethernet Error signal to be asserted [E.ERR], Ethernet DVMA requests to be set in the Ethernet DVMA request flipflop [7 bus error flipflop can only be reset by an Ethernet reset command [E.RESE]

<table>
<thead>
<tr>
<th>82586 State</th>
<th>T0</th>
<th>T1</th>
<th>T2</th>
<th>T3</th>
<th>T4</th>
</tr>
</thead>
<tbody>
<tr>
<td>E.C.125</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
</tr>
<tr>
<td>E.RD-</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
</tr>
<tr>
<td>E.RDO-</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
</tr>
<tr>
<td>E.RD1-</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
</tr>
</tbody>
</table>
3.13.4. Ethernet Phase Lock Loop Decoder - U701

The Fujitsu Ethernet Encoder/Decoder [MB502:U701] connects the board directly to an external Ethernet transceiver. The MB502 uses a digital phase lock loop with 10 samples per bit cell. An internal oscillator with external crystal X700 together with tank circuit [C:C700, C703, C704, L:L700] supplies the 100 MHz input frequency to the PLL chip. Jumper [J.2:J704] selects between Ethernet Level 1 and Level 2 interface characteristics (Level 2 if jumpered).

The Ethernet frontend is interfaced to the Ethernet data link controller with inverters [74F04:U709] and flipflops [74F74:U710, U712]. Pullup [R9.SIP:S700] raises the signal levels to those required by the EDLC.

3.13.5. Ethernet Transceiver Interface - J700

The Ethernet Connector [J700] follows the standard Ethernet definition. Jumper [J.2:J702] supplies +5V to the Ethernet connector for transceivers that require this voltage. The Ethernet transceiver drop cable is terminated with resistor networks [R4.SIP:R704, R705].
3.14. VME Bus Interface

Reference: Schematics Page 8, 9, 10, VME Bus Manual.

The VME Bus interface consists of the following functions:

- VME Bus Utility Functions
- VME Arbiter
- VME Master Interface
- VME Slave Interface
- VME Interrupt Handler

Figure 3-3 shows how these functions are interconnected.

Figure 3-3: VME Interface
3.14.1. VME Bus Utility Functions

The VME Bus Utility functions are implemented by these four utility lines: System Clock [P1.SYSCLK], AC Fail [P1.ACFAIL], System Reset [P1.SYSR], and System Fail [P1.SYSF].

System Clock is driven from the 16 MHz oscillator signal [C.62A] via a high-current driver [74F244:U817]. System Clock has no phase relationship with any other VME signals. It can be disconnected from the VME Bus by removing jumper [J.16:U900-15.16].

AC Fail is driven to the VME Bus by open collector driver [74ALS641:U918]. It is asserted while Power-On-Reset is active. It cannot be disconnected from the VME Bus.

System Reset is driven to the VME Bus by open collector driver [74ALS6411:U818]. It is asserted whenever Processor-Reset is active. It cannot be disconnected from the VME Bus.

The 2050 Board can be configured either as a P1-Bus Reset Master or Slave.

As a P1-Bus Reset Master, the 2050 Board issues Reset [B.RESET] to the VME Bus. Power-On-Reset, Watchdog Reset, and 68010 Reset will all assert P1-Bus Reset. Other P1-Bus devices may also assert P1-Bus Reset, but this will have no effect on the on-board CPU and devices.

As a P1-Bus Reset Slave, the 2050 Board receives Reset [B.RESET] from the VME Bus, but does not drive Reset to the VME Bus. The VME Bus Reset has the same effect as an on-board power-on-reset.

System Fail is not used or generated by the 2050 Board.

3.14.2. VME Arbiter and Requestor

The VME Arbiter and Requestor functions are implemented in one state machine [74F374:U812, U813, P9X4:U911, P16L8:U814]. Out of the options possible within the VME Bus Spec, the arbiter implements the ONE ROR arbitrator option. ONE means that the arbiter monitors bus request level 3 [P1.BR3] only and accomplishes arbitration via the level 3 daisy chain [P1.BG3IN, P1.BG3OUT]. ROR or release on request means that the arbiter only releases the bus when a request from another master is pending.

When the CPU wants to access the VME Bus, either for a standard read/write cycle or for an interrupt acknowledge cycle, it asserts signal Bus Select [B.BSEL] via PAL [P16L8:U810].

If the arbiter currently does not own VME Bus mastership, it requests bus mastership by asserting VME Bus request [P1.BREQ] and going through the normal VME Bus arbitration sequence. If the arbiter already owns bus mastership, it will keep the bus mastership until another VME Bus master requests it.

3.14.3. VME Master Interface

Once the 2050 Board obtains VME Bus mastership, the VME Master Interface allows the 2050 Board to access VME Slaves on the VME Bus. The interface consists of address and address modifier latches [ALS374:U940, U941, U942, U943] and drivers [ALS244:U900, U901, U902, U903]; write data latches [ALS374:U910, U911] and drivers [ALS244:U908, U909]; read data buffers [ALS244:U908, U909]; and control signal driver [74F244:U817-0]. The VME Slave Device being addressed will respond to the transfer by asserting either data transfer acknowledge [P1.DTACK] or bus error [P1.BERR]. These two signals pass through flow-through latch [74F373:U815] and are qualified in PAL [P16L8:U816] before reaching the 68010 CPU.
The VME Master interface supports complete backoff/rerun capability. This capability is utilized for VME accesses that take longer than 2 usec. In case of a VME access that is not completed within 2 usec, the state of the VME interface is frozen and a CPU rerun cycle is performed. During the rerun cycle, the CPU can give the on-board bus to the Ethernet interface or to the refresh logic to allow these devices to perform their functions. After these devices complete their activities, the rerun is terminated and the CPU continues with its VME access. This operation is transparent to the VME Bus. Notice that rerun cycles are also executed while the board is waiting for VME Bus mastership.

The VME rerun operation in detail proceeds as follows. Starting with [C.S4] of a cycle, counter [74LS393:U212] starts counting with the falling edges of [C.400]. After eight input transitions the counter asserts [B.C2]. This signal is inverted via [74F04:U221-1] and reclocked in register [74F274:U206], thereby generating x(B.C3). Signal [B.C3] closes the [BERR, DTACK] flow-through latch [74F273:U815]. If a [BERR, DTACK] arrives before the latch closes the CPU will complete the cycle as normal and the rerun sequence is aborted at that point.

If the CPU has not received a [BERR, DTACK] at this point the rerun sequence continues. After two additional transitions of clock [C.400], counter [74LS393:U212] asserts both [B.C2] and [B.C1]. This event is decoded in PAL [P16L8:U14] asserting output [B.T03]. [B.T03] enters PAL [P16L8:U10] which in turn generates [B.FREEZE] and initiates the actual rerun cycle to the CPU with signal [B.RE]. [B.FREEZE] causes the VME control signals, write data, and addresses to be latched until the CPU resumes the cycle after completion of the rerun.

The timeout counter [74LS393:U809] counts the number of bus reruns. Each assertion of [B.C2] increments the counter by one. When the counter reaches 128 it asserts timeout.

### 3.14.4. 68010 Cycle to VME Bus, Currently Busmaster

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.DS- (READ)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.DS- (WRITE)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.BSEL-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.AEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.CEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P1.AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P1.DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.14.5. 68010 Cycle to VME Bus, Not Currently Busmaster

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.IOO</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P.DS- (READ)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>F.DS- (WRITE)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>E.BSEL-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.REQ-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.AEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.BEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B.CEN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P1.AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P1.DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

3.14.6. VME Slave Interface

The VME Slave Interface allows the 2050 Board to be accessed by other VME Masters on the VME Bus. It uses the address comparator [LS2521:U930] to match the four high-order address lines from the bus [P1.A20..A23] against the base address bits [X.A0..A3] selected by switches [J.16:J900]. In addition, the VME address modifiers 4 and 5 must be set. [P1.AM4 = 1, P1.AM5 = 1], the VME interrupt acknowledge must be not set [P1.IACK = 0], and the 2050 Board must not be bus master [B.AEN = 0]. If all these conditions are met and VME address strobe [X.AS] and a VME data strobe [X.UDS OR X.LDS] is asserted then signal [X.DMA] is asserted, indicating that a VME Slave Interface request is pending.

The rising edge of [X.DMA] sets the external DMA request flipflop [74F74:U203-1] posing an external DMA request [X.DMAREQ] to the DVMA controller. In response, the DVMA controller requests the on-board bus from the CPU and executes an on-board cycle using the external DVMA address stored in register [ALS374:U904, U905, U906]. On a write cycle, the DVMA controller uses the data buffer [ALS244:U909] to enable data from the VME bus. On a read cycle, the data read from memory is stored in register [ALS374:U910, U911] before it is driven to the VME bus with data buffer [ALS244:U912, U913].

At the end of the VME DVMA cycle the handshaking flipflops [74F74:U931] are set with the trailing edge of [X.DMAEN]. If a bus error is present at this time, the bus error flipflop [74F74:U931-0] is set, asserting [X.BERR]. Otherwise, the DTACK flipflop [74F74:U931-1] is set, asserting [X.DTACK]. Both [X.DTACK] and [X.BERR] are driven to the VME bus with open-collector driver [ALS6411:U818]. Signal [X.DMA] stays asserted until the VME Master drops its data strobes. This in turn clears the Bus Error and DTACK flipflops [74F74:U931].
3.14.7. VME Interrupt Handler

The VME Interrupt Handler responds to Interrupts on the VME Bus. The 2050 Board does not generate any interrupts to the VME Bus. Jumper J800 can individually connect and disconnect all VME interrupt levels. Priority decoder [74LS148:U800] prioritizes the enabled VME interrupt requests and generates encoded interrupt lines [B.IPL0..2]. These encoded interrupt lines together with the onboard interrupt requests are combined in PROM [27S33A:U105] which in turn drives the 68010 interrupt lines [IPL0, IPL1, IPL2].

When the 68010 recognizes an interrupt request, it issues function code 7 and sends out the interrupt level being acknowledged on address lines [A01..A03]. The on-board/offboard interrupt selector [74F151:U802] decodes whether an external interrupt request is pending at the level the 68010 acknowledges. The output of this selector [B.IRO] is sampled at state 4 in the onboard/offboard interrupt flipflop [74F74:U205-0]. Output [O.AUTOV] is asserted if no onboard interrupt request was pending or if address bit [A19] is deasserted, indicating a non-interrupt cycle. Output [O.AUTOV] is deasserted if an onboard interrupt request is pending at the level being acknowledged and if address bit A19 is asserted, indicating a valid interrupt cycle.
3.14.8. 68010 Rerun Cycles

Rerun cycles are executed on two conditions: VME Bus deadlock and long VME accesses. These two rerun conditions are recognized in PAL [P16L8:U010] which generates [B.RERUN]. Signal [B.RERUN] is synchronized in flipflop [74F374:U206] before driving PAL [P16R4:U102] which in turn generates the required [O.BERR, P.HALT] signals to cause a CPU rerun.

3.14.9. Rerun, VME Deadlock Case

The condition here is that the CPU is attempting to access the VME Bus while another master on the VME Bus is attempting to access the 2950 Board as a slave device. Since the VME Bus has no rerun capability, the 68010 must yield to the VME Bus request to resolve the deadlock. The condition is present if [B.SEL] and [X.DMA] are simultaneously valid.

<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>C :00</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:AS-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:BR-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B:BROUT-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>B:RERUN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S:RERUN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S:BERR-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>S:HALT-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:BERR-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>P:HALT-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

3.14.10. Rerun, VME Rerun Case

The VME Rerun case is initiated for VME cycles that are not completed within the short timeout time, including VME accesses waiting for VME Bus mastership.
<table>
<thead>
<tr>
<th>68010 State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>....</th>
</tr>
</thead>
<tbody>
<tr>
<td>C.100</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>P.A5-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>P.DS- (READ)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>P.DS- (WRITE)</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>F.DTACK-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>E.T01-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>B.FREEZE-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>B.RERUN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>S.RERUN-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>P.BERR-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
<tr>
<td>P.HALT-</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>...</td>
</tr>
</tbody>
</table>
3.15. Memory

Reference: Base Board Schematics Page 11, 12, 13, 14, 15
Reference: Expansion Board Schematics Page 21, 22, 23, 24, 25

3.15.1. Introduction

The description of the memory applies in the same way to the memory contained on the 2050 Base Board as to the memory on the 2051 Expansion Board.

The memory design consists of the following functions:

- memory array (1/2/3/4M Bytes)
- address multiplexer and driver
- control signal driver
- bank decoder and driver
- data drivers

The interconnection of these pieces is shown in the Figure 3.4.
Figure 3-4: Memory Interface
3.15.2. Memory Interface

The CPU interfaces to the memory via the P2.Bus. This means that all interface signals are available on the P2-connector [996:P1102], allowing a memory expansion board to be interfaced to the same bus. The following description applies equally to the memory on the CPU Board as well as to the expansion memory.

3.15.3. Memory Organization

Memory is organized as 8 banks of 18 RAM chips each, making a total of 144 chips. Each bank stores 16 data bits and 2 parity bits.

RAM chips can be either 64K or 256K Bits. With 64K RAMs, each bank stores 128K Bytes plus parity, and all of memory stores one Megabyte.

With 256K RAMs, each bank stores 512K Bytes plus parity, making total memory capacity four Megabytes.

3.15.4. Memory RAM and Bank Decoding

Due to the pipelined RAS-CAS access, memory is CAS decoded because the translated address bits that select which bank of memory is accessed are only available in time for the CAS address strobe. For special cycles [0.SPECIAL = 1], such as MMU updates, CAS is not asserted.

Decoding for 64K and 256K RAM chips is as follows:

<table>
<thead>
<tr>
<th>Decoding</th>
<th>64K RAMs</th>
<th>256K RAMs</th>
</tr>
</thead>
<tbody>
<tr>
<td>RAS Bank</td>
<td>A01</td>
<td>A01</td>
</tr>
<tr>
<td>RAS Address</td>
<td>A02..A09</td>
<td>A02..A10</td>
</tr>
<tr>
<td>CAS Address</td>
<td>A10..A17</td>
<td>A11..A19</td>
</tr>
<tr>
<td>CAS Bank</td>
<td>A01,18,19</td>
<td>A01,A20,A21</td>
</tr>
</tbody>
</table>

3.15.5. Memory Section Decoding

To allow the memory to respond to arbitrary 1 megabyte sections within the 8 megabyte memory address space, memory select decoder [74F151:U1200] decodes the three high-order address bits [P2,A20..A22] and reads from the select jumper [J16:J1200] whether the addressed 1 megabyte section of memory is enabled or not. If enabled, the Memory Select signal [M.SEL] enables CAS decoder [74F138:U1201] and read/write buffers [ALS244:U1210..U1214] via decoder [ALS138:U1202].

The first megabyte of memory is always enabled. The second megabyte of memory is enabled with jumper [J1201:1-2] installed. The third and fourth megabyte are enabled as a pair if jumper [J1201:3-4] is installed.
3.15.6. Memory Drivers

The RAM signals are driven as follows:

[RAS, WEL, WEU], and the Address Lines are driven by 74F244 drivers with 33 Ohm series termination. Each bank of memory has its own set of drivers for these signals.

CAS is driven directly by the CAS decoder [74F138:U1201] with 33 Ohm series termination. Data to the RAMs is driven by [ALS244] drivers with 68 Ohm series resistors [R:R1200-R1217].
3.16. Video

Reference: Schematics Page 16, 17, 18, 19

3.16.1. Overview

The video subsystem consists of the following functions:

- video memory (128K Byte)
- video memory controller
- data multiplexor
- P2-Bus interface
- video sync controller
- video shifter

The interconnection of these pieces is shown in the Figure 3-5.

---

**Figure 3-5: Memory Interface**
3.16.2. Video Memory and Addressing

The 128 kilobyte video memory on the board, chips [4416:U1700-U1707, U1710-U1717], is dual ported for processor access and video refresh. The memory is organized as 16K Words of 64 bits each. Processor update cycles read 16 bits at a time or write 8 or 16 bits at a time. Video refresh cycles read 64-bits at a time.

The address for processor cycles is stored in register [ALS574:U1632] for the row-address and in register [ALS574:U1633] for the column address. Register [ALS373:U1634] demultiplexes the multiplexed memory addresses.

The address for video cycles comes from counters [74LS590:U1630, U1631] for row and column address, respectively. Notice that the organization of the 4416 RAM chips requires an 8-bit row address and a 6-bit column address. Address lines [V.A0] and [V.A7] are not used for column addressing.

The video refresh counters are incremented every 640 nsec with the rising edge of [V.OE1] except during states without display enable. They are reset to 0 with signal [V.RESET].

3.16.3. Video Memory Controller

The video memory controller state machine generates the timing for the video memory and other basic timing strobes for the video subsystem. It consists of PROMs [P5X8:U1604, U1605] and latches [74F374:U1606, U1607]. The state machine is clocked with [V.C.40].

The memory controller has a total of 16 states, enumerated 0 through 15, that are continuously executed in sequence. Each state has a duration of 40 nsec, making the 16 state cycle repeat every 640 nsec.

The memory controller can execute three basic types of cycles: Idle cycles, Processor update cycles, and Video refresh cycles. The memory controller executes an idle cycle or a processor update cycle between states 0 through 7 and a video refresh cycle between states 8 through 15.

Idle Cycles are executed between state 0 through 7 if no request is pending [V.SREQ = 0]. During an idle cycle, memory control signals are not asserted.

Processor Update Cycles: Processor Update Cycles are executed between states 0 and 7 if synchronous request is asserted [V.SREQ = 1] and if the register select bit is clear [V.BS19 = 0]. During a processor cycle, signals [V.PRA] and [V.PCA] enable the processor row and column address from the processor address latches [F374:U1634] and [F374:U1635], respectively, in time for [V.RAS] and [V.CAS], the row and column address strobe.

Read Cycle: A read cycle is executed if no external write strobes [V.LDS, V.UDS] are pending in the request latch [ALS374:U1615]. The memory word addressed by bank selects [V.BS1] and [V.BS2] is enabled via the RAS decoder PAL [P16R4:U1616]. The read data passes from the video RAM chips onto the internal data bus [V.B00..15] through buffers [74LS245:U1730..U1737] and is latched in the data output register [ALS374:U1602, U1603] at the rising edge of signal [V.ACK].

Write Cycle: A write cycle is executed if a external write strobes [V.LDS, V.UDS] is pending in the request latch [ALS374:U1615]. Write cycles are similar to read cycles except that the flow of data reverses. Write data is output enabled from the data input register [ALS374:U1600, U1601], passes through buffers [74LS245:U1730..U1737], and is then written into the RAM chips selected by active RAS strobe [V.RAS0..3] and write enable strobes [V.WU, V.WL]. The RAM Write Enable signal [V.WE] is asserted starting at state 3 for early write-cycle timing.
Video Refresh Cycle: Video refresh cycles are executed during every memory controller cycle between state 8 and 15. During a video refresh cycle, signals [V.VRA] and [V.VCA] enable the video row and column address contained in registers [74F374:U1640] and [74F374:U1641], respectively. These registers are loaded from counters [74LS590:U1660] and [74LS590:U1661]. Video memory data is read out 64-bits in parallel and is latched at the end of state 15 in the video data register [74LS374:U1720:U1727] with the trailing edge of [V.VCA]. In addition to executing the video refresh cycle, the current memory controller state is decoded in decoder [74F138:U1728] to enable consecutive bytes from the video data register onto video output bus [V.00-V.07] via control lines [V.OEO..V.OE7]. Starting with [V.OEO] in state 0, one byte from the video data register is enabled every two states. The data on the video output bus is then loaded into the video shifters [74F194:U1805].

A processor cycle is executed if the synchronous request [V.SREQ] is active (the generation of [V.SREQ] is described below under request logic). During a processor cycle, signals [V.PRA] and [V.PCA] enable the processor row and column address from the processor address latches [ALS374:U1632] and [ALS374:U1633], respectively, in time for [V.RAS] and [V.CAS], the row and column address strobe.
3.16.4. Video State Machine

<table>
<thead>
<tr>
<th>State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>V.OE</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.C-40</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.RAS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.CAS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.VRA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.VCA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.PRA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.PCA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.G</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.HCLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.ENREQ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>State</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
<th>15</th>
</tr>
</thead>
<tbody>
<tr>
<td>V.OE</td>
<td>0</td>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.C-40</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.RAS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.CAS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.VRA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.VCA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.PRA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.PCA</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.G</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.W</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.ACK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.HCLK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>V.ENREQ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
3.16.5. Video Interface to P2-Bus

3.16.6. P2-Bus Address Decoding

The video board responds to three types of accesses: direct reads, direct writes, and copy writes.

For direct reads and direct writes, the video logic is selected if the four most significant P2 address bits \([P2.A20..A23]\) are all ones. In that case, decoder [ALS138:U1621] produces signal \([V.BSEL]\), which generates a video request via PAL [P16L8:U1620].

Copy writes occur if the copy comparator [LS2521:U1623] matches P2 address bits \([P2.A17..P2.A22]\) with video base address bits \([V.BASE1..6]\) and if copy mode is set \([V.COPY = 1]\) in the control register. If all of these conditions are true then comparator [LS2521:U1623] generates \([V.CSEL]\) which generates a video request via PAL [P16L8:U1620].

PAL [P16L8:U1620] also decodes \([P2.A17]\) in direct mode \([V.BSEL = 1]\) to generate the read/write strobes for the video control register [ALS273:U1610, U1611].

3.16.7. P2-Bus Request Generation

The video board implements buffered write cycles and unbuffered reads. Reads follow the traditional conventions of memory systems. When the processor reads from the video board, the video board performs the desired access and returns the data read to the processor. Since the memory on the video board is dual-ported and asynchronous to the processor, the processor will have to wait until the read data is available. This is implemented by the video board asserting the \([P2.WAIT]\) signal until the read data is ready.

Write cycles, on the other hand, are buffered. The video board provides a set of registers that store all information related to a write cycle, effectively implementing a 1-deep FIFO. This means that on a write cycle the processor does not need to wait until the dual-ported video memory is available. Instead, the write cycle is automatically completed with the data stored in the registers. A second write, however, can only be initiated when the first write cycle has been completed. This is done by asserting the \([P2.WAIT]\) signal if a write cycle to the video board is attempted while a previous request is still in progress.

An interesting case occurs if a write cycle is immediately followed by a read cycle. In this case, the write cycle is still in progress while the new read cycle is pending. The design of the request logic assures that the read cycle is only begun after the write cycle has been completed.

This read/write cycle handshaking is implemented in PAL [P16L8:U1620]. A request is set when the video section is addressed in with a read or write cycle in direct mode \([V.BSEL]\) or with a write cycle in copy mode \([V.CSEL]\). Signal \([BUSY]\), causing \([P2.WAIT]\), is set while a request is in progress.

The leading edge of the request signal \([V.REQ]\) clocks the demultiplexed processor address into the processor address register [ALS534:U1632, U1633]. It also clocks the low-order address bits \([P2.A01, P2.A02]\) and the write enable bits \([P2.WEL, P2.WEU]\) into register [ALS374:U1615].

\([V.REQ]\) is sampled with signal \([V.ENREQ]\) into flipflop \([74F74:U1624-0]\). The sampled signal is reclocked on the next clock edge of \([V.C.40]\) into flipflop \([74F74:U1624-1]\) and becomes signal \([V.SREQ]\). This signal controls the memory state machine to perform either a CPU cycle \([V.SREQ = 1]\) or an idle cycle \([V.SREQ = 0]\).
3.16.8. P2-Bus Interface Timing

READ CYCLE

P2.RD- -------------------
V.RDACK------------------------
V.REQ- ------------------------
V.ACK- ------------------------
V.WAIT- ------------------------

WRITE CYCLE

P2.WR- -------------------
V.RDACK------------------------
V.REQ- ------------------------
V.ACK- ------------------------
V.WAIT- ------------------------

WRITE CYCLE FOLLOWED BY WRITE CYCLE

P2.WR- -------------------
V.RDACK------------------------
V.REQ- ------------------------
V.ACK- ------------------------
V.WAIT- ------------------------

WRITE CYCLE FOLLOWED BY READ CYCLE

P2.WR- -------------------
P2.RD- -------------------
V.RDACK------------------------
V.REQ- ------------------------
V.ACK- ------------------------
V.WAIT- ------------------------

3.16.9. Video Controller

The video controller generates the timing for the video monitor. The following description applies to the "standard Sun-2 video monitor". This video monitor has the following attributes:

- **Visible Display**: 1152 pixels by 900 lines
- **Video Clock**: 10 nsec, 100 MHz
- **Horizontal Cycle**: 16.00 usec, 62.5 kHz
- **Vertical Cycle**: 15000 usec, 66.66 Hz
- **Horizontal Retrace**: 4.46 usec
- **Vertical Retrace**: 60.0 usec

Video controller latch [74F374:U1812] latches the outputs of horizontal and vertical decoding PROM on the rising edge of [V.HCLK].

3.16.10. Horizontal State Machine

Horizontal counter [74LS393:U1810] is advanced every 640 nsec with the falling edge of clock [V.HCLK]. Horizontal counter is reset with [V.HCLR] generated by video controller latch.

Horizontal decode PROM [P9X4:U1811] decodes horizontal counter inputs [V.HS0] through [V.HS6], plus vertical blank [VBLANK] from the vertical state machine. Horizontal decode PROM outputs are [V.HCLR, V.HSYNC, AND V.DISPEN].

3.16.11. Horizontal State Machine Timing Diagram

```
Signal State
STATE+1 0 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2
        0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5
HCLK                                      ---------------
DISPEN                                    ---------------
HSYNC                                     ---------------
HRESET                                    ---------------
```

3.16.12. Vertical State Machine

Vertical counter [74LS393:U1813, U1814] is advanced on falling edge of horizontal sync [V.HSYNC]. Vertical counter is reset with [V.VCLR] from video controller latch.

Vertical decode PROM [P9X4:U1815] decodes vertical counter states [V.VSTATE1..7], the AND of [V.VSTATE8..9], and [V.VSTATE10]. Vertical decode PROM outputs are [V.VSYNC, V.CLR, V.VBLANK, AND V.RESET]. The vertical decode PROM function is defined in PROM A1815.
3.16.13. Vertical State Machine Timing Diagram

<table>
<thead>
<tr>
<th>Signal</th>
<th>State</th>
</tr>
</thead>
<tbody>
<tr>
<td>STATE+1</td>
<td>0 0 0 0 0 0 0 0 ... 5 5 5 5 5 5 5 5 ... 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9</td>
</tr>
<tr>
<td>VCLK</td>
<td>-----</td>
</tr>
<tr>
<td>VBLANK</td>
<td>________________</td>
</tr>
<tr>
<td>VSYNC</td>
<td>________________</td>
</tr>
<tr>
<td>VRESET</td>
<td>____________________________</td>
</tr>
</tbody>
</table>

3.16.14. Video Interrupt Logic

Interrupt flipflop (74F74:U1803-1) is set at the leading edge of [V.VBLANK] as long as interrupt enable [V.INTEN] is enabled.
3.16.15. Video Clock and Shifter

The 100 MHz video clock [V.C.10] that is generated by crystal oscillator [K114A:U1800] is buffered by gate [74F06:U1808-0] and is then divided into a 50 MHz clock by flipflop [74F112:U1801-0].

The video data [V.00..7] is loaded into two 50 MHz shift register, [74F194:U1805, U8106], one shifting the odd and one the even bits, respectively. A pair of odd and even bits [V.VIDEO, V.VIDEO] together with 10 nanosecond clock [V.C.10] and 20 nanosecond clock [V.C.20] is converted from TTL to ECL levels by converter [10H124:U1807] and drives the 100 MHz shift register [10H141]. Since both true and inverted data is loaded into the shifter, differential output levels [VIDEO+, VIDEO+] are available on its outputs. The differential outputs are terminated with 390 Ohm resistors [R1800, R1801] to [5V] and are intended to drive differential ECL terminated with an impedance of 100 Ohm.

The timing is illustrated in the figure below.

```
V.C.10  ^---------------------------------------
V.C.20  -----^---------------------------------------
V.C.40  ^---------------------------------------
V.STATED  ^---------------------------------------
V.DISPEN  ^---------------------------------------
V.LOAD  ^---------------------------------------
V.LDEN  ^---------------------------------------
V.LD  ^---------------------------------------
V.ELD  ^---------------------------------------
V.ECLK  ^---------------------------------------
```
paltype pal1618
palname A101
palid 1.24 84/07/31

PALBEGIN

% Inputs

1 INPUT P.FC0
2 INPUT P.FC1
3 INPUT P.FC2
4 INPUT BOOT-
5 INPUT Q.AUTOV-
6 INPUT RD.PROM-
7 INPUT Q.AS
8 INPUT C.S7
9 INPUT PIN9
11 INPUT B.DTACK

10 GND
20 VCC

% Outputs

19 OUTPUT Q.MMU-
18 OUTPUT C.S7AS
17 OUTPUT OE.PROM-
16 OUTPUT Q.SPECIAL-
16 OUTPUT Q.INTVEC-
14 OUTPUT Q.VPA-
13 OUTPUT FC7-
12 OUTPUT SPWAIT-

EQUATIONS

ASSERT Q.MMU- % Function code 3. MMU access.
ENABLE ALWAYS
OR / P.FC2 & P.FC1 & P.FC0 & Q.AS

ASSERT C.S7AS % Demorganize: C.S7 & AS
ENABLE ALWAYS
OR / C.S7
OR / Q.AS

ASSERT OE.PROM- % Boot and FC=6; Fetch inst from EPROM.
ENABLE ALWAYS
OR P.FC2 & P.FC1 & P.FC0 & BOOT & Q.AS
OR RD.PROM

ASSERT Q.SPECIAL- % Special Cycle. Inhibit CAS.
ENABLE ALWAYS
OR P.FC1 & P.FC0 % FC=7 or FC=3. INTA or MMU cycle.
OR P.FC2 & P.FC1 & P.FC0 & BOOT % BOOT cycle.

ASSERT Q.INTVEC- % VME interrupt acknowledge cycle.
ENABLE ALWAYS
OR P.FC2 & P.FC1 & P.FC0 & C.S7 & / Q.AUTOV & Q.AS

ASSERT Q.VPA-
% Local interrupt acknowledge cycle.
ENABLE ALWAYS
OR P.FC2 & P.FC1 & P.FC0 & C.S7 & Q.AUTOV & Q.AS

ASSERT SPWAIT-
% DTACK for SPECIAL cycles.
ENABLE ALWAYS
OR P.FC2 & P.FC1 & P.FC0 & / P.FC0 & / C.S7 % Boot cycles
OR P.FC2 & P.FC1 & P.FC0 & / Q.AUTOV & / B.DTACK % VME Vector
OR P.FC2 & P.FC1 & P.FC0 & Q.AUTOV % VPA cycles. No DTACK.

ASSERT FC7-
ENABLE ALWAYS
OR P.FC2 & P.FC1 & P.FC0

TIMING: NO-CLOCK
\%
Q.MMU- 1234567890
Q.AS ---------------
P.FC0 ---------------
P.FC1 ---------------
P.FC2 ---------------
C.S7 ---------------
C.S7AS ---------------
BOOT- ---------------
RD.PROM- ---------------
OE.PROM- ---------------
Q.SPECIAL- ---------------
Q.AUTOV- ---------------
Q.INTVEC- ---------------
Q.VPA- ---------------
SPWAIT- ---------------
B.DTACK ---------------
FC7- ---------------
PIN9 ---------------

PALEND
paltypa pal18r4
palname A102
palid 1.16 84/07/30

PALBEGIN

% Inputs
2 INPUT Q.SPECIAL-
3 INPUT CE.IO-
4 INPUT Q.R/W-
5 INPUT S.DMA-
6 INPUT POR1-
7 INPUT TC_20480-
8 INPUT S.RERUN-
9 INPUT TYPE1
1 CLOCK C-80-
10 GND
11 OUTPUT-ENABLE OE-
20 VCC

% Outputs
19 OUTPUT RD.IO-
18 OUTPUT WR.IO-
17 OUTPUT S.BERR-
16 OUTPUT S.HALT-
15 OUTPUT X.HALT-
14 OUTPUT INIT-
13 OUTPUT P.HALT-
12 OUTPUT P.RESET-

EQUATIONS

: WRITE Q.R/W ;
: READ Q.R/W ;

ASSERT RD.IO-
ENABLE ALWAYS
OR / S.DMA & Q.SPECIAL & READ
OR / S.DMA & CE.IO & READ
OR / S.DMA & TYPE1 & READ
OR S.DMA & WRITE

% Define WRITE
% Define READ

% Enable data buffers from IO.Dx->P.Dx

MMU read cycle
% I/O read cycle

% VME read cycle

% DVMA write cycle

ASSERT WR.IO-
ENABLE ALWAYS
OR / S.DMA & WRITE
OR S.DMA & / CE.IO & / TYPE1 & READ

% Enable data buffers from P.Dx->IO.Dx

MMU + I/O + VME write cycle
% DVMA read cycle from P2-bus

ASSERT S.BERR-
OR S.RERUN

% Clocked output. Synchronized bus error

ASSERT S.HALT-
OR S.RERUN

% Clocked output. Synchronized halt.
paltbep: pal1618
paltname A103
palid 1.15 84/07/31

PALBEGIN

% Inputs
1 INPUT Q.ERROR
2 INPUT Q.SPECIAL-
3 INPUT C.S5
4 INPUT Q.S7
5 INPUT Q.AS
6 INPUT WR.PMAPOL-
7 INPUT Q.R/W-
8 INPUT MOD
9 INPUT S.DMA-
11 INPUT S.BERR-
18 INPUT TIMEOUT-

10 GND
20 VCC

% Outputs
19 OUTPUT Q.BERRCLK
17 OUTPUT Q.BERR-
16 OUTPUT Q.PARCLR-
15 OUTPUT WR.STAT-
14 OUTPUT WR.UPDATE-
13 OUTPUT WR.PMAPOL-
12 OUTPUT MOD1

EQUATIONS

: WRITE Q.R/W ; % Confusing once ' ' gone

ASSERT Q.BERRCLK
ENABLE ALWAYS
OR / Q.BERR
OR S.DMA
OR S.BERR
OR / Q.AS

ASSERT Q.BERR-
ENABLE ALWAYS
OR Q.ERROR & C.S5 & / Q.S7 & Q.AS & / Q.SPECIAL % Set only btwn CS5-QS7
OR Q.BERR & Q.AS
OR Q.BERR & S.DMA & / Q.PARCLR % Hold while Q.AS
OR S.BERR & C.S5 & Q.AS % Clear parerr at end of cycle
OR TIMEOUT & C.S5 & Q.AS % Rerun cycle
OR / Q.BERR

ASSERT Q.PARCLR-
ENABLE ALWAYS
OR Q.BERR & S.DMA & / Q.AS

% Processor bus error
% Demorganize:
% Q.BERR & /S.DMA & /S.BERR & Q.AS
% Pulse at end of Q.BERR
ASSERT WR.UPDATE-
ENABLE ALWAYS
OR / Q.ERROR & C.S5 & / Q.S7 & / Q.SPECIAL
OR WR.PMAPOL & Q.SPECIAL & / Q.S7

ASSERT WR.STAT-
ENABLE ALWAYS
OR / Q.ERROR & C.S5 & / Q.S7 & / Q.SPECIAL
OR WR.UPDATE & / Q.SPECIAL

ASSERT WR.PMAPX-
ENABLE ALWAYS
OR WR.PMAPOL & Q.SPECIAL
OR WR.UPDATE & Q.SPECIAL

ASSERT MOD1
ENABLE ALWAYS
OR / MOD & WRITE

TIMING: NO-CLOCK
% Wr strobe for pmap nibble
% ...containing acc/mod bits
% Update for normal cycles
% Written by CPU

% OE stat bits to pmap entry
% Turn-on quickly
% Turn-off slowly

% OE ID bus to pmap entry
% Turn-on quickly
% Turn-off slowly

% Pmap page modified bit
% De-morganize: MOD or WRITE

PALEND
/* This information proprietary to Sun Microsystems Inc */

#include "/usr/local/pl/prom.c"
#define range(low,x,high) ((low<=x) && (x<=high))

/* Define inputs to 1K x 4 prom. */
#define cpu_int1 (a0)
#define cpu_int2 (a1)
#define cpu_int3 (a2)
#define cpu_int4 (a3)
#define cpu_int5 (a4)
#define cpu_int6 (a5)
#define cpu_int7 (a6)
#define vme_ip12 (a7)
#define vme_ip11 (a8)
#define vme_ip10 (a9)

/* Define vme interrupt levels */
#define vme_int1 (!vme_ip12 && !vme_ip11 && vme_ip10)
#define vme_int2 (!vme_ip12 && vme_ip11 && !vme_ip10)
#define vme_int3 (!vme_ip12 && vme_ip11 && vme_ip10)
#define vme_int4 ( vme_ip12 && !vme_ip11 && !vme_ip10)
#define vme_int5 ( vme_ip12 && vme_ip11 && !vme_ip10)
#define vme_int6 ( vme_ip12 && vme_ip11 && vme_ip10)
#define vme_int7 ( vme_ip12 && vme_ip11 && vme_ip10)

/* Perform priority encoding */
intlevel()
{ int level;
  level = 0;
  if (vme_int1 || cpu_int1) level = 1; /* Lowest priority */
  if (vme_int2 || cpu_int2) level = 2;
  if (vme_int3 || cpu_int3) level = 3;
  if (vme_int4 || cpu_int4) level = 4;
  if (vme_int5 || cpu_int5) level = 5;
  if (vme_int6 || cpu_int6) level = 6;
  if (vme_int7 || cpu_int7) level = 7; /* Highest priority */
  return(level);
}
/= Define Outputs /=
#define ipl2  (intlevel() & 0x04)  /* msb */
#define ipl1  (intlevel() & 0x02)  /* msb */
#define ipl0  (intlevel() & 0x01)  /* msb */

main()
{
  prom1024x4;

  prombegin
  prom(0.c0, ipl0)
  prom(0.c1, ipl1)
  prom(0.c2, ipl2)
  prom(0.c3,1)
  promend;

  writeprom("A105",0);
}
paltype pal1618
palsname A106
palid 1.10 84/07/31

PALBEGIN

% Inputs

1  INPUT  C.S5
2  INPUT  C.S7
3  INPUT  C.S9
4  INPUT  CE.IO-
5  INPUT  PIN5
6  INPUT  PIN6
7  INPUT  Q.R/W-
8  INPUT  P2.WAIT-
9  INPUT  P.AC1
10 INPUT  R.DMAEN-
10  GND
20 VCC

% Outputs

: OUTPUT PIN19
: OUTPUT PIN18
17 OUTPUT PIN17
16 OUTPUT PIN16
15 OUTPUT IOWAIT-
14 OUTPUT IOWAIT-
:3 OUTPUT Q.BANK0
:2 OUTPUT Q.BANK1

EQUATIONS

: WRITE Q.R/W ;

ASSERT IOWAIT-
ENABLE ALWAYS
OR WRITE & P2.WAIT

% At 10 MHz, 2 wait I/O, 1 wait frame buffer.
: IOWAIT_10MHz
   OR CE.IO & / C.S7
   OR / C.S5 ;

% At 12 MHz, 3 wait I/O, 2 wait frame buffer.
: IOWAIT_12MHz
   OR CE.IO & / C.S9
   OR / C.S7 ;

ASSERT IOWAIT-
ENABLE ALWAYS
IOWAIT_10MHz % Initial product at 10 mhz

ASSERT Q.BANK0 % Select first ram bank
ENABLE ALWAYS
OR P.A01 & / R.DMAEN

ASSERT Q.BANK0
ENABLE ALWAYS
OR / P.A01 & / R.DMAEN

TIMING: NO-CLOCK
% 1234567890123456789012345678901234567890
Q.R/W- ___________---------------------------
P2.WAIT- ___________---------------------------
TOWAIT- ________________________________
C.S5 ________________________________
C.S7 ________________________________
C.S9 ________________________________
CE.ID- ________________________________
IDWAIT- ________________________________
P.A01 ________________________________
R.DMAEN- ________________________________
Q.BANK0 ________________________________
Q.BANK1 ________________________________

PIN5

PIN6

PIN19

PIN18

PIN17

PIN16

PALEND
static char sccs_id = "1.8 64/06/02";

/* This information proprietary to Sun Microsystems Inc */

* Author: Model-50 Group
* Date: March 9, 1984
* Prod Name: A1604 and A1605
* Prod Type: 32 x 8.
* Speed: 35 nsec.
* Purpose: Video Memory State Machines
* Timing:
  * The video state machines perform an optional read or write access
    to the frame buffer memory followed by a video update read cycle.
  * The basic memory cycle consists of 16 states; the state machine
    is clocked every 40 nsec and, hence, repeats every 640 nsec.
* XREQ=0 (No CPU read/write access)

* State 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

* Clock

* VOE/ RAS/ RASO/ CAS/ G/ WE/ OEVR/ OEVCA/ OEP/ A/ HCLK

* ENREQ

* LOAD/ LDO/ LD1

* XREQ=1 (CPU read/write access)

* State 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15

* Clock

* VOE/ RAS/ CAS/ G/ WE/ OEVR/ OEVCA/ OEP/ A/ HCLK

* ENREQ

* LOAD/ LDO/ LD1

* XREQ=2 (CPU read/write access)
```c
#include "/usr/local/pl/prom.c"
#define range(lo,x,high) (((lo<=x)&&(x<=high))

/* Define inputs to 32 x 8 proms */

#define state0 (a0)  
#define state1 (a1)  
#define state2 (a2)  
#define state3 (a3)  
#define xreq (a4)    

/* Define outputs */

#define nstate nnstate()  
nstate()  
{ int state,xstate;  
Author:  
  state = (cvb(state0)*d0+cvb(state1)*d1+cvb(state2)*d2+cvb(state3)*d3);  
xstate = ((state + 1) % 16);  
return(xstate);  
}

#define ras ((xreq & range(2,nstate,6)) || range(10,nstate,14))  
define cas ((xreq & range(5,nstate,8)) ||  
              (range(13,nstate,15) || (nstate == 0)) )  
define g ((xreq & range(5,nstate,8)) || range(13,nstate,16))  
define we ((xreq & range(3,nstate,10)))

#define pra range( 0,nstate, 3)  
define pca range( 4,nstate, 7)  
define vra range( 8,nstate,11)  
define vca range(12,nstate,16)

#define ack (xreq & (nstate==9))  
define hclx range(0,nstate,1)  
define load ((nstate % 2) == 1)  
define enreq (nstate == 0)

main()  

prom32x6;

prombegin  
prom(0,d0,(nstate&d0))  
prom(0,d1,(nstate&d1))  
prom(0,d2,(nstate&d2))  
prom(0,d3,(nstate&d3))  
prom(0,d4,!pra)  
prom(0,d5,!pca)  
```

prom(0, d6, !vra)
prom(0, d7, !vca)

prom(1, d0, !ras)
prom(1, d1, !cas)
prom(1, d2, !g)
prom(1, d3, !we)
prom(1, d4, hclk)
prom(1, d5, load)
prom(1, d6, enreq)
prom(1, d7, ack)

promend;

writeprom(*A1604*, 0);
writeprom(*A1605*, 1);

}
Inputs
2 INPUT V.BS1
3 INPUT V.BS2
4 INPUT V.LDS-
5 INPUT V.UDS-
6 INPUT V.RAS-
7 INPUT V.WE-
8 INPUT V.RCD-
9 INPUT V.STATE3
12 INPUT V.DISPEN-

CLOCK CLK
GND
OUTPUT-ENABLE OE
VCC

Outputs
19 OUTPUT V.WU-
18 OUTPUT V.WL-
17 OUTPUT V.RAS0-
16 OUTPUT V.RAS1-
15 OUTPUT V.RAS2-
14 OUTPUT V.RAS3-
13 OUTPUT V.CEN-

EQUATIONS
: VIDEO_CYCLE V.STATE3 ; % Cycle is for video
: CPU_CYCLE / V.STATE3 ; % Cycle is for CPU

% Equations to generate all video RAM RAS strobes

ASSERT V.RAS0-
OR V.RAS & / V.BS2 & / V.BS1 & CPU_CYCLE % RAS bank 0
OR V.RAS & VIDEO_CYCLE % CPU cycle to this bank
OR V.RAS & VIDEO_CYCLE % Video cycle runs all banks-

ASSERT V.RAS1-
OR V.RAS & / V.BS2 & V.BS1 & CPU_CYCLE % RAS bank 1
OR V.RAS & VIDEO_CYCLE

ASSERT V.RAS2-
OR V.RAS & V.BS2 & / V.BS1 & CPU_CYCLE % RAS bank 2
OR V.RAS & VIDEO_CYCLE

ASSERT V.RAS3-
OR V.RAS & V.BS2 & V.BS1 & CPU_CYCLE % RAS bank 3
OR V.RAS & VIDEO_CYCLE
palttype pal1618
palname A1620
palid 1.11 84/08/01

PALBEGIN

% Inputs

1 INPUT V.BSEL-
2 INPUT V.CSEL-
3 INPUT P2.RD-
4 INPUT P2.WEU-
5 INPUT P2.WEL-
6 INPUT V.WL-
7 INPUT P2.A17
8 INPUT V.WU-
9 INPUT V.ACK
10 INPUT Q.AS

10 GND
20 VCC

% Outputs

19 OUTPUT V.RD-
18 OUTPUT V.RDC-
17 OUTPUT V.WLC
16 OUTPUT V.WUC
15 OUTPUT V.REQ-
14 OUTPUT V.RDACK-
13 OUTPUT V.WAIT-
12 OUTPUT VREQ

EQUATIONS

ASSERT V.RD-
ENABLE ALWAYS
OR V.BSEL & P2.RD & / P2.A17

ASSERT V.RDC-
ENABLE ALWAYS
OR V.BSEL & P2.RD & P2.A17

ASSERT V.WUC
ENABLE ALWAYS
OR / V.BSEL
OR / Q.AS
OR / P2.A17
OR / P2.WEU

ASSERT V.WLC
ENABLE ALWAYS
OR / V.BSEL
OR / Q.AS
OR / P2.A17

% NAME OK, we gen both V.REQ and V.REQ-
% Enable frame buffer read data to P2
% Enable control reg read data to P2
% Write upper byte control reg
% De-morganize: V.BSEL & AS & A17 & WEU
% Write lower byte control reg
% De-morganize: V.BSEL & AS & A17 & WEL
OR / P2.WEL

ASSERT V.REQ- % Frame buffer request
ENABLE ALWAYS
OR V.BSEL & Q.AS & / P2.A17 & P2.RD & / V.ACK & / V.RDACK
OR V.BSEL & Q.AS & / P2.A17 & P2.WEL & / V.ACK
OR V.CSEL & Q.AS & / P2.WEL & / V.ACK
OR V.REQ & / V.ACK % Hold till ack

ASSERT V.RDACK- % Used to hold deassertion of V.WAIT
ENABLE ALWAYS
OR V.ACK & / V.WL & / V.WU % Set at end of read req
OR P2.RD & V.RDACK % Hold till RD gone

ASSERT V.WAIT- % Inhibit DTACK
ENABLE ALWAYS
OR V.BSEL & P2.RD & / P2.A17 & / V.RDACK % Set on RD
OR V.WAIT & P2.RD & / V.RDACK % Hold until V.RDACK
OR / P2.WEL & / P2.WEU & V.REQ % Set at end of write
OR V.WAIT & V.REQ & / V.ACK % Hold till V.ACK

ASSERT VREQ % Inverter
ENABLE ALWAYS
OR V.REQ-

TIMING: NO-CLOCK
%
12345678901234567890123456789012345

P2.RD- -- ----- ---------------------
P2.WEL- ----- ----- ----- ----- ----
P2.WEU- ----- ----- ----- ----- ----- ----
Q.AS- -------- ----- ----- ----- ----- 
V.REQ- -------- ----- ----- ----- ----- 
VREQ- ------ ----- ----- ----- ----- 
V.ACK- ------ ----- ----- ----- ----- 
V.WAIT- ------ ----- ----- ----- ----- 
V.RDACK- -------- ----- ----- ----- ----- 
V.WL- -------- ----- ----- ----- ----- 
V.WU- -------- ----- ----- ----- ----- 
V.BSEL- -------- ----- ----- ----- ----- 
V.CSEL- -------- ----- ----- ----- ----- 
P2.A17- ------ ----- ----- ----- ----- 
V.RD- ---- ---- ---- ---- ---- ---- ----
V.RDC- ----- ----- ----- ----- ----- ----- ----
V.WUC- ----- ----- ----- ----- ----- ----- ----

PALEND
static char socs_id = "1.12 84/06/20";

#include "/usr/local/pl/prom.c"
#define range(lo, x, high) ((lo<=x) && (x<=high))

/* This information proprietary to Sun Microsystems Inc */

/*====================================================================*/
/* Author: Model-50 Group */
/* Date : March 9, 1984 */
/* Prom Name: A1811 */
/* Prom Type: 612 x 4. */
/* Speed: 55 nsec. */
/* Purpose: Video horizontal state machine. */
/* Timing: */
/* 1 Horizontal state = 64 pixel; 1 pixel = 10 nsec. */

* Range     Length     Length     Time
[State]    [State] [Pixel] [usec]
*====================================================================*
* === 1152 x 900 Display ===*
* cycle     00..24  25  1600  16.00  HFreq = 62.5 KHz
* visible   00..17  18  1152  11.52
* invisible 18..24  7   448   4.48
* frontporch ...  0   0    0
* hsync     18..19  2   128   1.28
* backporch 20..24  5   320   3.20
* === 1024 x 1024 Display ===*
* cycle     00..24  25  1600  16.00  HFreq = 62.5 KHz
* visible   00..15  18  1152  11.52
* invisible 16..24  7   448   4.48
* frontporch 16..15  1   64   0.64
* hsync     17..18  2   128   1.28
* backporch 19..24  6   384   3.84
*====================================================================*

/* Define Inputs */

int res_1152x900;

#define h0 (a0)
#define h1 (a1)
#define h2 (a2)
#define h3 (a3)
#define h4 (a4)
#define h5 (a5)
#define h6 (a6)
#define h7 (a7)
define vblank (a8)
define state (cvb(h0)*d0 + cvb(h1)*d1 + cvb(h2)*d2 + cvb(h3)*d3 + 
            cvb(h4)*d4 + cvb(h5)*d5 + cvb(h5)*d6 + cvb(h7)*d7 )
#define nstate ((state + 1) % 25)

dispen()
{
    int dispen;
    if (res_1152x900) {
        dispen = (!vblank && range(0, nstate, 17));
    } else {
        dispen = (!vblank && range(0, nstate, 15));
    }
    return(dispen);
}

hsync()
{
    int hsync;
    if (res_1152x900) {
        hsync = range(18, nstate, 19);
    } else {
        hsync = range(17, nstate, 18);
    }
    return(hsync);
}

#define breset (nstate == 0)
#define vclock (nstate == 21)

main()
{
    prom512x4;

    res_1152x900 = 1;
    prombegin
    prom(0, d0, hsync())
    prom(0, d1, dispen())
    prom(0, d2, !dispen())
    prom(0, d3, breset)
    promend;

    res_1152x900 = 0;
    prombegin
    prom(1, d0, hsync())
    prom(1, d1, dispen())
    prom(1, d2, !dispen())
    prom(1, d3, breset)
    promend;

    writeprom("A1811", 0);
    writeprom("A1811_1024", 1);
}
static char sccs_id = "1.10 84/05/20";

#include "/usr/local/pl/prom.c"
#define range(low,high) (((low<=x)&&(x<=high))

/* This information proprietary to Sun Microsystems Inc */

*Author: Model-60 Group
*Date: March 9, 1984
*Prom Name: A1816
*Prom Type: 512 x 4.
*Speed: 55 nsec.
*Purpose: Video vertical state machine
*
* 1 states = 1 line = 16.00 usec (62.50 KHz)
*
<table>
<thead>
<tr>
<th>Range</th>
<th>Length</th>
<th>Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>[Lines]</td>
<td>[Lines]</td>
<td>[usec]</td>
</tr>
<tr>
<td>-----------</td>
<td>--------</td>
<td>-------</td>
</tr>
</tbody>
</table>
| *** 1152x900 Display ***
* cycle    000..936  937  14992  65.70 Hz
* visible  000..899  900  14400
* invisible 900..936  37   592
* frontporch .. 0        0
* vsync    900..909   10  160
* backporch 910..935  27  432
| *** 1024x1024 Display ***
* cycle    000..1050  1051  16976  58.91 Hz
* visible  000..1023  1024  16384
* invisible 1024..1060 37  592
* frontporch .. 0        0
* vsync    1024..1033  10  160
* backporch 1034..1060 27  432
*-----------|--------|-------|

int res_1152x900;

/* Define Inputs to prom */

#define v0 0
#define v1 (a1)
#define v2 (a2)
#define v3 (a3)
#define v4 (a4)
#define v5 (a5)
#define v6 (a6)
#define v7 (a7)
#define v8 (a8)
#define v9 (a8)
#define v10 (a0)

#define line (cvb(v0)*d0 + cvb(v1)*d1 + cvb(v2)*d2 + cvb(v3)*d3 + \
vsync()
{ int vsync;
  if (res_1152x900) {
    vsync = range(line, 909);
  } else {
    vsync = range(line, 1033);
  }
  return(vsync);
}

vblank()
{ int vblank;
  if (res_1152x900) {
    vblank = (line >= 900);
  } else {
    vblank = (line >= 1024);
  }
  return(vblank);
}

vreset()
{ int vreset;
  if (res_1152x900) {
    vreset = (line >= 936);
  } else {
    vreset = (line >= 1060);
  }
  return(vreset);
}

main()
{ pro512x4:

  res_1152x900 = 1;
  prombegin
  prom(0, 0, vsync())
  prom(0, 1, vreset())
  prom(0, 2, vblank())
  prom(0, 3, vreset())
  promend;

  res_1152x900 = 0;
  prombegin
  :wa(1, 0, vsync())
  prom(1, 1, vreset())
  prom(1, 2, vblank())
  prom(1, 3, vreset())
  promend;

  writeprom("A1815", 0);
  writeprom("A1815_1024", 1);
% Inputs
2 INPUT S.RREQ-
3 INPUT S.EREQ-
4 INPUT S.XREQ-
5 INPUT S.EHOLD
6 INPUT P.BG-
7 INPUT S.ASIN
8 INPUT S.ERR-
9 INPUT Q.S7
1 CLOxLCLK
10 GND
11 OUTPUT-ENABLE OE-
20 VCC

% Outputs
19 OUTPUT R.DMAEN-
18 OUTPUT E.DMAEN-
17 OUTPUT X.DMAEN-
16 OUTPUT E.CLK-
15 OUTPUT S.DMA-
14 OUTPUT S.ASOFF-
13 OUTPUT PIN13-
12 OUTPUT S.BR-

EQUATIONS
: IDLE / R.DMAEN & / E.DMAEN & / X.DMAEN ;

% Non-contigous DVMA
: GRANT1 P.BG & / S.ASIN & IDLE & S.BR & / S.ERR ;

% Back-to-Back DVMA (Last state on current DMAEN cycle)

ASSERT S.BR-
OR / P.BG & S.RREQ % Set
OR / P.BG & S.EREQ & S.EHOLD % Set
OR / P.BG & S.XREQ % Hold. Pending S.RREQ
  S.BR & S.RREQ % Hold. Pending S.EHOLD /R.DMAEN
OR S.BR & S.EHOLD & / R.DMAEN % Hold. Pending S.XREQ
OR S.BR & S.DMA & / R.DMAEN & / Q.S7 % Hold while R.DMAEN
OR S.BR & S.DMA & / R.DMAEN & / Q.S7 % Hold while E.DMAEN and X.DMAEN

ASSERT R.DMAEN-
OR S.RREQ & GRANT1 % Refresh DVMA
OR S.RREQ & GRANT2
OR RDMAEN & SDMA & / S.ASOF
OR RDMAEN & SDMA & / S.ASIN
OR SDMA & / S.ASOF & / E.DMAEN & / XDMAEN

% Deal with S.DMA on POR

ASSERT E.DMAEN- % Ethernet dma
OR S.EREQ & S.EHOLD & / S.RREQ & GRANT1
OR S.EREQ & S.EHOLD & / S.RREQ & GRANT2
OR E.DMAEN & SDMA & / S.ASOF
OR E.DMAEN & SDMA & / S.ASIN

ASSERT X.DMAEN- % VME-bus dma
OR SXREQ & / S.RREQ & / S.EREQ & GRANT1
OR SXREQ & / S.RREQ & / S.EREQ & GRANT2
OR XDMAEN & SDMA & / S.ASOF
OR XDMAEN & SDMA & / S.ASIN

ASSERT S.DMA- % R.DMAEN or E.DMAEN or X.DMAEN
OR S.RREQ & GRANT1 % Refresh turnons
OR S.RREQ & GRANT2
OR S.EREQ & S.EHOLD & / S.RREQ & GRANT1 % Ethernet turnons
OR S.EREQ & S.EHOLD & / S.RREQ & GRANT2
OR SXREQ & / S.RREQ & / S.EREQ & GRANT1 % VME turnons
OR SXREQ & / S.RREQ & / S.EREQ & GRANT2
OR S.DMA & / S.ASOF
OR S.DMA & / S.ASIN

ASSERT S.ASOF- % Assert E.CLR to clear Ethernet request flipflop.
OR RDMAEN & S.ASIN
OR S.DMA & / S.ASOF & / Q.S7 & S.ASIN
OR S.ERR

% Assert E.CLR- % Ethernet dma
OR S.EREQ & E.DMAEN & / S.ASIN

TIMING:

<table>
<thead>
<tr>
<th>S.ASOF-</th>
<th>S.ASIN</th>
<th>Q.S7</th>
<th>XDMAEN-</th>
<th>E.DMAEN-</th>
<th>RDMAEN-</th>
<th>S.DMA-</th>
<th>E.CLR-</th>
<th>S.ERR-</th>
<th>OE-</th>
</tr>
</thead>
</table>

```c

```

```c

```

```c

```
PIN13- ?????????????????????????????????????????????????????????????????????????????????
PALEND
paltype pal1618
palname A800
palid 1.11 84/07/30

PALBEGIN

% Inputs

1 INPUT R.DMAEN- % Refresh DMA enable
2 INPUT E.DMAEN- % Ethernet DMA enable
3 INPUT X.DMAEN- % VME (external) DMA enable
4 INPUT Q.R/W- % Read or Write
5 INPUT S.DMA-
6 INPUT S.ASOF-
7 INPUT S.ASON-
8 INPUT E.A0
9 INPUT X.LDS-
11 INPUT X.UDS-
10 GND
20 VCC

% Outputs

19 OUTPUT E.WE
18 OUTPUT E.OE-
17 OUTPUT P.FC0
16 OUTPUT P.FC1
15 OUTPUT P.FC2
14 OUTPUT P.AS-
13 OUTPUT P.UDS-
12 OUTPUT P.LDS-

EQUATIONS

: WRITE Q.R/W ;

ASSERT E.WE % Demorganize:
ENABLE ALWAYS
OR / E.DMAEN
OR / S.ASON
OR S.ASOF
OR WRITE

ASSERT E.OE-
ENABLE ALWAYS
OR E.DMAEN & / S.ASOF & WRITE

% Function codes for DVMA cycles:
% R.DMAEN: FC=7, CPU space.
% E.DMAEN: FC=5, Supervisor data.
% X.DMAEN: FC=5, Supervisor data.

ASSERT P.FC0
ENABLE S.DMA
OR NEVER

ASSERT P.FC1
ENABLE S.DMA
OR / R.DMAEN

ASSERT P.FC2
ENABLE S.DMA
OR NEVER

ASSERT P.AS-
ENABLE S.DMA
OR S.ASON & / S.ASOFF

ASSERT P.UDS-
ENABLE S.DMA
OR E.DMAEN & / E.AO & S.ASON & / S.ASOFF
OR X.DMAEN & X.UDS & S.ASON & / S.ASOFF

ASSERT P.LDS-
ENABLE S.DMA
OR E.DMAEN & S.ASON & / S.ASOFF
OR X.DMAEN & X.LDS & S.ASON & / S.ASOFF

TIMING: NO-CLOCK
% 12345678901234567890123456789012345678901234567890
Q.R/W-
S.ASON-
S.ASOF-
E.DMAEN-
E.WE
E.OE-
R.DMAEN-
S.DMA-
P.FC0
P.FC1
P.FC2
P.AS-
E.AO
X.DMAEN-
X.UDS-
X.LDS-
P.UDS-
P.LDS-
PABEND
paltypa pal16r4
pallname A507
palid 1.18 84/08/01

PALBEGIN

% Inputs

2 INPUT WR.DCP-
3 INPUT C-160
4 INPUT C-320
5 INPUT C.S9
6 INPUT P.A01
7 INPUT RD.DCP-
8 INPUT C.S6
9 INPUT C-80-

1 CLOCK CLK
11 OUTPUT-ENABLE OE-
13 GND
20 VCC

% Outputs

19 OUTPUT MAS-
18 OUTPUT D.START-
17 OUTPUT D.END-
16 OUTPUT T150-
15 OUTPUT T240-
14 OUTPUT WAIT-
13 OUTPUT MDS-
12 OUTPUT P2.WAIT-

EQUATIONS

ASSERT MAS- % DCP addr strobe. Unclocked.
ENABLE ALWAYS
OR P.A01 & WR.DCP & / C.S9

ASSERT D.START- % DCP data strobe. Unclocked.
ENABLE ALWAYS
OR / P.A01 & RD.DCP & / C.S9
OR / P.A01 & WR.DCP & / C.S9 & C.S6
OR D.START & / T240

ASSERT D.END- % DCP data strobe. Clocked.
OR D.START & / T240

ASSERT T150- % Internal clocked edge
OR D.END & C.S9 & / C-320 & C-160
OR T150 & / T240

ASSERT T240- % Internal clocked edge
OR T150
ASSERT WAIT-
    % Clocked
    OR D.START & RD.DCP & / D.END & / T160 & / T240
    OR D.START & RD.DCP & / C.S9 & / T160 & / T240
    OR D.START & RD.DCP & / C-320 & / T160 & / T240
    OR D.START & RD.DCP & / C-160 & / T160 & / T240
    OR D.START & WR.DCP & / T160 & / T240

ASSERT MDS-
    % Actual data strobe to chip
    ENABLE ALWAYS
    OR D.START
    OR D.END
    OR MDS & / C-80

ASSERT P2.WAIT-
    % Open-collector WAIT
    ENABLE WAIT
    OR WAIT

TIMING:

CLK
C-80-
C-160
C-320
C.S6
C.S9
P.A01
MAS-
WR.DCP-
RD.DCP-
WAIT-  ?????????
P2.WAIT-  ?????????
D.START-  ?????????
D.END-  ?????????
MDS-
T160-
T240-
OE-

PALEND
palttype pal1518
palname A810
palid 1.42 64/10/04

PALBEGIN

% Inputs

1  INPUT  RD.P1-
2  INPUT  WR.P1-
3  INPUT  B.AEN-
4  INPUT  B.TC3-
5  INPUT  X.DMA-
6  INPUT  P.RESET-
7  INPUT  X.DMAEN-
8  INPUT  P1.WRITE-
9  INPUT  C.S4-
10 INPUT  Q.INTVEC-
11 INPUT  P.R/W-

10  GND
20  VCC

% Outputs

19 OUTPUT  VME.DWEN-
18 OUTPUT  B.BSEL-
17 OUTPUT  B.RERUN-
16 OUTPUT  B.FREEZE-
15 OUTPUT  VME.DDOE-
14 OUTPUT  XHOLD-
12 OUTPUT  VME.DIE-

EQUATIONS

ASSERT B.BSEL-  % CPU wants vme mastership
DISABLE ALWAYS
OR  RD.P1 & / X.DMAEN  % Read cycle
OR  WR.P1 & / X.DMAEN  % Write cycle
OR  Q.INTVEC & / X.DMAEN  % VME interrupt acknowledge cycle
OR  B.BSEL & C.S4  % Hold during read-modify-write cycles
OR  B.BSEL & B.FREEZE  % Hold during any rerun condition

ASSERT B.FREEZE-
DISABLE ALWAYS
OR  B.RERUN & / X.DMAEN & / P.RESET  % Set
OR  B.FREEZE & / C.S4 & / P.RESET  % Hold starting on RERUN turn-off
OR  B.FREEZE & / RD.P1 & / WR.P1 & / Q.INTVEC & / P.RESET
OR  B.FREEZE & / X.DMAEN & / P.RESET

ASSERT B.RERUN-
DISABLE ALWAYS
OR  B.TC3  % 2.5 usec short timeout
OR  RD.P1 & X.DMA & / XHOLD  % Bus deadlock
OR  WR.P1 & X.DMA & / XHOLD  % Bus deadlock
OR Q. INTVEC & X.DMA & XHOLD % Bus deadlock
OR B.RERUN & C.S4 % Hold until CPU accepts Rerun.

ASSERT XHOLD-
ENABLE ALWAYS
OR X.DMAEN % Set
OR XHOLD & X.DMA % Hold till end of XDMA
OR XHOLD & B.FREEZE % Or Hold till rerun cycle

ASSERT VME.DWEN-
ENABLE ALWAYS
OR C.S4 & X.DMA & B.FREEZE & B.BSEL
OR C.S4 & X.DMA & XHOLD
OR C.S4 & X.DMAEN

ASSERT VME.DOE-
ENABLE ALWAYS
OR B.AEN & X.DMAEN & P.R/W & C.S4 % Set on CPU write.
OR B.AEN & P1.WRITE & B.FREEZE % Hold during CPU rerun
OR X.DMA & P1.WRITE % DMA read

ASSERT VME.DIE-
ENABLE ALWAYS
OR RD.P1
OR Q.INTVEC
OR X.DMAEN & P.R/W-

TIMING: NO-CLOCK
% 1234567890123456789012345678901234567
P.RESET-
B.T03-
B.BSEL-
B.FREEZE-
B.RERUN-
RD.P1-
WR.P1-
Q.INTVEC-
C.S4-
XHOLD-
X.DMA-
B.AEN-
X.DMAEN-
P1.WRITE-
P.R/W-
VME.DWEN-
VME.DOE-
VME.DIE-
PALEND
static char *sccs_id = "$Id: 1.17 84/10/02:"

/* This information proprietary to Sun Microsystems, Inc */

#include /usr/local/pl/prom.c
#define range(lo,x,high) ((lo<=x)&&(x<=high))

/* Define inputs to 1K x 4 Prom. */
#define bgout ! (a0)
#define bbout ! (a1)
#define brout ! (a2)
#define aen ! (a3)
#define bbin ! (a4)
#define brin ! (a5)
#define as ! (a6)
#define sel ! (a7)
#define bgin ! (a8)
#define arb ! (a9)

/* Define Bus Busy. *bbin* suppressed externally if *bbout* asserted. */
/* Prevents transition from MASTER to BUSGRANT to IDLE on our own *bbout*. */
#define busy (bbin || bbout)
/* Define Bus Req. "brin" suppressed externally if "brout" asserted. */
/* Prevents transition from BUSREQ to MASTER to MASTER_G on our own "brout". */
#define breq (brin || brout)

/* Define potential states */

#define IDLE (!bgout && !bbout && !brouf && !aen)
#define BUSREQ (!bgout && !bbout && !brouf && !aen)
#define WAITFORBUS (!bgout && bbout && !brouf && !aen)
#define WAITREQ (!bgout && bbout && !brouf && !aen)
#define MASTER_REQ (!bgout && bbout && !brouf && !aen)
#define MASTER (!bgout && bbout && !brouf && !aen)
#define MASTER_NB (!bgout && !bbout && !brouf && !aen)
#define MASTER_G (bgout && !bbout && !brouf && !aen)
#define BUSGRANT (bgout && !bbout && !brouf && !aen)

/* Define state transitions */

n_IDLE()
{  int value;
   value =  arb && IDLE && (busy && !sel);
   value |=  arb && IDLE && (!busy && !sel && !breq && as);
   value |=  arb && BUSGRANT && (busy && !sel);
   value |=  !arb && BUSGRANT && (!busy && !breq); /* Error */
   value |=  !arb && IDLE && (!sel && !bg1n);
   value |=  !arb && MASTER && (!sel && !bg1n && breq);
   value |=  !arb && MASTER_NB && (!sel && !bg1n);
   value |=  !arb && BUSGRANT && (!sel && !bg1n);
   return(value);
}

n_BUSREQ()
{  int value;
   value =  arb && IDLE && (busy && sel);
   value |=  arb && BUSREQ && (busy);
   value |=  arb && BUSGRANT && (busy && sel);
   value |=  !arb && BUSGRANT && (sel && bg1n);
   value |=  !arb && IDLE && (sel && bg1n);
   value |=  !arb && BUSREQ && (sel && bg1n);
   value |=  !arb && BUSREQ && (!bg1n);
   return(value);
}

n_WAITFORBUS()
{  value;
   value =  arb && IDLE && (!busy && sel && as);
   value |=  arb && WAITFORBUS && (as);
   value |=  arb && WAITREQ && (as);
   value |=  !arb && IDLE && (!busy && sel && as && bg1n);
   value |=  !arb && WAITFORBUS && (as);
   value |=  !arb && WAITREQ && (as);
   return(value);
}
n_WAITREQ()
{
    int value;
    value = arb ** BUSREQ ** (!busy ** as);
    value |= !arb ** BUSREQ ** (!busy ** as ** begin);
    return(value);
}

n_MASTER_REQ()
{
    int value;
    value = arb ** BUSREQ ** (!busy ** !as);
    value |= !arb ** BUSREQ ** (!busy ** !as ** begin);
    return(value);
}

n_MASTER()
{
    int value;
    value = arb ** IDLE ** (!sel ** !busy ** !breq ** !as);
    value |= arb ** IDLE ** (sel ** !busy ** !as);
    value |= arb ** WAITFORBUS ** (!as);
    value |= arb ** WAITREQ ** (!as);
    value |= arb ** MASTER_REQ; 
    value |= arb ** MASTER ** (sel ** !breq);
    value |= arb ** MASTER ** (sel ** breq ** !as);
    value |= arb ** MASTER ** (!sel ** !breq);
    value |= !arb ** IDLE ** (sel ** !busy ** !as ** begin);
    value |= !arb ** WAITFORBUS ** (!as);
    value |= !arb ** WAITREQ ** (!as);
    value |= !arb ** MASTER_REQ;
    value |= !arb ** MASTER ** (sel ** !breq);
    value |= !arb ** MASTER ** (sel ** breq ** !as);
    value |= !arb ** MASTER ** (!sel ** !breq);
    value |= !arb ** MASTER ** (begin);
    return(value);
}

n_MASTER_NB()
{
    int value;
    value = !arb ** MASTER ** (sel ** !begin ** breq ** as);
    value |= !arb ** MASTER_NB ** (sel ** !begin);
    return(value);
}

n_MASTER_G()
{
    int value;
    value = arb ** MASTER ** (sel ** breq ** as);
    value |= arb ** MASTER_G ** (sel);
    value |= !arb ** MASTER_NB ** (sel ** begin);
    value |= !arb ** MASTER_G ** (sel);
    return(value);
}

n_BUSGRANT()
{
    int value;
    value = arb ** IDLE ** (!sel ** !busy ** breq);
    value |= arb ** MASTER ** (!sel ** breq);
    value |= arb ** MASTER_G ** (!sel); 
}
value &= arb && BUSGRANT && (!busy && breq);
value &= !arb && IDLE && (!sel && bgin);
value &= !arb && MASTER_NB && (!sel && bgin);
value &= !arb && MASTER_G && (!sel);
value &= !arb && BUSGRANT && (bgin);
return (value);
}

/* Define new outputs */
#define n_bgout (n_MASTER_G() || n_BUSGRANT())
#define n_bbout (n_WAITFORBUS() || n_WAITREQ() || n_MASTER_REQ() || n_MASTER())
#define n_brout (n_BUSREQ() || n_WAITREQ() || n_MASTER_REQ())
#define n_aen (n_MASTER_REQ() || n_MASTER() || n_MASTER_NB() || n_MASTER_G())

main()
{
  prom1024x4;

  prombegin
  prom(0, d0, !n_bgout)
  prom(0, d1, !n_bbout)
  prom(0, d2, !n_brout)
  prom(0, d3, !n_aen)
  promend;

  writeprom("A811", 0);
}
paltypa pal1618
palname A814
pallid 1.10 84/10/04

PALBEGIN

% Inputs
1 INPUT B.C1
2 INPUT B.C3
3 INPUT Q.RAS
4 INPUT B.XBSY-
5 INPUT B.BBOUT-
6 INPUT B.BROUT-
7 INPUT P1.BRO-
8 INPUT P1.BR1-
9 INPUT P1.BR2-
10 INPUT P1.BR3-
11 INPUT P1.BRIN-
12 INPUT P1.SYSR-
13 INPUT P1.BR2-
14 INPUT P1.BROUT

% Outputs
15 OUTPUT B.T03-
16 NOTUSED
17 OUTPUT B.SYSR
18 NOTUSED
19 OUTPUT B.BBSY-
20 VCC
21 OUTPUT B.BR-

EQUATIONS

ASSERT B.T03-
ENABLE ALWAYS
OR B.C3 & B.C1

ASSERT B.SYSR
ENABLE ALWAYS
OR P1.SYSR-

ASSERT B.BBSY-
ENABLE ALWAYS
OR B.XBSY & / B.BBOUT

ASSERT B.BR-
ENABLE ALWAYS
OR P1.BRO & / B.BROUT
OR P1.BR1 & / B.BROUT
OR P1.BR2 & / B.BROUT
OR P1.BR3 & / B.BROUT
OR B.BRIN & / B.XBSY

% Inverter
% Hold to correct RC delay
paltype pal1618
palname A816
palid 1.9 84/10/08

PALBEGIN

% Inputs

1 INPUT Q.AS
2 INPUT P.LDS-
3 INPUT P.UDS-
4 INPUT B.BERRIN-
5 INPUT B.DTACKIN-
6 INPUT B.AEN-
7 INPUT B.BEN-
8 INPUT B.FREEZE-
9 INPUT C.S6
11 INPUT B.BSEL-
14 INPUT B.BBOUT-
10 GND
20 VCC

% Outputs

19 OUTPUT P1.AEN-
18 OUTPUT B.AS-
17 OUTPUT B.LDS-
16 OUTPUT B.UDS-
15 OUTPUT B.DTACK
13 OUTPUT B.DEN-
12 OUTPUT B.BERR-

EQUATIONS

:XEN B.AEN & B.BEN & B.DEN ;

ASSERT B.AS-
ENABLE ALWAYS
OR  XEN & B.BSEL & C.S6 & Q.AS & / B.FREEZE
OR  XEN & B.AS & B.FREEZE % Hold between C.S4 and C.S6
OR  XEN & B.AS & Q.AS % after FREEZE deassertion
OR  XEN & B.AS & / B.BBOUT & B.LDS % Add 2 delay on last vme cycle
OR  XEN & B.AS & / B.BBOUT & B.UDS % Add 2 delay on last vme cycle

ASSERT B.UDS-
ENABLE ALWAYS
OR  XEN & B.AS & B.BSEL & Q.AS & P.UDS & / B.FREEZE
OR  XEN & B.UDS & B.FREEZE
OR  XEN & B.UDS & Q.AS & P.UDS % Hold between C.S4 and C.S6

ASSERT B.LDS-
ENABLE ALWAYS
OR  XEN & B.AS & B.BSEL & Q.AS & P.LDS & / B.FREEZE
OR  XEN & B.LDS & B.FREEZE
OR XEN & B.LDS & Q.AS & P.LDS  % Hold for rerun cycle

ASSERT B.DEN-
ENABLE ALWAYS
OR B.AEN & B.BEN & B.BSEL & C.S6 & Q.AS
    & / B.DTACKIN & / B.BERRIN & / B.FREEZE
OR XEN & B.FREEZE
OR XEN & B.AS
OR XEN & B.LDS
OR XEN & B.UDS

ASSERT B.DTACK
ENABLE ALWAYS
OR / B.DTACKIN
OR / B.DEN
OR B.FREEZE
OR / C.S6

ASSERT B.BERR-
ENABLE ALWAYS
OR B.BERRIN & B.DEN & / B.FREEZE & C.S6

ASSERT P1.AEN-
ENABLE ALWAYS
OR B.AEN & B.BBOUT
OR B.AEN & B.DEN & B.FREEZE
OR B.AEN & B.LDS & P.LDS
OR B.AEN & B.UDS & P.UDS  % Off at P.DS + 1 pal

TIMING: NO-CLOCK
% 1234567890123456789012
B.BBOUT- 
B.BEN- 
B.AEN- 
P1.AEN- 
C.S6 
Q.AS 
B.AS- 
B.FREEZE- 
B.BSEL- 
B.DTACKIN- 
B.DEN- 
B.DTACK 
B.BERRIN- 
B.BERR- 
P.UDS- 
B.UDS- 
P.LDS- 
B.LDS- 
PALEND