| <b>A</b> | | | |----------|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### ©1986 AT&T All Rights Reserved Printed in USA #### NOTICE The information in this document is subject to change without notice. AT&T assumes no responsibility for any errors that may appear in this document. Motorola is a registered trademark of Motorola, Incorporated. Centronics is a registered trademark of Centronics Data Corporation. Cipher is a registered trademark of Cipher Data Products, Incorporated. Seagate is a registered trademark of Seagate Technology. Toshiba is a registered trademark of Toshiba America Inc. L-244069-5 The AT&T UNIX® PC Reference Manual is solely intended for use by qualified service personnel to assist in maintaining the UNIX PC. The Reference Manual is NOT intended for development of UNIX PC hardware enhancements. A "UNIX PC Expansion Bus Specification" can be obtained for this purpose by writing: AT&T Information Systems UNIX PC Product Management 1776 on the Green Morristown, New Jersey 07960 (201) 898-6000 The UNIX PC Reference Manual is subject to change without notice. The recipient accepts this Reference Manual "as is." Neither AT&T Information Systems, nor its affiliates, contractors, suppliers, or agents make any representations or warranties, expressly or implicitly, including, but not limited to, implied warranties of merchantability and fitness for a particular purpose, with respect to this Reference Manual and shall not be liable for errors contained in such Manual or from any claim for damages or expenses, including indirect, special, reliance, incidental or consequential losses (including lost profits or opportunities), arising out of the use thereof, whether or not AT&T-IS, its affiliates, contractors, suppliers or agents had prior knowledge of any defect or error in the Reference Manual. #### Preface The AT&T UNIX $^{\circledR}$ PC Reference Manual has been written for technicians doing component-level troubleshooting of the AT&T UNIX $^{\circledR}$ PC logic board. ### Organization of this Manual This manual contains the following sections: # System Features and Functions Briefly describes the physical features and functional capabilities of the UNIX PC system. ### Logic Board Theory of Operation Describes the logic board hardware and the functions performed by it, including direct memory access and bus arbitration, machine cycle timing, memory management, and input/output handling. ### Diagnostics Describes boot ROM, floppy disk, and expert mode diagnostics, including algorithms, screen displays, and error messages. # Logic Board Test Procedures Contains a collection of test procedures intended to aid in troubleshooting. #### Schematics Contains the schematic of the logic board for P4 and P5 configurations and schematics for DMA and video gate arrays. #### Appendix A: PAL Equations Contains the logic equations for the arbitor, disk interface, memory management unit, and hard disk data separator PALs. # Appendix B: Mnemonics Contains definitions of the mnemonics used throughout the theory of operation and the schematics. # Appendix C: Expansion Memory Locations Contains a table listing of the possible expansion memory configurations and their expansion slot position requirements. # Contents | 1 | System Features and Functions Functional Specifications Logic Board Terminal Subsystem Keyboard Mouse Audible Indicator Data Storage RS-232-C Port Centronics Parallel Printer Interface Expansion Slots Physical and Electrical Specifications Logic Board Bus System Simplified Address and Data Block Diagram Onboard Memory | 1-1<br>1-3<br>1-3<br>1-4<br>1-4<br>1-5<br>1-6<br>1-6<br>1-7<br>1-12<br>1-13<br>1-13 | |---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------| | | System Control Block Diagram | 1-17 | | 2 | Logic Board Theory of Operation Direct Memory Access Machine Cycle Timing Memory Management Input/Output Handling Boot ROM Algorithm Fast and Slow Cycles Clock Generation Bus Arbitration Bus Masters and Slaves Arbitration Priority Arbitration Signal Sequence Reset Vector Loading 68010 ROM Read Sequence Mapping Virtual Address | 2-1<br>2-1<br>2-1<br>2-2<br>2-2<br>2-2<br>2-6<br>2-7<br>2-9<br>2-10<br>2-11<br>2-12<br>2-13<br>2-15 | | Write Sequence: Processor to | | |--------------------------------------------|-------| | Page Map | 2-21 | | 608010 Local RAM Read Sequence | 2-23 | | Parity | 2-27 | | Page Status Update and Memory | | | Management Errors | 2-29 | | Generation of Memory Management | | | Interrupts | 2-30 | | Refresh Operation | 2-31 | | System Control and Status | | | Registers | 2-33 | | Reading General Status Register | | | (Address 410000) | 2-39 | | Interrupting the Processor | 2-40 | | Exception Vectors | 2-40 | | Interrupts: Theory of Operation | 2-42 | | Disk Direct Memory Access (DMA) | 2-43 | | Definitions | 2-45 | | Initializing Hard Disk DMA Read | 2-57 | | Executing Hard Disk DMA Read | 2-62 | | Terminal Count | 2-64 | | Underrun/Overrun Errors | 2-64 | | Separating Hard Disk Data | 2-65 | | Floppy Disk Direct Memory Access | 2-69 | | Video Bit Map | 2-78 | | Screen Layout | 2-78 | | State Generator | 2-80 | | 68010 Loading of Bit Map | 2-81 | | Bit Map Address Multiplex | 2-83 | | Refresh Address Counter | | | Horizontal Synchronization | 2-84 | | Vertical Synchronization | 2-85 | | Shift Register | 2-85 | | Telephony | 2-85 | | Line Control | 2-86 | | | 2-87 | | Telephony Status Register Dialer Interface | 2-89 | | | 2-90 | | Serial Communication | 2-91 | | RS-232 Serial Port | 2~91 | | Baud Rate Generation | 2-93 | | 7201 Serial Controller | 2-94 | | Modem | 2-96 | | Line Printer | 2-100 | | Ports | 2-100 | | Control Signals | 2-100 | | Write Sequence | 2-101 | | Status Signal Description | 2-102 | | Serial Printer Cables | 2-103 | | Realtime Clock Interface | 2-104 | | Keyboard Controller | 2-105 | | Boot ROM Program 3-1 | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------|------| | Bootstrap Jump 3-1 | 3 | Diagnostics | 3-1 | | Initializing the System 3-2 | | Boot ROM Program | 3-1 | | Initializing the 7201 Serial Port Controller 3-2 Initializing the Keyboard 3-2 Initializing the Modem 3-2 Initializing the Modem 3-2 Initializing the Telephone Line Control 3-2 Clearing the Printer Interrupt 3-3 Clearing the Dialer Chip 3-3 Resetting the Disk DMA 3-3 Testing Video RAM 3-3 Testing Wap RAM Memory 3-4 Testing RAM 3-4 Jumping to the Loader Program 3-5 Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-7 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-26 Seek and Step Commands 3-27 Register Commands 3-27 Register Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Read/Write Loop Program 4-12 Read/Writest Procedure 4-15 Page Status Test 4-17 | | | 3-1 | | Port Controller | | Initializing the System | 3-2 | | Initializing the Keyboard Initializing the Modem Initializing the Modem Initializing the Telephone Line Control Clearing the Printer Interrupt Clearing the Dialer Chip Resetting the Disk DMA Insting Map RAM Insting Map RAM Memory Insting Map RAM Insting Map RAM Memory Insting RAM Insting Map RAM Memory Insting RAM Insting Map RAM Memory Insting RAM Insting Map RAM Memory Insting RAM Insting Map RAM Insting Map RAM Insting Map RAM Insting RAM Insting Map RAM Insting RAM Insting Map RAM Insting | | Initializing the 7201 Serial | | | Initializing the Modem | | | 3-2 | | Initializing the Telephone Line | | | 3-2 | | Control Clearing the Printer Interrupt 3-3 Clearing the Dialer Chip 3-3 Resetting the Disk DMA 3-3 Testing Video RAM 3-3 Testing Map RAM Memory 3-4 Testing RAM Jumping to the Loader Program 3-5 Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-7 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-26 Read and Write Commands 3-27 Register Commands 3-27 Register Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test Address Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Walking Ones Test Program 4-1 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 | | | 3-2 | | Clearing the Printer Interrupt Clearing the Dialer Chip Resetting the Disk DMA 3-3 Testing Video RAM 3-3 Testing Map RAM Memory 3-4 Testing RAM 3-4 Jumping to the Loader Program 3-5 Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-6 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-27 Register Commands 3-27 Register Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 | | | | | Clearing the Dialer Chip Resetting the Disk DMA 3-3 Testing Video RAM 3-3 Testing Map RAM Memory 3-4 Testing RAM 3-4 Jumping to the Loader Program 3-5 Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-7 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-27 Register Commands 3-27 Register Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-15 Page Status Test 4-17 | | | | | Resetting the Disk DMA Testing Video RAM Testing Wap RAM Memory 3-4 Testing RAM Jumping to the Loader Program 3-5 Floppy Disk Diagnostics Main Menu Diagnostics Summary Jiagnostic Subtest Summary Jiagnostic Test Descriptions Expert Mode Diagnostics Program Jisk Drive Commands Read and Write Commands Seek and Step Commands Seek and Step Commands Jeffer Commands Seek and Step Commands Seek Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading Program Reading Descriptions Reading Program Resed/Write Loop Program Read/Write Loop Program Read/Write Loop Program Parity Test Procedure Read Read Parity Read Parity Read Parity Read Parity Read Parity Re | | | | | Testing Wideo RAM Testing Map RAM Memory Testing RAM Jumping to the Loader Program 3-4 Jumping to the Loader Program 3-5 Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-7 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-27 Register Commands 3-27 Register Commands 3-27 Register Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Testing Map RAM Memory Testing RAM Jumping to the Loader Program Expert Mode Diagnostics Summary Jumping to Expert Mode Diagnostics Program Jumping to Expert Mode Jumping to Expert Mode Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode Logic Board Test Procedures Jumping to Hard Disk with Expert Mode Logic Board Test Procedures Jumping to Hard Disk with Expert Mode Logic Board Test Procedures Jumping to Hard Disk with Expert Mode Logic Board Test Procedures Jumping to Hard Disk with Expert Mode H | | | | | Testing RAM | | | | | Jumping to the Loader Program Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-6 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-26 Seek and Step Commands 3-27 Register Commands 3-27 Buffer Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 Reading/Writing to Hard Disk with 5-29 4 Logic Board Test Procedures 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-12 Turn On/Turn Off Program 4-12 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Floppy Disk Diagnostics 3-6 Main Menu Diagnostics Summary 3-6 Diagnostic Subtest Summary 3-7 Diagnostic Test Descriptions 3-9 Expert Mode Diagnostics Program 3-24 Disk Drive Commands 3-26 Read and Write Commands 3-26 Seek and Step Commands 3-27 Register Commands 3-27 Buffer Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-15 Page Status Test 4-17 | | | | | Main Menu Diagnostics Summary Diagnostic Subtest Summary Diagnostic Test Descriptions Expert Mode Diagnostics Program Disk Drive Commands Read and Write Commands Seek and Step Commands Seek and Step Commands Seek and Step Commands Seek Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Reading/Writing to Hard Disk with Expert Mode 4-1 Data Test Address Test Feror Loops RAM EPROM Program Debugger Program Debugger Program Machine Language Programming Definitions Walking Ones Test Program Read/Write Loop Program Parity Test Procedure Page Status Test Page Status Test Page Status Test Page Status Test Page Status Test | | | | | Diagnostic Subtest Summary Diagnostic Test Descriptions Expert Mode Diagnostics Program Josk Drive Commands Read and Write Commands Seek and Step Command Seek and Step Commands | | | | | Diagnostic Test Descriptions Expert Mode Diagnostics Program Joisk Drive Commands Read and Write Commands Seek and Step See | | <b>_</b> | | | Expert Mode Diagnostics Program Disk Drive Commands Read and Write Commands Seek and Step Procedures Seek and Step Commands | | <del>-</del> | | | Disk Drive Commands 3-26 Read and Write Commands 3-26 Seek and Step Commands 3-27 Register Commands 3-27 Buffer Commands 3-28 Miscellaneous Commands 3-29 Reading/Writing to Hard Disk with Expert Mode 3-29 Address Test 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-15 Page Status Test 4-17 | | | | | Read and Write Commands Seek and Step Commands Register Commands Buffer Commands Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode Logic Board Test Procedures Map RAM EPROM Program Data Test Address Test Error Loops RAM EPROM Program Error Loops Debugger Program Machine Language Programming Definitions Walking Ones Test Program Read/Write Loop Program Read/Write Loop Program Parity Test Procedure 4-15 Page Status Test 4-27 4-17 | | | | | Seek and Step Commands Register Commands 3-27 Buffer Commands 3-28 Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Map RAM EPROM Program Data Test Address Test 4-3 Error Loops Frogram Program Poebugger Program A-5 Debugger Program A-6 Machine Language Programming A-9 Walking Ones Test Program A-12 Read/Write Loop Program A-12 Read/Write Loop Program A-14 Parity Test Procedure A-15 Page Status Test A-2 A-10 A-20 A-11 A-11 A-11 A-11 A-11 A-11 A-11 A-1 | | | | | Register Commands Buffer Commands 3-28 Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 4 Logic Board Test Procedures Map RAM EPROM Program Data Test Address Test Fror Loops Fror Loops AAM EPROM Program Fror Loops Debugger Program Definitions Walking Ones Test Program Walking Ones Test Program Read/Write Loop Program Parity Test Procedure Fage Status Test F | | | | | Buffer Commands Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures Map RAM EPROM Program 4-1 Data Test Address Test Error Loops Family Program 4-5 Debugger Program Machine Language Programming Machine Language Program Malking Ones Test Program Walking Ones Test Program 4-12 Read/Write Loop Program 4-14 Parity Test Procedure 4-15 Page Status Test | | | | | Miscellaneous Commands Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test | | | | | Reading/Writing to Hard Disk with Expert Mode 3-29 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | 3-29 | | 4 Logic Board Test Procedures 4-1 Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | Expert Mode | 3-29 | | Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Map RAM EPROM Program 4-1 Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | 4 | Logic Board Test Procedures | 4-1 | | Data Test 4-2 Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | • | | | | Address Test 4-3 Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Error Loops 4-4 RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | RAM EPROM Program 4-5 Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Debugger Program 4-6 Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Machine Language Programming 4-9 Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Definitions 4-9 Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Walking Ones Test Program 4-12 Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Read/Write Loop Program 4-12 Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Turn On/Turn Off Program 4-14 Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Parity Test Procedure 4-15 Page Status Test 4-17 | | | | | Page Status Test 4-17 | | | | | | | | | | | | MMUERR* Test | 4-18 | | Dummy DMA Test Procedure 4-19 | | | | # Contents | | Floppy Disk Recalibration | | |---|-----------------------------------|-------------| | | Procedure | 4-20 | | | Floppy Disk Read Track Procedure | 4-23 | | | Seek Command | 4-25 | | | Read Address Command | 4-25 | | | Floppy Write Sector Procedure | 4-27 | | | Initialize Floppy Program | 4-27 | | | DMA Looping Program | 4-29 | | | Hard Disk Registers | 4-29 | | | WD1010 Command Register (E0000E) | 4-31 | | | Commands in Hexadecimal | 4-31 | | | Write Precompensation Register | | | | (E00002, Write Only) | 4-33 | | | Error Register (E00002, Read | | | | Only) | 4-34 | | | Status Register (E0000E, Read | | | | Only) | 4-34 | | | Hard Disk Recalibration Procedure | 4-35 | | | Procedures for Reading/Writing | | | | Data to Any Sector | 4-36 | | | Read Data to Any Sector | 4-36 | | | Write Data to Any Sector | 4-38 | | | Signals to Check if Procedures do | | | | not Execute | 4-39 | | | Hard Disk Data Separator Test | 4-40 | | | Dialer Test | 4-42 | | | Waveform Timing Analysis | | | | Procedure | 4-42 | | | Logic Analyzer Setup | 4-43 | | | Typical Waveforms | 4-44 | | | 68010 Timing Summary | 4-50 | | | | | | | | | | Α | PAL Equations | A-1 | | В | Mnemonics | B-1 | | С | Expansion Memory Locations | C-1 | | | • | | | | | <del></del> | | | Figures | | | | 1-1 Base Unit, Keyboard and | | | | Mouse | 1-2 | | | 1-2 Keyboard Layout | 1-5 | | | 1-3 Keyboard and Mouse | | | | Connections | 1-6 | | | 1-4 RS-232-C Cabling | 1-8 | | | 1-5 Loopback Plug Pinning | 1-9 | | | | | | Figu | r <b>es</b> (Continued) | | |------|-----------------------------------------|--------------| | 1-6 | Logic Boord | 1-14 | | 1-7 | Logic Board<br>Bus System Block Diagram | 1-14 | | 1-8 | System Control Block Diagram | 1-18 | | 1. 0 | byscem control block bragiam | 1 10 | | 2-1 | System Bus | 2-10 | | 2-2 | Parity Generator | 2-28 | | 2-3 | Floppy Disk Write Timing | 2 76 | | 2-4 | Diagram<br>Screen Layout | 2-76<br>2-79 | | 2-5 | State Signal Generator | 2 13 | | 2 9 | Timing | 2-81 | | 2-6 | UNIX PC to Terminal Cable | | | | Pinning | 2-92 | | 2-7 | | 2-92 | | 2-8 | | 2-102 | | 2-9 | Printer Cable Pinning | 2-103 | | 3-1 | LED Locations and Off/On | | | - | Patterns | 3-5 | | | | | | 4-1 | | 4-44 | | 4-2 | Timing of DTACK (210 ns) | 4-45 | | 4-3 | Timing of LDS and UDS | 4 45 | | 4-4 | (230 ns) | 4-45 | | 4-4 | DTACK Latched by Processor (260 ns) | 4-46 | | 4-5 | AS, LDS, and UDS Deasserted | 1 10 | | | by Trailing Edge of Next | | | | 1PCK (380 ns) | 4-46 | | 4-6 | Length of Machine Cycle | | | | (400 ns) | 4-47 | | 4-7 | Timing of LDS and UDS During | | | | a Read Operation (130 ns) | 4-47 | | 4-8 | Slow Cycle Timing of AS | 4 40 | | 1-0 | (130 ns)<br>Timing of DTACK (710 ns) | 4-48<br>4-48 | | 4-10 | DTACK Latched by Processor | 1 10 | | 4 10 | (760 ns) | 4-49 | | 4-11 | AS, LDS, and UDS Deasserted | | | | by Trailing Edge of Next | | | | 1PCK (880 ns) | 4-49 | | 4-12 | Slow Cycle Ends (Complete | | | | Cycle = 1.0 us) | 4-50 | | | 68010 to DRAM Write Cycle | 4-53 | | 1-11 | 68010 Read Cycle Summary | 4-54 | | Tabl | es | | |------|------------------------------------------------|------| | 1-1 | RS-232-C Signals | 1-7 | | 1-2 | The Parallel Interface | 1-10 | | 1-3 | | 1-19 | | 1-4 | | 1-20 | | 1-5 | Hard Disk Drive | 1-20 | | 1-6 | Floppy Disk Drive | 1 20 | | | (Winchester) | 1-24 | | | , | | | 2-1 | 68010 Processor Pin | | | | Functions | 2-3 | | 2-2 | Significant Address Decoding | 2-6 | | 2-3 | Bus Master Priorities | 2-11 | | 2-4 | Summary of Address Bit | | | | Assignments | 2-20 | | 2-5 | Row Address Strobing | 2-25 | | 2-6 | General Status Register | | | | Address 410000 (Read Only) | 2-33 | | 2-7 | Bus Status Register 0 | | | | Address 430000 (Read Only) | 2-34 | | 2-8 | Bus Status Register 1 | | | | Address 440000 (Read Only) | 2-35 | | 2-9 | General Control Register | | | | Address E4X000 (Write | | | | Only) | 2-36 | | 2-10 | Miscellaneous Control | | | | RegisterAddress 4A0000 | 2 25 | | 2 11 | (Write Only) | 2-37 | | 2-11 | Interrupt Vector Numbers and | 2 41 | | 2 12 | Hexadecimal Offsets | 2-41 | | 2-12 | Interrupts and Their | 2 42 | | 2.12 | Priority Levels | 2-42 | | 2-13 | Disk Control Register<br>Address 4E0000 (Write | | | | Only) | 2-46 | | 2-14 | Miscellaneous Control | 2-40 | | 2 17 | RegisterAddress 4A0000 | | | | (Write Only) | 2-47 | | 2-15 | Line Printer Status | 2 1/ | | 2 10 | RegisterAddress 4A0000 | | | | (Write Only) | 2-48 | | 2-16 | Pin Functions WD1010 | 2-49 | | | Task File Registers | 2-52 | | 2-18 | WD1010 Commands | 2-54 | | | DMA Address Count Register | | | | Selection | 2-55 | | 2-20 | Disk DMA Count Register | | | | Address 460000 | 2-56 | | Tables (Continued) | | |----------------------------------------------------------------------------------------|--------------| | 2-21 Signal Status to Assert MREG WR* | 2-57 | | 2-22 Signal Status to Assert<br>HDCTLWR* | 2-58 | | 2-23 Signal Status to Assert DCNTCS* | 2-60 | | 2-24 Pin Functions WD2797 | 2-70 | | 2-25 WD2797 Registers<br>2-26 WD2797 Commands | 2-72<br>2-73 | | 2-27 Signal Status to Generate | | | BMSEL<br>2-28 Multiple Select Status | 2-82<br>2-83 | | 2-29 Bit Map Address Multiplex Assignments | 2-84 | | 2-30 Address Status to Select | | | Telephony Control Register 2-31 Telephony Control Register | 2-88 | | Address 49X000 | 2-89 | | 2-32 Telephony Status Register<br>Address 450000 (Read Only) | 2-90 | | 2-33 RS-232-C Signals | 2-91 | | 2-34 7201 Registers<br>2-35 Modem Registers | 2-95<br>2-98 | | 2-36 Address Status to Select<br>Modem and Dialer Network | | | Control Signals | 2-99 | | 2-37 I/O Ports<br>2-38 Line Printer Status | 2-100 | | RegisterAddress 470000 | | | (Read Only) 2-39 Realtime Clock Interface | 2-102 | | Address 480000<br>2-40 Keyboard Controller | 2-104 | | Addresses | 2-105 | | 3-1 Read/Write Command Format | 3-26 | | <ul><li>3-2 Seek and Step Command Format</li><li>3-3 Register Command Format</li></ul> | 3-27<br>3-28 | | <ul><li>3-4 Buffer Command Format</li><li>3-5 Miscellaneous Command Format</li></ul> | 3-28<br>3-29 | | 4-1 Logic Board LED States | 4-2 | | 4-2 Program Instructions | 4-10 | | 4-3 Read/Write Loop Program 4-4 WD2797 Pin Listing | 4-13<br>4-22 | | 4-5 Bit Number | 4-31 | # Contents | Tables (Continued) | | |-----------------------------------------------|------| | 4-6 Read Sector Commands | 4-32 | | 4-7 Write Sector Commands | 4-32 | | 4-8 SDH Byte Register (E0000C,<br>Read/Write) | 4-33 | | 11000) | | #### 1 System Features and Functions The UNIX PC is an intelligent desktop workstation that provides users with personal computing and enhanced voice and data communications services. It provides the UNIX System V virtual memory operating system in a telephone network environment. The UNIX PC can connect to a telephone system to allow communication with other telephones, workstations, and computers. Direct connection, or connection through a local area network, to other terminals, workstations, or computers, is also provided. The UNIX PC can be upgraded to a multiuser system. The UNIX PC consists of the following parts, as illustrated in Figure 1-1: - o Base unit - o Kevboard - o Mouse The workstation base unit houses the monitor, power supply, hard disk drive, floppy disk drive, logic board, and three expansion slots. The logic board provides the processor logic, bit-mapped graphics logic, communications, and interface logic for all connected input/output (I/O) devices. The monitor is attached to a base that allows it to tilt and swivel. Figure 1-1 Base Unit, Keyboard, and Mouse ### Functional Specifications These specifications describe the major circuitry and general characteristics of the UNIX PC system. ## Logic Board The Logic Board is shown in Figure 1-4. - Motorola 68010 central processing unit (CPU) with 10-megahertz (MHz) clock - Virtual memory address space of 4 megabytes (MB) - o 0.5MB, 1 MB standard or 2 MB random access memory (RAM) - o 720 by 348 bit-mapped graphics monitor interface - o DTE RS-232-C serial port - o Centronics-compatible parallel printer port - o Keyboard interface - o Telephone interfaces for voice and data service. Three modular jacks are used: one for connection to a user-provided telephone and the other two for connection to tip/ring telephone lines. Also included is an integrated 300/1200 bits per second (bps) modem compatible with AT&T Models 103 and 212, offering asynchronous operation and autobaud capabilities. - o Hard disk interface - o Floppy disk interface - o Expansion bus interface that allows memory and I/O expansion. The bus has 21 address lines and 16 data lines and supports bus mastership by expansion hardware - $\boldsymbol{o}$ A realtime clock that retains the time and date when the $\boldsymbol{UNIX}$ PC is powered down ### Terminal Subsystem The monitor contains a 12-inch cathode ray tube (CRT), a deflection board, and a yoke. It provides a 20-MHz screen capable of displaying 720 by 348 pixels. The display can be programmed either as light on dark (normal) or dark on light (inverse video). The monitor is attached to the base. The monitor tilts -5 to +20 degrees relative to the horizontal plane and swivels. The screen is treated to reduce glare. A brightness control is accessible to the operator, as shown in Figure 1-1. ### Keyboard The keyboard is shown in Figure 1-2. The keyboard is connected to the base with a flexible, coiled cord that can expand to approximately six feet. One end of the cord has about an inch of straight cord that plugs into the base unit. Both ends of the cable have connectors that prevent accidental disconnection. Figure 1-2 Keyboard Layout ### Mouse The mouse connects to the keyboard unit with a lightweight, uncoiled cord that is approximately four feet long. The cable has a connector that locks preventing accidental disconnection. The cord plugs into the keyboard. These connections are shown in Figure 1-3. Figure 1-3 Keyboard and Mouse Connections ### Audible Indicator An audible indicator consisting of a small speaker is provided for monitoring telephone calls when using the AT&T UNIX PC Telephone Manager. A user-accessible slide volume control, illustrated in Figure 1-1, is located just under the right edge of the base unit. #### Data Storage Data can be stored either on a hard disk which is part of the UNIX PC system, or on floppy disks using the floppy disk drive. The storage capacities available are: - o A 10MB, 20MB, 40MB or 67MB hard disk (Winchester) for mass storage - o A double-sided, 1/2-MB (320 Kb formatted), 5 1/4-inch, 48-tpi floppy disk drive #### RS-232-C Port The RS-232-C port supports both synchronous and asynchronous data communications. Asynchronous bit rates of 110 bps to 19.2 Kbps are available. ### RS-232-C Signals The following table of signals applies to the RS-232-C connector. The table gives the pin number, signal name, and direction for the UNIX PC. Table 1-1 RS-232-C Signals | Pin | Name | Direction | |-----|---------------------|-----------| | 1 | Ground (shield) | - | | 2 | Transmit data | Output | | 3 | Receive data | Input | | 4 | Request to send | Output | | 5 | Clear to send | Input | | 6 | Data set ready | Input | | 7 | Ground (signal) | _ | | 8 | Carrier detect | Input | | 15 | Transmit clock | Input | | 17 | Receive clock | Input | | 20 | Data terminal ready | Output | | 22 | Ring indicator | Input | | 24 | DTE transmit clock | Output | Channel B of the 8274/7201 multiple protocol serial controller is connected to the modem. The following list describes the channel B signals: 8274/7201 Carrier detect <---RS-232-C ring indicator 8274/7201 Receive clock <----Modem receive clock 8274/7201 Clear to send <----RS-232-C data set ready 8274/7201 Transmit data---> Modem transmit data 8274/7201 Transmit clock <---Modem transmit clock 8274/7201 Receive data <----Modem receive data # RS-232-C Signal Levels Figure 1-4 illustrates the possible RS-232-C cabling to a printer or terminal. Signal levels are +/-12V nominal. # UNIX PC to Terminal Cable Pinning | UNIX | PC <u>Terminal</u> | | |------|--------------------|---| | 3 | | | | 4-5 | -6 4-5-6<br>7 | | | 8 | > 20 | | | 20 | < 8 | | | | | _ | # UNIX PC to Printer with CTS Control | UNIX | PC | Printer | |---------------------|----|-----------------| | 2<br>3<br>4<br>6-8- | < | > 3<br>2<br>> 4 | Figure 1-4 RS-232-C Cabling # Diagnostic Loopback Plug The diagnostic floppy tests RS-232-C functions through the use of a loopback plug, which must be installed when a channel is being tested. Loopback plug (male) pinning is shown in Figure 1-5. | 2 | > | 3 | |----|---|----| | 4 | > | 5 | | 4 | > | 8 | | 20 | > | 6 | | 20 | > | 22 | - (2) Transmit data -----> (3) Receive data - (4) Request to send ----> (5) Clear to send - (4) Request to send -----> (8) Carrier detect - (20) Data terminal ready ----> (6) Data set ready - (20) Data terminal ready ---> (22) Ring indicator Figure 1-5 Loopback Plug Pinning #### Centronics Parallel Printer Interface Table 1-2 is an example of how a parallel printer cable might be constructed for a Centronics printer. The UNIX PC has an Amphenol 57 series 36-pin connector. This is a standard Centronics connector. #### Cable Pinning The following guidelines showing the printer signal requirements do not have to be adhered to strictly when building your own cable (in the case of signal ground). Signal ground is tied to pins 16, 17, 19-30, 33, and 36 on the UNIX PC connector. Make sure your printer is strapped for negative strobes and acknowledges. Do not let any signals float. For example, if you are not going to use BUSY+, ground it. This table shows typical pin functions for the Centronics printer cable: Table 1-2 The Parallel Interface | Signal<br>Pin | Return<br>Pin | Signal | Direc-<br>tion | Description | |--------------------------------------|----------------------------------------------|---------------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 19 | STROBE | OUT | Pulse to read data in. Pulse width should be 0.5 ms at the receiving terminal. | | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9 | 20<br>21<br>22<br>23<br>24<br>25<br>26<br>27 | DATA 1 DATA 2 DATA 3 DATA 4 DATA 5 DATA 6 DATA 7 DATA 8 | OUT OUT OUT OUT OUT OUT OUT OUT | These signals represent information of the 1st to 8th bits of parallel data, respectively. Each signal is at HIGH level when data is logical 1 and LOW when it is logical 0. | | 10 | 28 | ACKNLG | IN | Approximately 12- microsecond pulse. LOW indicates that data has been received and that the printer is ready to accept more data. | | 11 | 29 | BUSY | IN | A HIGH signal indicates that the printer cannot receive data. The signal goes HIGH in the following cases: o During data entry o During printing o When offline o During printer -error state | | 12 | 30 | PE | IN | A HIGH signal indicates that the printer is out of paper. | Table 1-2 The Parallel Interface (Continued) | [ | T | | I | <b></b> | | |---------------|---------------|--------------|----------------|-------------------------------------------------------------------------------------------|--| | Signal<br>Pin | Return<br>Pin | Signal | Direc-<br>tion | Description | | | 13 | | LP SELECT | IN | Pulled up to +5 volts<br>through a 1K-ohm<br>resistor. | | | 14 | | AUTO FEED XT | OUT | This signal is pulled up to +5 volts through a 1K-ohm resistor. | | | 15 | | NC | | Unused. | | | 16 | | ov | | Logic ground level. | | | 17 | | CHASSIS GND | | Printer's chassis<br>ground, which is<br>isolated from the logic<br>ground. | | | 18 | | NC | | Unused. | | | 19-30 | | GND | | Twisted-pair return signal ground level. | | | 31 | | INIT | OUT | This signal is pulled up to +5 volts through a 1K-ohm resistor. | | | 32 | <u> </u> | ERROR | IN | This level becomes LOW when the printer is in: o Paper-end state o Offline o Error state. | | | 33 | | GND | | Same as for pins 19-30. | | | 34 | | NC | | Unused. | | | 35 | | NC | | Unused. | | | 36 | | SLCT IN | OUT | Signal ground level. | | #### Notes - o The column heading "Return" denotes the twisted-pair return, to be connected at signal ground level. For the interface wiring, be sure to use a twisted-pair cable for each signal and to complete the connection on the return side. To prevent noise, these cables should be shielded and connected to the chassis of the host computer and the printer, respectively. - o The column heading "Direction" refers to the direction of signal flow as viewed from the base unit. - o All interface conditions are based on TTL level. The rise and fall times of each signal must be less than 0.2 microseconds. ## Status Signal Description - LPNOPAPER+: Centronics pin 12, asserted by printer when paper-out sensor senses no paper in the printer. - o LPBUSY+: Pin 11, asserted by the printer to indicate that it cannot receive data. Also indicates a paper empty or fault condition. - o LPSELECT+: Pin 13, asserted by printer to indicate that it is selected and ready to receive data. - ERROR\*: Pin 32 asserted when there is a problem with the printer. - LPACK\*: Pin 10, asserted by line printer to indicate that it has received data. #### **Expansion Slots** Three expansion slots are provided as part of the base unit. Expansion cards can be installed in any slot. However, depending on the memory being added, they must be located in accordance with the expansion memory location matrix in Appendix C. Expansion slots support expansion boards including those listed below: - o 0.5MB or 2MB expansion RAM board - o Three versions of combo boards - 0.5MB, 1MB or 1.5MB with two RS-232 ports - o MS-DOS expansion board - o Two port RS-232 only board - o Interface board for tape backup (floppy tape) - o Interface board for tape backup (QIC-02) Expansion boards may dissipate up to 12 watts each. ### Physical and Electrical Specifications The basic characteristics of the UNIX PC are: - o Base unit: Approximately 18 inches wide, 17 inches deep, and 16 inches high; weighs approximately 40 pounds. - o Keyboard: AT&T 103-key, low-profile design. - o Electrical: 100-130 volts; maximum power under 400 watts. ### Logic Board Bus System This section describes the logic board bus system, including the address and data bus and the system control block diagram, which explains how bus transfers are regulated. Figure 1-6 shows the layout of the UNIX PC logic board. Figure 1-6 Logic board ### Simplified Address and Data Block Diagram The system block diagram in Figure 1-7 shows how the system bus allows the various devices within the UNIX PC CPU board to transmit data to each other. The right half of the drawing shows the peripheral devices. Each peripheral has special control interface circuitry that modifies information coming from or going to the peripheral into a form that is acceptable for the bus and the peripheral. These circuits are indicated in the drawing by the rectangular boxes marked bit map, printer port, telephony controller, and so on. The bus accepts data 16 bits wide. The keyboard, for example, generates data in the form of a serial bit stream. These control interface circuits also receive control signals that initiate and terminate data transfers. The left half of Figure 1-5 shows devices that do internal information processing. These include the 68010 CPU and the three forms of memory: ROM, RAM, and disk storage. The bus itself is really two buses, a data bus and an address bus. The data bus consists of 16 bits, labeled D0-D15, for transmission of 16-bit data words. The address bus consists of 23 bits, labeled A1-A23. (There is an A0 function that is internal to 68010.) Data transfers on the UNIX PC bus are performed using a master-slave system. A master device such as the 68010 begins a transfer by first putting an address on the address bus to identify the device with which it will perform a data transfer. Then, depending on the direction of the data transfer, either master-to-slave or slave-to-master data is loaded onto the data bus, and the transfer takes place. In the UNIX PC, the 68010 and the DMA (direct memory access) controller are both masters. There are other possible masters that are not shown for simplicity. Any of the devices on the right side of the drawing can be slaves to the 68010. The DMA controller for the disk drives transfers data only to RAM memory, so it has only one slave. Before starting a DMA transfer, the 68010 must load information into the DMA controller, in which case the DMA controller is acting as a slave to the 68010. During the transfer, the DMA controller generates appropriate control signals that cause the transfer to begin and end and also determine the direction of the transfer, either from master to slave or slave to master. On the drawing, arrows indicate the direction of transfer. Notice that the address bus differs from the data bus in that the address bus allows only a one-way transfer of information, from master to slave. The data bus allows two-way transmission, as indicated by the arrows. Figure 1-7 Bus System Block Diagram ### Onboard Memory Memory in the UNIX PC consists of both Random Access and Read Only memory, both are located on the logic board. ### Random Access Memory The logic board provides a minimum of 512 KB of onboard RAM, which can be expanded to either 1 or 2 MB maximum. A minimum memory configuration is made up of 72 type 4864, 64K by 1-bit dynamic RAM chips. The 1MB logic board is made up of 36 type 4256, 256K by 1 bit, dynamic RAM chips. The 2MB logic board is made up of 72 type 4256, 256K by 1 bit, dynamic RAM chips. The memory is used for program execution. It is organized into a virtual memory system, which allows the programmer to write programs as if there were a much larger amount of memory available than is physically present. The UNIX PC virtual memory system is 4 MB. The hardware provides this function through a special set of memory chips called page map RAMs. These RAMs are 1K by 4-bit static RAM chips. ### Read Only Memory The logic board contains two 2764 8-KB or two 27128 16-KB ROM chips. They hold the initialization program that is run when the power is turned on or the Reset button is pressed, or a software reboot command is exercised. #### System Control Block Diagram The system control block diagram, Figure 1-8, shows how the system determines which bus master controls the bus at any given time. There are three elements to system control: interrupt, memory management, and bus arbitration. The right side of the drawing shows the I/O controller logic. When a peripheral device such as the keyboard wants to send data to the system, its controller sends an interrupt signal to the interrupt logic. This is one method of communication between an I/O device and the system. Figure 1-8 System Control Block Diagram The interrupt signal is compared to a priority list. The highest priority pending at any given time causes the interrupt logic to send a signal to the 68010. The 68010 then responds by performing a sequence of data movements called an <u>interrupt</u> processing sequence. The function of the interrupt acknowledge is to allow the processor to store its current status so it can return to the same state after responding to the interrupt. First it completes execution of its current instruction and stores the status of its internal registers. Then it jumps to an interrupt service program that determines which device generated the interrupt. Finally, it jumps to a program to service that particular interrupt. Interrupt priorities are listed in Table 1-3. Priority Level Device (highest) Parity error or MMU error (logic board) 6 60-Hz (logic board) 5 Expansion slots 1, 2, and 3 4 8274/7201 communication (detection circuit, RS-232-C) 3 Keyboard/mouse, modem 2 Hard disk drive, floppy disk drive, or line Expansion slots 1, 2, and 3 1 (lowest) Table 1-3 Interrupt Priorities Note: Levels 1 and 5 are available to expansion slots 1, 2, and 3. ### Memory Management A second element of system control is the memory management unit shown on the left in Figure 1-6. This unit monitors every access to the dynamic RAM memory chips. Certain accesses cause a memory management error. For example, if a user program attempts to write to a memory address that has been defined as being in disk address space and not in physical RAM, the memory management unit generates a signal called a <u>bus error</u>. #### Bus Arbitration At some point two bus masters will both want control of the bus. The third element of system control, the bus arbitration unit, resolves the conflict. It evaluates requests for bus control from masters and grants bus control on a priority basis. The 68010 has lower priority than the disk controller. The 68010 has to wait for the disk controller to release control of the bus before it can take control. Table 1-4 Bus Arbitration Priorities | Priority<br>Level | <u>Device</u> | |-----------------------------------------------|-----------------------------------------------------------------------------------------------------| | 6 (highest)<br>5<br>4<br>3<br>2<br>1 (lowest) | Refresh Expansion slot 1 Disk Interface Hard and Floppy Expansion Slot 2 Expansion Slot 3 68010 CPU | # Data Storage Device Specifications The following tables list specifications for both types of storage device used on the UNIX PC system. These tables are arranged by manufacturer for each drive offered on the Model 7300 and 3Bl machines. Table 1-5 Hard Disk Drive | Manufacturer | Specifications | | | | | |--------------|----------------|-------------|-----|--------|----------------------------------------------------------| | Miniscribe | Capacity | Unformatted | Per | Drive | 12.0 MBytes<br>25.0 MBytes<br>53.0 MBytes<br>85.0 MBytes | | | | | Per | Track | 10,416 Bytes | | | | Formatted | Per | Drive | 10.0 MBytes<br>20.0 MBytes<br>44.0 MBytes<br>67.0 MBytes | | | | | Per | Sector | 8,192 Bytes<br>r 512 Bytes<br>er Track 16 | Table 1-5 Hard Disk Drive (Continued) | Manufacturer | Specific | cations | |-----------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Miniscribe<br>(cont.) | Functional | Rotational Speed (RPM) 3600 Recording Density (bpi) 10,030 for 10, 20MByte Drives 9,950 for 40, 67MByte Drives Area Density (M/bit/sq/in) 5.9 Track Density (tpi) 588 for 10, 20MByte Drives 1000 for 40, 67MByte Drives Total Data Tracks 2,448 Cylinders 612 for 10, 20MByte Drives 1024 for 40, 67MByte Drives R/W Heads 10MByte 2, 20MByte 4, 40MByte 5, 67MByte 8 | | | Data Transfer Rate | (Mbits per second) 5.0 | | | Access Time (includes | settling) | | | | 10 and 20MByte Average (msec) 85 Track-to-Track (msec) 15 Maximum (msec) 190 Latency (average, msec) 190 40 and 67MByte | | | | Average (msec) 30 Track-to-Track (msec) 3 Maximum (msec) 60 Latency (average, msec) 60 | | | Interface | ST412 | | | Error Rates<br>Soft Read Error:<br>Hard Read Error:<br>Seek Errors per | s 1 per 10 <sup>10</sup> bits transferred<br>s 1 per 10 <sup>12</sup> bits transferred<br>10 <sup>6</sup> seeks | Table 1-5 Hard Disk Drive (Continued) | Manufacturer | Specifications | | | |-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Miniscribe<br>(cont.) | DC Power Requirements 10MByte +5V DC +/- 5%, 0.75 amps +12V DC +/-5%, 0.75 amps 20MByte +5V DC +/- 5%, 0.4 amps +12V DC +/-5%, 1.0 amps 44MByte +5V DC +/- 5%, 0.6 amps +12V DC +/-5%, 1.0 amps 67MByte +5V DC +/- 5%, 0.6 amps +12V DC +/-5%, 2.0 amps Max Starting (10 sec) 3.5 amps Power Dissipation 14 watts | | | | | | | | Table 1-5 Hard Disk Drive (Continued) | Manufacturer | Specifi | cations | | |--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Hitachi | Capacity Unformatted | Per Drive 51.0 MBytes | | | | | Per Track 10,416 Bytes | | | | Formatted | Per Drive 40.0 MBytes | | | | | Per Track 8,192 Bytes<br>Per Sector 512 Bytes<br>Sectors per Track 16 | | | | Functional | Rotational Speed (RPM) 3600 Recording Density (bpi) 9,340 Area Density (M/bit/sq/in) 5.9 Track Density (tpi) 784 Total Data Tracks 2,448 Cylinders 714 R/W Heads 7 Disks 2 | | | | Data Transfer Rate | (Mbits per second) 5.0 | | | | Access Time (includes | settling) | | | | | Average (msec) 30<br>Track-to-Track (msec) 8<br>Maximum (msec) 55 | | | | Interface | ST412 | | | | Error Rates Soft Read Errors 1 per 10 <sup>10</sup> bits transferre Hard Read Errors 1 per 10 <sup>12</sup> bits transferre Seek Errors per 10 <sup>6</sup> seeks | | | | | | 0.4 amps typical<br>1.0 amps typical | | | | Power Dissipation | 14 watts | | Table 1-6 Floppy Disk Drive (Winchester) | Manufacturer | Specifi | cations | |--------------|----------------------|----------------------------------------------------------------------------------------------| | Teac | Capacity Unformatted | Per Disk Single Density<br>250KBytes | | | | Per Disk Double Density<br>500KBytes | | | | Per Track<br>3,125KBytes Single Density,<br>6.25KBytes Double Density | | | Formatted | Per Disk Single Density<br>163.84KBytes | | | | Per Disk Double Density 327.68KBytes | | | | Per Track Single Density 2,048KBytes | | | | Per Track Double Density<br>4,096KBytes | | | | Per Sector Single Density<br>256 Bytes | | | | Per Sector Double Density<br>512 Bytes | | | | Sectors per Track 8 | | | Functional | Rotational Speed (RPM) 300 Recording Density (bpi) Single Density 2,938 Double Density 5,876 | | | | Area Density (M/bit/sq/in) 5.9 Track Density (tpi) 48 Total Data Tracks 80 | This overview summarizes the major functions performed by the logic board hardware. In addition, it describes the boot ROM program algorithm. The logic board hardware functions include: - Direct memory access and bus arbitration - o Machine cycle timing - o Memory management - o Input/output handling # Direct Memory Access The UNIX PC bus is shared by the 68010 central processing unit (CPU) and several direct memory access (DMA) devices, such as the disk bus interface unit, dynamic RAM refresh, and expansion boards. During a DMA transfer, the 68010 waits while data is moved directly from a DMA device, such as the disk bus interface unit, into RAM memory. DMA provides high-speed transfer of blocks of data to or from memory. ## Machine Cycle Timing A 68010 machine cycle consists of putting an address on the bus, transferring data, and releasing the bus. Machine cycles are either fast (400 nanoseconds) or slow (1100 ns). Access to the lower half of the address space results in a fast cycle; access to the upper address space results in a slow cycle. DMA machine cycles are considered fast (500 ns). The additional 100 ns is needed in this case to do bus arbitration. # Memory Management Programs run on the UNIX PC are often too large to fit in the RAM memory chips on the logic board. Thus, when the system is booted up, only a portion of the program is loaded into memory. While the program is being executed, it is monitored by memory management hardware. When a portion of the program that is on the disk is needed, the memory management hardware generates an error, causing the DMA to move the required portion of the program from the disk drive into RAM memory. The processor can address locations anywhere in the entire 16 megabytes (MB) of system space, but the DMA can access only the lower 1/4 of system address space that is used by RAM (physical memory space). ## Input/Output Handling Input and output (I/O) operations are memory mapped--that is, the 68010 does not have separate instructions for I/O operations. I/O ports are accessed by assigning addresses to them. I/O operations are handled either by interrupt or by polling. Polling is used in boot ROM programs where stack operations are forbidden. Table 2-1 lists the 68010 processor pin functions. # Boot ROM Algorithm The boot ROM is used for program memory following power up, hard reset (reset switch), or a software generated re-boot. The boot ROM program tests memory. Then it initializes the logic board by initializing the status of the memory management hardware and various peripheral controller chips. Then it causes a program to be loaded from floppy or hard disk and jumps to that program. Table 2-1 68010 Processor Pin Functions | | | T | |--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Pin No. | Mnemonic | Description | | 29-52 | A1-A23 | 23-bit address bus (outputs only)A unidirectional, three-state bus capable of addressing 16 MB of data. Provides addressing for all CPU cycles except space cycles. | | 1-5<br>54-64 | D0-D15 | 16-bit data busBidirectional, three-<br>state bus that is the general-purpose<br>data path. Transfers either words or<br>bytes. | | 6 | AS | Address strobeSignal indicating there is a valid address on address bus. | | 7-8 | UDS, LDS | Upper and lower data strobesSignals used with R/W to control data flow on the data bus. UDS enables the upper byte; LDS enables the lower byte. When both are active, words are transferred. | | 8 | R/W | Read/Write Defines the data bus transfer as a read or write cycle. | | 10 | DTACK | Data transfer acknowledgeInput indicating that a data transfer has been completed. When received during a read cycle, data is latched one clock cycle later and the bus cycle is terminated. When received during a write cycle, the bus cycle is terminated. | | 13 | BR | Bus requestNot used | | 11 | BG | Bus grantNot used | | 12 | BGACK | Bus grant acknowledgeNot used | Table 2-1 68010 Processor Pin Functions (Continued) | Pin No. | Mnemonic | Description | | | | | |---------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 23-25 | IPLO, IPL1, IPL2 | Interrupt priority level 0-2Inputs indicating the encoded priority level of the device requesting to interrupt the CPU. Level 7 has highest priority, and level 0 indicates no interrupts present. Level 7 cannot be masked. These inputs must remain stable until the processor acknowledges, which is accomplished by setting FCO-FC2 and A04-A23 high. | | | | | | 26-28 | FC0,FC1,FC2 | Function code 0-2Outputs activated along with address strobe to indicate the state (user or supervisor) and the cycle type currently being executed. | | | | | | | | FC2 FC1 FC0 Cycle Type Low Low Low (Undefined) Low Low High User data Low High Low User program Low High High (Undefined) High Low Low (Undefined) High Low High Supervisor data High High Low Supervisor program High High High CPU space | | | | | | 15 | CLK | Clock10-MHz input, internally buffered for development of timing needed internally by the processor. | | | | | | 20 | E | EnableNot used | | | | | | 19 | VMA | Valid memory addressNot used | | | | | | 21 | VPA | Valid peripheral addressAsserted during an interrupt cycle to inform the CPU that the current interrupt cycle is an autovector cycle. As implemented in the UNIX PC, all interrupts are autovectored. | | | | | Table 2-1 68010 Processor Pin Functions (Continued) | Pin No. | Mnemonic | Description | |---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 22 | BERR | Bus errorInput informing the CPU that there is a problem with the current cycle. Most commonly used when applied memory address is not in primary memory. | | 17 | HALT | HaltBidirectional. When used as input, the processor floats all outputs and stops at the completion of the current bus cycle. Other uses are described below. | | 18 | RESET | ResetBidirectional signal that resets the system upon power up or pressing the Reset button. The reset and halt inputs are tied together to ensure a total processor reset. Pressing the Reset button for 10 clock cycles causes a total system reset. Upon power up, reset and halt must be driven low for at least 100 ms. A software reset causes the reset signal to be driven for 124 clock cycles. | # Note An alphabetical listing of mnemonics used in this section appears in Appendix B. # Fast and Slow Cycles 68010 machine cycles are either fast (400 ns) or slow (1100 ns) depending on the address being accessed. The slow cycle is achieved by delaying the arrival of <u>data transfer acknowledge</u> (DTACK) to the 68010. A custom IC containing the timing circuit determines how much delay to provide through address decoding. DMA machine cycles are fast (500 ns) transfers between the DMA devices and RAM memory or refresh of RAM memory. Table 2-2 shows how the two most significant address bits are decoded to select fast or slow cycles: | A23 | A22 | Region Description | |-----|-----|----------------------------------------------------------------| | 0 | 0 | RAM memory: fast-cycle access by 68010 user or supervisor mode | | 0 | 1 | I/O registers: fast-cycle 68010 access in supervisor mode only | | 1 | 0 | ROM memory: slow-cycle 68010 read in supervisor mode only | | 1 | 1 | I/O registers: slow-cycle 68010 access in supervisor mode only | Table 2-2 Significant Address Decoding From the program execution viewpoint, fast and slow cycle transfers are identical. An instruction is executed in the same way except that the CPU waits longer for an acknowledge signal during slow-cycle transfers. The CPU adjusts the length of its machine cycle to meet the requirements of the bus. It drives address and control signals and waits for DTACK data transfer acknowledge (pin 10). The 68010 is clocked by a 10-MHz signal called 1PCK. 1PCK is a 50% duty cycle clock with a full-cycle duration of 100 ns. The CPU uses four PCK cycles to accomplish a fast bus cycle. These four cycles are used as eight states (S0-S7) by the 68010: The CPU samples DTACK\* at the trailing edge of S4. If DTACK\* is present at the trailing edge of S4, the CPU latches data (for a read), tristates control signals at the trailing edge of S6, and tristates its address lines at the trailing edge of S7. If DTACK\* is not present, the processor begins inserting wait states and sampling DTACK\* at the trailing edge of each succeeding 1PCLK. When DTACK\* arrives, the processor behaves as described in the preceding paragraph. For a slow processor cycle, the hardware simply prevents the generation of DTACK\* for an extra six clock cycles. The extra time is allotted for the slow response of the ROM and I/O devices. This describes the difference between a fast cycle and a slow cycle. 68010 CPU machine cycles are either instruction fetches or instruction execution cycles. The 68010 outputs status bits that identify the type of cycle being performed. These status bits can be used by a logic analyzer to display only program execution to aid in troubleshooting. #### Clock Generation Sheet 3 refers to schematic sheet 3. Note that integrated circuits (IC) are referred to by their location identifiers. For example, 21F refers to an IC located at position 21F on the logic board. As seen from the front of the UNIX PC, parts on the logic board are identified with two coordinates, numbers from left to right (1-28) and letters from front to back (A-P). System clock signals are generated as follows: - o A 40-MHz oscillator provides the source frequency for the majority of the system clocks. - ${\bf o}$ This frequency passes through OR gate 21F and provides the clock for dual J-K F/F 20G. - o Pins 9 and 7 of 20G output a 20-MHz signal, and pins 5 and 6 output 10 MHz. - These signals are buffered by 19G and output as 20MCK, X20MCK+, XPCK+, PCK\*, 1PCK+ 2PCK+. - o 1PCK+ feeds the clock input of F/F 16K and causes the generation of the 5-MHz signal, 5MCK+. - o 1PCK+ feeds the DMA address IC (22E, sheet 9) and causes the generation of the 1-MHz signal, 1MCK+. ### Bus Arbitration A bus arbitration programmable array logic (PAL) decides which DMA device is granted accesses to the bus when two DMA devices request the bus at the same time. When no DMA devices are requesting the bus, the 68010 controls the bus. #### Bus Masters and Slaves The **UNIX** PC uses a system address and data bus as shown in Figure 2-1. The system bus makes it possible for bus arbitration to switch the bus between several devices, called <u>bus masters</u>. The devices connected to the system bus are classified as either bus masters or bus slaves. In every data transfer, one device is the master and one is the slave. The master outputs the control signal that starts the transfer and provides the address of the device to or from which it wants to transfer data . A bus slave is connected to the bus when an address decoder detects the presence of the address assigned to that device on the address bus. Figure 2-1 shows two bus masters in the UNIX PC system, the 68010 CPU and the disk DMA controller, and a single device to which they can both transfer data, the RAM memory array. When the 68010 CPU transfers data to RAM memory, control signals are asserted that enable the tristate buffers and connect the 68010 address and data lines to the system address and data bus. At the same time, other control signals put the DMA circuits inside the custom DMA address and put data and gate array chips in a tristate condition, thus disconnecting them from the system address and data bus. When the DMA ICs are transferring data between a disk drive and memory, the DMA address counter and data latch are enabled. The 68010 address and data buffers are in a tristate condition. Figure 2-1 System Bus # Arbitration Priority The process of deciding which bus master receives the bus at any given time is called <u>bus arbitration</u>. It takes place in the bus arbitration PAL 25B shown on sheet 2 of the schematics. For a detailed discussion of PALs, refer to Appendix A, PAL Equations. The following table shows how priority is assigned to the various possible bus masters. With the exception of the processor, the other bus masters are DMA. The 68010 issues no bus request; it is granted use of the system bus by default (no other requests are present). | Priority | Bus Master | | | | | | |----------|-------------------------|--|--|--|--|--| | 1 | Disk bus interface unit | | | | | | | 2 | Not used | | | | | | | 3 | Refresh controller | | | | | | | 4 | Expansion board 2 | | | | | | | 5 | Expansion board 1 | | | | | | | 6 | Expansion board 0 | | | | | | | 7 | 68010 | | | | | | Table 2-3 Bus Master Priorities ## Arbitration Signal Sequence When a bus master requires use of the system bus, it issues a bus request to the 25B arbiter. If no higher priority requests are pending, the arbiter sends a bus grant to the requesting circuit. The bus master then sends a bus grant acknowledge back to the arbiter, drops its request, and executes the bus cycle. The bus grant acknowledge latches the bus grant and locks out other requests. When the bus cycle is finished, the bus master drops the bus grant acknowledge and the arbiter drops the grant. The bus arbiter allows continuous transfers to occur. If another transfer is pending at the end of one transfer, the arbiter immediately sends a new bus grant and the next transfer begins. ## Memory: Theory of Operation Onboard memory consists of random access memory (RAM). The logic board contains a minimum of 512K of RAM that can be expanded to 2 MB. The logic board also contains read-only memory (ROM) that holds the initialization program. This program is run when power is turned on or the Reset button is pressed. ### Memory Address The 68010 provides 24 address bits, although address bit 0 does not leave the CPU. This allows the addressing of 16 MB of memory. The data bus contains 16 bits. Memory operations can be performed on either 8-bit bytes or 16-bit words. All memory or register <u>word</u> accesses must be even-byte aligned. This means word instruction address operands must be even numbers. A0 is always zero. Address numbers are six hexadecimal digits from 000000 through FFFFFF. These correspond to 16 MB. Physical memory is organized in 16-bit words. The first word is address 000000, the second is 000002, the third is 000004, and so on. When even-numbered bytes are accessed, the upper half of the data bus D15 to D8 is used. When odd-numbered bytes are addressed, the lower half of the data bus, D7 to D0 is used. The internal address bit A0 is logically equivilent to the $\overline{\text{UDS}}$ (upper data strobe) pin of the 68010. <u>Words</u> are accessed only at even addresses when both $\overline{\text{UDS}}$ and $\overline{\text{LDS}}$ are active. ### Reset Vector Loading When a system is powered or reset, the CPU automatically addresses ROM. A bootstrap routine directs the CPU to initialize the UNIX PC system and read the operating system from the disk. When a system is reset, internal microcode forces the 68010 to read from RAM address 000000. Address 000000 is referred to as the <u>reset vector</u>. The 68010 loads the stack pointer with the values stored in addresses 000000 and 000002. It reads the values stored in addresses 000004 and 000006 and loads them into the program counter. Actual address space for ROM is 800000-BFFFFF. The values necessary to initialize the stack pointer and the program counter are actually at addresses 800000 through 800006. Therefore, during a reset, the hardware is responsible for forcing address bit 23 high, thus causing the processor to refer to ROM. During reset, a signal called ROMLMAP\* is generated and ORed with address bit PA23 (see Sheet 5). Although the processor is addressing 000000, ROMLMAP\* causes the address sent to ROM to be 800000. At this point, the hardware forces the processor into the ROM address space, and no RAM references can be made as long as ROMLMAP\* is active. The boot code is responsible for vectoring the processor into legitimate ROM address space and must also cause the processor to deactivate ROMLMAP\* so RAM can be accessed again. The processor is vectored into legitimate ROM address space by the first instruction executed after the program counter is loaded with the vector address at 800004 and 800006. This value is loaded into the program counter. The processor then fetches and begins instruction execution. Now that the CPU is driving PA23 high, ROMLMAP\* is no longer necessary. In fact, it must be dropped to access RAM. The first instruction, addressed by the reset vector, causes 8000 to be written to address E43000. This deactivates ROMLMAP\*. ## 68010 ROM Read Sequence The system must do a slow-cycle transfer to read ROM. The following description refers to the schematics. Sheet 5--Asserting reset: o Upon power up or depression of the Reset button, the HALT and RST pins of the 68010 are driven low by the power-up detection and reset switch debounce circuit. #### Note At power up, the RST and HALT pins must be low for a minimum of 100 ms. At reset, they must be low for 10 clock cycles. At 60 ns after reset goes high, the CPU outputs the function code--in this case, FC2+, FC1+, and FC0- (supervisor program mode). The processor drives R/W\* high (specifying a read operation) and places the address on the PA bus. Once the processor has been vectored into ROM, PA23 is a 1, and PA22 is a 0. ### Sheet 6--Asserting ROMLMAP\*: ${f o}$ RST\* clears the addressable latch 7K, causing the assertion of ROMLMAP\* from pin 7. Sheet 5--Asserting SPA23 and PDS: - o ROMLMAP\* is inverted to a high by 3K. This is applied to OR gate 13E. When it receives a high from 3K, it generates high output at SPA23. - o At 120 ns the processor asserts AS\*, UDS\*, and LDS\*. LDS\* and UDS\* generate PDS+ via 22D. Sheet 3--Asserting I/ORQ+: o PDS+, SPA23, and an inactive INTA\* cause gate 27F to assert I/ORQ+. Sheet 9--Asserting BGACK\*: o I/ORQ+ causes the DMA address IC to assert BGACK\*. (This DMA address IC is a custom IC. In early versions of the UNIX PC logic boards, a piggyback gate array simulation board was used instead of custom ICs.) Sheet 17--Asserting ROMEN\*: o 1 of 4 decoder 6J is enabled by BGACK\* and addressed by SPA23 and PA22. SPA23 is high and PA22 is low, putting a binary 2 on the address inputs of the decoder. The decoder drives its Q2 output low, asserting ROMEN\*. Sheet 5--Addressing and enabling ROM: - o BGC+ and MRAMEN\* force the output of NAND gate 25N (pin 11) low, enabling address buffers 16F and 17F. Transparent latch 17G is put into its transparent mode by gate 27H, pin 10 \_\_\_\_ (MMUWREN+ and MMUWREND+), and the outputs are enabled by BGC+. - o ROMEN\* disables data transceivers 13C and 13D and enables boot ROMs 14C and 15C. Note that the ROMs output directly to the processor data bus. o At this point the boot ROMs are addressed, enabled, and asserting data; the processor has been inserting wait states, waiting for DTACK\*. When DTACK\* arrives, the processor latches the data on the trailing edge of the next PCK\* and deasserts address and control signals. Sheet 9--Disabling BGACK\*: o 650 ns after I/ORQ+, the DMA address IC asserts I/O DTACK+; 900 ns after I/ORQ+, BGACK\* is disabled. Sheet 3--Asserting DTACK\*: o I/O DTACK+ causes gate 27N to assert DTACK\*. ### Mapping Virtual Address The memory management circuitry includes page status registers on sheet 16 and the memory management PAL on sheet 2. It performs four general functions: - o Translates logical address to physical address - O Updates the page status registers during each legal RAM access, either by the 68010 or DMA - o If the access is illegal, inhibits the access and generates a memory management unit (MMU) error - o Provides a data path for the 68010 to write page status to the page registers while servicing an interrupt resulting from an illegal access to RAM. The address output of the 68010 and the DMA devices are virtual address. Virtual address space is fixed at 4 MB. Programs are assigned fixed positions within this large address space. This virtual memory is sectioned off into 1024 pages of equal length (4096 bytes), and the pages reside in either RAM (physical pages) or disk storage (logical pages). From any user program viewpoint, these pages are available storage, and a major task done by the supervisor program is to juggle pages between RAM memory on the logic board and the hard disk drive. The supervisor program uses map registers (static RAM chips) to locate pages in physical memory (RAM). The amount of physical address space can vary from 0.5MB to 4MB, depending on whether or not memory expansion boards are used. The map register's address input is a virtual or logical page address. Its data output lines are the physical page address plus status bits. These determine whether that page is located in the onboard RAM or in disk storage. There are 1024 map registers, one for each page of virtual memory. When an instruction attempts to access a page that has been declared not present, the MMU PAL (memory management PAL, sheet 2) generates an error signal called PGF (page fault). This is used for internal processing and has priority over interrupts. To correct the page fault, a new page must be declared present. Since the number of pages that can be declared present is fixed, declaring a new page present means one that was present must be declared not present. The exception processing program determines which new page is declared present and which page that was present is declared not present. This determination is based on how long it has been since a given page was last accessed. Typically the kernel of the operating system is contained in the lowest portion of memory. This section of memory is unity mapped. Unity mapping means a one-to-one correspondence between virtual address into the map RAMs and physical address output. Virtual page 0 is mapped to physical page 0, virtual page 1 is mapped to physical page 1, and so on. The kernel is the lowest level of the operating system. It is responsible for scheduling processes, executing command sequences to peripheral controllers, and performing other similar tasks never seen by a user running an application program. The process working set is the set of pages that currently resides in physical memory. Whenever the CPU reads or writes a memory location, the memory management hardware determines whether or not the page addressed is in the process working set. If it is not, the hardware generates a BERR\*. Upon receiving a BERR\*, the CPU invokes the supervisor. The supervisor sets up a DMA disk operation to obtain the missing page. Then it returns to CPU user mode, allowing it to do a different user process while the DMA is working. When the disk controller finishes the DMA operation, it interrupts the CPU. The supervisor notes the updated process working set and, either now or later, returns the CPU to the original user process. The amount of physical memory determines the upper size limit of the process working set. As memory size increases, the upper size limit increases, which improves system performance by reducing disk transfers. Virtual program memory is being addressed if address bits 22 and 23 are equal to 00. The memory control receives the lower 21 virtual address bits, using the logical address bus. The upper 10 bits (21-12) address the map logic to select a page. The maps output a 10-bit-mapped address, MA21-12, which, when combined with the lower 11 address bits (11-1), forms the complete physical memory address. When a user loads an application program into the computer, the supervisor program sets up the map RAMs for that application, thus mapping the application onto an unused portion of memory. As the user inputs more information, the supervisor sends data back to the disk, remembering where it has sent the data and to which application it belongs. During each memory access, the map logic updates a table, called the <u>page map table</u>, to indicate the result of the access. This table consists of two page status bits, which indicate the status for each page of memory as follows: - Not present (memory not installed at that address) - o Present but not accessed - o Accessed but not written to - o Written (in this case, the information in this page of memory must be stored on disk before the page can be overwritten) ### Map Addresses MA12-MA21 The page mapping RAMs (integrated circuits 19C through 22C) are shown on sheet 16. The page mapping RAMs receive 10 bits of virtual address, A12-A21, and output 10 bits of physical address, MA12-MA21. Bits MA12-MA19 are used to address onboard memory. The page map is composed of static RAM chips (21C, 22C, 19C, and 20C). The RAM chips are addressed by 10 bits from the systemaddre ss bus (A12-A21). Note that the chips are always enabled on pin 8. The page RAMs output a 10-bit address (MA12-MA21), 5 status bits (PS0-PS4), and a write-enable bit (WE+). Bits MA12-MA19 go directly to the memory address multiplexers (MUXs) and are considered physical address bits. MA21 is used to determine if memory is in base memory or on the memory expansion board. PS2, PS3, and PS4 are not used by the software as shipped, but are available for future memory management enhancements. PS0 and PS1 are used to provide the operating system with the following page status information: | PS0 | PS1 | Status of Page | | |------------------|------------------|---------------------------------------------------------------------------------------|--| | 0<br>0<br>1<br>1 | 0<br>1<br>0<br>1 | Page not present Present but not accessed Accessed but not written Written to (dirty) | | ### Selecting RAM Row Sheet 17 shows the RAM row decoder, 6J. RAM is divided into two rows of RAM chips, each row containing 512KB. Note that for the 0.5MB and 2.0MB designs, RAM chip locations are different. Address bit Al is decoded to enable a particular row of RAM as follows: | LA1 | Row Enabled | Row | |--------|----------------|-----| | 0<br>1 | Row Y<br>Row Z | | # Address Multiplexing The dynamic RAM chips (see sheets 19 and 20) have 9 address inputs that are multiplexed to form the required 18-bit address, although the 64K RAM chips use only 16 bits. This is done through the row address strobe (RAS\*) and the column address strobe (CAS\*) inputs to pins 4 and 15 of these chips. Sheet 18 shows the memory address MUXs. Multiplex chips switch the RAM address input from row to column address. Notice there are two sets of MUXs, one set for each of the two rows of memory. Each set of MUXs outputs to one of the two buses: Y bus, or Z bus. These buses carry 9 bits of address directly to their respective row of memory. They first transfer 9 bits of RAS address and then 9 bits of CAS address. As inputs, each set of MUXs receives MA12-MA9, A3-A11, and LA2. MA12-MA9 is the page address from the outputs of the page-mapping RAMs. These bits address the selected physical page of memory. LA2, A3-A11 is the word address from the system bus. These bits are not altered by memory management. They address a word on the selected page. LA2, A3-A10 are gated through the MUXs at RAS time. A11 and MA12-MA18 are gated through at CAS time. Table 2-4 Summary of Address Bit Assignments\* | Address Bit | Assignment | | | |-------------|----------------------------------------------------------------------|--|--| | PA23 | When = 0, fast bus cycle memory<br>fast register cycle | | | | | When = 1, slow ROM cycle<br>slow I/O access cycle | | | | PA22 | When = 0, fast cycle memory access slow ROM cycle | | | | | When = 1, fast register cycle<br>slow I/O access cycle | | | | A12-A21 | Virtual page address to map RAMs | | | | MA21 | When = 0, base memory enabled<br>When = 1, expansion memory enabled | | | | MA12-MA20 | Address from page mapping RAMs | | | | A2-A11 | Address from system address bus | | | | A1-A2 | Word address bits from system bus used to select a bank of RAM chips | | | $<sup>{}^{\</sup>star}$ This table reflects the address bit assignments for 1MB design. ## Write Sequence: Processor to Page Map A reference to the page mapping RAM is considered a CPU fast cycle, which is 400 ns or four cycles of the processor clock. When a time reference is made in the following text--for example, DTACK\* is generated at 190 ns--it means 190 ns from the rising edge of the first PCLK in the cycle. Note the position of the asterisk in the following diagram: Sheet 5--Asserting address and control signals: - At 60 ns into the fast cycle, the 68010 outputs the function code: FC2, FC1, or FC0. In this case, FC2 is high because the CPU has to be in supervisor mode to refer to the page map. - Also at 60 ns, the processor places the address on PA23-PA1. PA23 and PA22 will be 0 and 1, respectively, signifying a fast-cycle access to RAM. - o At 120 ns the CPU outputs AS-, UDS-, and/or LDS-. The processor also asserts R/W\* low at this point. - o Gate 22D asserts PDS+. Sheet 3--Starting memory timing: - o PA23 applies a low to pin 9 of 16H; pin 8 of 16H is an inactive BGC+ (low). 16H outputs high to 19K; pin 3 of 19K is clocked. 19K clocks F/F 21E clear because of the inactive ROMLMAP\* tied to its K input. This asserts ENRAS\* (low) and starts delay line 19H. - o ENRAS\* is generated at 100 ns. Note that the signals generated from the delay line are time referenced to the generation of ENRAS\*. #### Sheet 9: • ENRAS\* (low) causes the DMA address IC to assert BGACK\* for 200 ns. ENRAS\* and R/W\* assert FWR\*. The system address space allocated for the page mapping RAM includes addresses 400000-4007FF. These addresses are decoded to enable the page map. | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 | |------|------|------|------|------|------|------|------| | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | #### Sheet 17: O Decoder 6J is enabled by ENRAS\*. It is addressed by SPA23 and PA22, which are 0 and 1, respectively. This causes the decoder Q1 output to go low, thus asserting GATE1\*. #### Sheet 4--Enabling map RAM: - o 1 of 8 decoder 26G is enabled by GATE1\* (pin 5), PA19 = 0 (pin 6), the active SUPV+, and the inactive BGC\* (pin 4). It is addressed by PA16-PA18, all equal to 0. The decoder drives pin 15 low, generating MRAMEN\* (map RAM enable). - MRAMEN\* goes to sheet 5, where it disables the processor data transceivers, and to sheet 16. ## Sheet 16--Page map: - o 19C, 20C, 21C, and 22C are the page-mapping RAM chips. They are 100 ns, 1K x 4, static RAMs. - o The processor addresses the page map with address bits PA1-PA10 through buffer chips 16G and 12F. These chips are enabled by MRAMEN\*. - o The data is gated to the RAM chips using transceivers 23C and 24C. - o The RAM is enabled for a write by gate 20E (pin 11). Sheet 3--Acknowledging transfer by generating DTACK: - o 19F, acting as a MUX, is set up to select the A inputs because we are not in expansion memory. At T90 pin 9 goes high, partially enabling 27F. An inactive BGC\* and an inactive BMSEL\* fully enable the gate. The high output from 27F (pin 8) generates DTACK\* from 27N (pin 5) at 190 ns. - The processor samples DTACK\* at 250 ns, verifies it at 300 ns, and latches the data at 350 ns. ### 68010 Local RAM Read Sequence A reference to RAM is considered a CPU fast cycle, which lasts 400 ns or four cycles of the processor clock. Sheet 5--Asserting address and control signals: - At 60 ns into the fast cycle, the 68010 outputs the function code: FC2, FC1, or FC0. The R/W\* signal is negated (high) because data is being read. - o Also at 60 ns, the processor places the address on PA23-1. PA23 and PA22 are 0, signifying a fast-cycle access to RAM. - Processor address buffers 16F and 17F are enabled by an inactive MRAMEN\* and an inactive BGC\* from gate 25N. - o Transparent latch 17G is enabled on pin 1 by the inactive BGC+. It is put into transparent mode using 27H by an inactive MMUWREN+ and an inactive MMUWREND+. - o At 120 ns, the CPU outputs AS-, UDS-, and/or LDS-. - o Gate 22D generates PDS+. # Sheet 3--Starting memory timing: - o PA23 is low and feeds pin 9 of 16H; pin 8 of 16H is an inactive BGC+. 16H outputs high to 19K; pin 3 of 19K is clocked. 19K clocks F/F 21E clear because of the inactive ROMLMAP\* tied to its K input. This generates ENRAS\* and starts delay line 19H. - o ENRAS\* is generated at 100 ns. Note that the signals generated from the delay line are time referenced to the generation of ENRAS\*. Sheet 16--Obtaining physical address from page map: - o The page mapping RAMs (19C, 20C, 21C, and 22C) are always enabled because of the ground on pin 8. Gate 26M sets them up for a read because of the inactive MRAMEN\*. - o The RAMs are addressed by virtual address bits A12-A21 and output physical address bits MA12-MA21 along with five page status bits. Sheet 18--Driving the address to memory: o The address MUXs are always enabled by a ground on pin 15. The select input (pin 1) is high for the first 160 ns of the cycle and gate through the row address. After 160 ns, the column address is gated to memory. Sheet 16--Strobing the row address: o Transparent latch 25F is in its transparent mode before T150 and passes address bits A1 and A2 through to become LA1 and LA2. At T150 pin 11 goes from high to low and 25F latches its data. #### Sheet 17: - The RAM row decoder (6J) is enabled by a low PA22 using gate 20F. LA1 and LA2 select one of the four banks of RAM as shown in Table 2-5, the respective 4J gate and partially enables one of the 3J gates. At 130 ns, RAS goes out to the selected row of memory (T30\*). - o On the 1MB machine, RAS is distributed by an LA1 alone. On 0.5 or 2MB machines, the LA1 and LA2 states are as follows. Table 2-5 Row Address Strobing | L | 12 | LA1 | RAS Enabled | Row Affected | |---|----|------------------|----------------------------------|----------------------------------| | | ) | 0<br>1<br>0<br>1 | RAS0*<br>RAS1*<br>RAS2*<br>RAS3* | Row W<br>Row X<br>Row Y<br>Row Z | Sheet 2--Strobing the column address: - With PA22 low and BGC+ inactive, gate 26M outputs low to 22D, generating CASEN+. - o MMU PAL 24G outputs only CASDIS\* during a MMU error. This signal prevents a memory reference in the event of an error condition (such as a page fault). #### Sheet 16: o The inactive CASDIS\* and CASEN+ feed gate 24P, forcing a low onto pin 5 of 27H. Pin 6 is low for a read operation. 27H outputs high to 26M and 26M outputs high to 25F, generating ENCAS+. #### Sheet 17: - o ENCAS+ partially enables decoders 7J and 9J, LDS\* and UDS\* further enable the decoders, and at T90, one or both of the decoders are fully enabled. Note that LDS\* and UDS\* control byte or word selection. - o The decoders are addressed by LA1, LA2, and LMA21. If LMA21 is low, LA1 and LA2 generate CAS to one of the rows of memory. If LMA21 is high, the target memory address is on the expansion board and no CAS goes to base memory. # Sheet 19--Accessing RAM: - At 130 ns into the bus cycle, RAS strobes in the row address. At 160 ns, the address MUXs switch from row address multiplexing to column address multiplexing. At 190 ns, CAS strobes in the column address. - After access time (150 ns from RAS), the data is available on the RD bus. Sheet 20--Putting information on the system data bus: - o 12C and 12D are the RAM data transceivers. They are enabled during CAS time, provided address bit 21 is a 0 (base memory). - o The direction in which the transceivers pass data is controlled by R/W\* from the processor. For a read operation, they route the data from the RD bus to the D bus. Sheet 3--Stopping memory timing and resetting ENRAS\* using PDS+: - o Gate 18G stops memory timing. Pin 13 is high when the bit map is not being referenced. Pin 12 is high when PDS+ is active. Pin 11 is high when no bus grant common is active, and pin 1 goes high at T120. These conditions cause 18G to output a low to gate 16H. - o 16H outputs high to the D input of F/F 16K. At the next 1PCK+, MMUWREN+ is generated. - o MMUWREN+ is tied to the D input of F/F 18H, and the trailing edge of the next PCK\* sets the F/F. - o 18H outputs low on pin 3 and sets the ENRAS F/F (21E). Sheet 3--Acknowledging the transfer and generating DTACK\*: - o 19F, acting as a MUX, is set up to select the A inputs because we are not in expansion memory. At T90 pin 9 goes high, partially enabling 27F. An inactive BGC\* and an inactive BMSEL\* fully enable the gate. The high output from 27F generates DTACK\* from 27N at 190 ns. - o The processor samples DTACK\* at 250 ns, verifies it at 300 ns, and latches the data at 350 ns. Sheet 10--Checking parity: o The DMA data IC outputs UPARIN if bad parity (odd) is found in the high byte and LPARIN if a problem occurs in the low byte. Parity is checked during a read. During a write, LPARIN and UPARIN set the data into the memory parity chips so that the data byte plus the parity bit have odd parity. #### Sheet 17: - o Gate 13H outputs low at CAS time when a read-to-base memory is being done. This output, along with the data strobes, enables one or both of the gates feeding 12H. - o 12H outputs low when there has been a parity error. When T90 goes from low to high, F/F 6K resets and 20E presents PERR\* to the system. #### Sheet 6: • PERR\* forces a low out of 28F. If the error-enable bit is active, a low is gated to pin 4 of 18F. Decoder 18F presents a level 7 interrupt to the processor. ## Parity Figure 2-2 is a simplified schematic of the parity generator circuit in the custom IC simulator board. ## Parity Write During a RAM write operation, the parity circuit determines if the number of bits set to a one in the upper or lower data byte is odd or even. If the number is even, the parity bit for that byte is set high. If the number is odd, the parity bit is set low. Parity is checked during a 68010 RAM read cycle. If parity is incorrect, a level seven interrupt is generated. The ENCAS\* input to the parity error generating circuit on sheet 17 prevents generation of a parity error during a page fault. The LDS input prevents parity error during a DMA RAM memory access. ## Sheet 17: O During a write, the BP+ bit is low and the select input S to the multiplexer 10J is high; thus UMUXPAR and LMUXPAR are both high during a write. The odd-parity generators in the DMA data IC (sheet 10) generate the odd-parity signals UPARIN (upper-byte parity) and LPARIN (lower-byte parity). If the data on the data bus has an even number of high bits, the hi input from UMUXPAR makes the number of high inputs to the 74LS280 odd, and the parity bit input to RAM is hi. If the number of highs on the data bus is odd, then adding the hi input from UMUXPAR or LMUXPAR keeps the total input to 75LS280 even and the output of the DMA data IC is low. Thus the two combined inputs to RAM, D0-D7 plus LPARIN and D8-D15 plus UPARIN, always have odd parity. Figure 2-2 Parity Generator ## Parity Check During a memory-read operation, the two parity generator chips check the parity of the 8-bit bytes plus their corresponding parity bit. Thus, during a RAM read, both UPARIN and LPARIN should be low, indicating even parity. If either signal is high, circuitry on sheet 18 generates a parity error (PERR\*). The PERR\* signal is used by the 68010 interrupt logic on sheet 6. An interrupt is generated if the parity error-enable is asserted at the general control register (GCR). The PERR\* signal latches the current bus status into the bus status register (BSR) and the general status register (GSR). If the supervisor program has not masked out the error with the error-enable bit at the GCR, the PERR\* generates a level-7 interrupt. ## Page Status Update and Memory Management Errors Each memory access to RAM is checked for validity. If it is a valid access, the status bits in the map RAMs are updated. If it is not valid, the attempted access to memory must be prevented and an error signal must be generated. The circuitry to accomplish this is explained below. The memory management unit write (MMUWR\*) signal originates on sheet 2. On sheet 16, it updates the status of the page status registers. This signal is asserted each time an access to RAM is made that does not produce an access error. On sheet 2 MMUWR\* enables tristate buffers that load the new page status bits PSO (page status bit zero), PS1, and WE (write enable). On sheet 16 MMUWR\* puts the map status RAMs into a write condition so that the new status of PSO, PS1, and WE is written into the RAMs during each valid RAM access. On sheet 2 MMUWR\* is asserted by MMUWREN+ (memory management enable) high and MMUERR\* (memory management unit error) high, no error, and CASEN+ (column address strobe enable). MMUWREN+ is enabled each time an access to RAM is made by the 68010 or the DMA interface unit. The memory management PAL generates the following new page status: PS1: Set to 1 regardless of previous state to indicate a read has taken place. # Logic Board Theory of Operation - PS0: Set to 0 during a memory read if there is no memory error. Otherwise, it is set to 1. - o WE+: Set equal to SPA23. Pages are write enabled when and only when they are accessed in supervisory mode by the 68010. ## Generation of Memory Management Interrupts If the EE+ bit is set high on sheet 6, the MMUERR\* generates a level-7 interrupt. The memory management PAL generates two signals that drive the interrupt logic on sheet 6: PGF (page fault) and MMUERR (memory management unit error). # Page Fault This signal is asserted whenever both PSO and PS1 are 0 and the 68010 is executing a user program, FC2 is low, or a DMA RAM access (BGC+ asserted) is taking place. When PSO and PS1 are both 0, a page fault is not generated when the 68010 accesses the page in supervisory mode. #### Memory Management Error The three ways to generate a memory management error are: - o Page fault - o User attempt to access the kernel, indicated by: Kernel access--A19, A20, and A21 all low User program execution--PA22, SUPV, and BGC all low • User access to a page that is not write enabled, indicated by: Page not enabled for a write--LWE low User program execution--PA22, SUPV, and BGC all low #### Bus Error The memory management unit also has an output called BERR (bus error). This signal goes directly to the 68010 on sheet 4. It is caused by the following conditions: o CPU page fault: page not present - o User I/O fault (access to address not in RAM) - User attempt to write to a page that is not write enabled - User attempt to write to the kernel. #### Column Address Strobe Disable The column strobe disable (CASDIS) signal is generated by the memory management PAL to prevent the completion of an illegal access to RAM. ### Refresh Operation Circuitry for refresh is contained in the DMA address IC shown on sheet 9. The dynamic RAM chips in physical memory (sheets 19-22) must be refreshed at least every 4 ms to prevent data loss. A RAS-only refresh is used--that is, 256 row addresses are strobed to all rows of RAM every 4 ms. This means that 64 refresh cycles must be accomplished every millisecond. Two 8-bit counters in the DMA address IC constitute most of the refresh circuitry. One is used as an address counter and the other is used to time the refresh requests. The request counter is clocked by 1PCK+. It presents RFRQ\* to the bus arbitration circuitry on every 144th 1PCK+. In other words, it is configured as a divide by 144 circuit. The address counter is incremented by the refresh bus grant (RFBG\*). It drives row addresses onto the system bus. This counter-cycles through the 256 row addresses (0-FF), driving a different address onto the system bus for each refresh bus grant. Sheet 9--Getting bus control and driving address: - o The DMA address IC asserts RFRQ\* on every 144th occurrence of 1PCK+ (every 14.4 u sec). - When the RFRQ\* has priority, the arbiter PAL grants the refresh circuitry control of the system bus by returning RFBG\* and BGC\* (bus grant common). - o The DMA address IC acknowledges receipt of the bus grant by asserting BGACK\*, which causes the bus arbiter to latch RFBG\* and BGC\*. - o BGACK\* also determines how long mastery of the bus lasts by latching the grants. BGACK\* remains active for two clock cycles during a refresh. o The refresh circuitry internal to the DMA address IC then drives the 8-bit refresh address onto the system bus (A3-A10). Sheet 3--Starting memory timing: - o F/F 18H (pin 6) is set when the system is idle, because BGC+ and ENRAS+ are absent. F/F is used to start memory timing for bus masters other than the CPU. - When bus control is granted to the refresh circuitry by the bus arbiter, the common bus grant is generated (BGC+). - o This causes F/F 18H to reset, 19K clocks F/F 21E clear, and memory timing is started. Sheet 17--Refreshing RAS: o RFBG\* enables all of the 4J gates to output lows, partially enabling the 3J gates. T30\* fully enables the 3J gates, asserting RAS to all rows of memory. # Sheet 2: CASEN+ is not generated because gate 26M is broken by BGC+, and gate 22D is broken by an inactive NRF/BGC\*. # System Control and Status Registers Various control and status registers are available to the processor. These registers monitor system status and control the hardware. Tables 2-6 through 2-11 describe these various registers. Table 2-6 General Status Register--Address 410000 (Read Only) | Data Bit | Signal | Description | |----------|--------|---------------------------------------------------------------------------------------------------------| | 14 | R/W- | 0 = Write cycle, 1 = Read Cycle | | 13 | NPC+ | 1 = Nonprocessor cycle | | 12 | PF- | <pre>0 = Page fault; applies to the<br/>processor (supervisor or user)<br/>and the DMA controller</pre> | | 1.0 | PIE+ | 1 = Parity interrupts enabled | | 08 | UIE- | 0 = User access to memory above 4MB | Information in the general status register is updated with each bus cycle. If the current cycle causes a parity error, MMU error, or processor bus error, the information in the GSR is not updated at the following cycles until the clear-status, register signal is received. This signal is generated when the processor writes to address 4C0000. The general status register is on sheet 6 (24D) of the schematics. Table 2-7 Bus Status Register 0--Address 430000 (Read Only) | Data Bit | Signal | Description | |----------|---------|------------------------------------------| | 15 | MMUERR- | <pre>0 = MMU error; three possible</pre> | | 14 | DKBG- | 0 = Disk DMA cycle | | 13 | EXP0BG- | 0 = Expansion board 0 DMA cycle | | 12 | EXP1BG- | 0 = Expansion board 1 DMA cycle | | 11 | EXP2BG- | 0 = Expansion board 2 DMA cycle | | 10 | EXP3BG- | 0 = Expansion board 3 DMA cycle | | 09 | UDS- | 0 = Upper byte access | | 08 | LDS- | 0 = Lower byte access | | 07 | PA23 | Processor address bit 23 | | 06 | PA22 | Processor address bit 22 | | 00-05 | A16-A21 | Logical address bits 16-21 | # Note The bus status register is on sheet 6 of the schematics. Table 2-8 Bus Status Register 1--Address 440000 (Read Only) | Data Bit | Signal | Description | |----------|---------|---------------------------------------| | 00-15 | A00-A15 | Latches address during NMI or<br>BERR | The bus status registers (BSR0, BSR1), located on sheet 6 in the schematics, are composed of transparent latches: 18C and 25D are BSR0; 16B and 21D are BSR1. They latch information pertaining to the status of the bus when there has been a bus, parity, or MMU error. They can be useful when troubleshooting hardware problems or debugging code. The BSRs are not cleared by reset. Table 2-9 General Control Register--Address E4X000 (Write-Only) | Address | Bit | Signal | Description | |---------|-----|--------------|---------------------------------------------------------------------------------------------------------------------| | E40000 | 15 | EE+ | <pre>1 = Error enable 0 = Error disable, meaning no level-7 interrupt or bus error can occur</pre> | | E41000 | 15 | PIE+ | <pre>1 = Parity error circuit and<br/>interrupt are enabled<br/>0 = Parity is disabled</pre> | | E42000 | 15 | BP+ | <pre>1 = Memory-write cycle resulted with parity error 0 = Memory-write cycle resulted with good parity</pre> | | E43000 | 15 | ROMLMAP | <pre>0 = Processor is forced into ROM address space 1 = Normal addressing</pre> | | E44000 | 15 | L1 MODEM* | 0 = Modem connected to line 1 | | E45000 | 15 | L2 MODEM* | 0 = Modem connected to line 2 | | E46000 | 15 | D/N CONNECT* | 0 = Dial network connected to<br>line 1 | The general control register is located on sheet 6 of the schematics. It is an addressable latch (7K). The processor addresses the GCR with address bits A12, A13, and A14. The various control signals are enabled and disabled using processor data bit 15. Table 2-10 Miscellaneous Control Register--Address 4A0000 (Write-Only) | Data Bit | Signal | Description | |----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | CLRSINT- | Dismisses the level-6, 60-Hz interrupt. To dismiss the interrupt, the bit must be toggled from high to low and back to high. When this bit is low, it makes the interrupt. | | 14 | DMAR/W- | <pre>0 = Disk DMA write operation 1 = Disk DMA read operation. This bit, along with the IDMAR/W- bit in the disk DMA count register, should be updated before a disk DMA operation.</pre> | | 13 | LPSTR+ | Strobes data from the line printer data register to the line printer through Centronics interface protocol. After data is set up at the data register, LPSTB+ must be toggled from low to high and back to low to strobe the data to the printer. | | 12 | MCKSEL- | <pre>0 = Modem RX clock and TX clock gated to the communication controller's RX clock and TX clock inputs 1 = Programmable timer selected to generate the clock pulses for the communication controller.</pre> | | 11 | LED3- | 0 = Red LED 3 (CR21) on<br>1 = Off | | 10 | LED2- | 0 = Green LED 2 (CR22) on<br>1 = Off | Table 2-10 Miscellaneous Control Register -- Address 4A0000 (Write-Only) (Continued) | Data Bit | Signal | Description | |----------|--------|---------------------------------------| | 09 | LED1- | 0 = Yellow LED 1 (CR23) on<br>1 = Off | | 08 | LED0- | 0 = Red LED 0 (CR24) on<br>1 = Off | The miscellaneous control register is located on sheet 15 of the schematics. # Reading General Status Register (Address 410000) The processor accesses the system status and control registers by performing a fast bus cycle. This operation is similar to the previous fast cycles discussed. The processor drives address and control signals and waits for DTACK\*. The address decode is the only difference between this and previous fast cycles. | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 | |------|------|------|------|------|------|------|------| | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | ## Sheet 4--Decoding address: - o GATE1\* is active for all fast cycles other than accesses to main memory. This signal enables decoder 26G on pin 5. - o The processor must be in supervisor mode to access the GSR, and BGC\* is not active during process bus cycles. These conditions cause gate 25N to enable the decoder on pin 4. - When addressing the GSR, PA19 = 0, which fully enables the decoder (pin 6). - o The decoder is addressed by PA18, PA17, and PA16. As the chart above illustrates, these bits are 0, 0, and 1, respectively. This causes the decoder to generate GSRRD\* from pin 14. ## Sheet 6--Driving the data: - o The general status register is transparent latch 24D. Its outputs are enabled by GSRRD\*, and it Sheet 3--Acknowledging data transfer: - o Gate 27F causes the generation of DTACK\* at T90. The processor latches the data on the trailing edge of the third PCK+, the DMA address array. ### Interrupting the Processor Interrupts inform the processor of special situations within the system. They interrupt normal processing and cause the CPU to be vectored into a routine to deal with the special situation. Motorola calls this exception processing. The processor can mask interrupts by manipulating bits 12, 11, and 10 of the 68010's status register. For example, if these bits are loaded with a binary 100, interrupt priority levels (IPL) of 4 and below are ignored. IPL7 interrupts cannot be masked; this is the nonmaskable interrupt (NMI). If bits 12, 11, and 10 are all set to 1's, all interrupts except the level-7 interrupt are masked. Exception processing is the only way to go from the user state to the supervisor state. It occurs in these four steps: - A temporary copy of the status register is made and the status register is set for exception processing (all interrupts equal to the current level and below are masked and the S bit is set, which puts the processor into the supervisor state). - o The exception vector is determined. - The current processor context is saved (status register and program counter are pushed onto the supervisor stack). - New context is obtained and instruction processing resumed. # Exception Vectors Exception vectors are memory locations from which the processor fetches the address of a routine to handle an exception. Exception vectors are words in length, and all exception vectors lie in supervisor data space. Exception vectors are obtained through the use of a <u>vector number</u>, which is an 8-bit value that, when multiplied by 4, gives the offset of the exception vector. The 68010 can accept an externally generated, vector number or generate the vector number internally. As implemented in the UNIX PC, all vector numbers are generated internally by the 68010 microcode. This is called <u>auto-vectoring</u>. Once a vector has been calculated, the processor fetches an address from that location in memory. The processor loads the address into the program counter and begins executing instructions. Typically, it is then vectored into the interrupt service routine. Table 2-11 shows the interrupt vector number generated for each interrupt and the hexadecimal offset calculated from each vector number. If a level-2 interrupt is received, the 68010 generates a vector number of 26. It then reads two words beginning at address 68H, leads the words into its program counter, and begins executing instructions. Table 2-11 Interrupt Vector Numbers and Hexadecimal Offsets | Vector<br>Number<br>(Decimal) | Offset<br>(Hex) | Assignment | |----------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 25<br>26<br>27<br>28<br>29<br>30<br>31 | 64<br>68<br>6C<br>70<br>74<br>78<br>7C | Level 1 interrupt autovector Level 2 interrupt autovector Level 3 interrupt autovector Level 4 interrupt autovector Level 5 interrupt autovector Level 6 interrupt autovector Level 7 interrupt autovector | The interrupt logic is located on sheet 6 of the schematics. Seven levels of interrupts are implemented through the use of three interrupt priority level signals (IPL0, IPL1, and IPL2). IPL7, the NMI, is the highest priority interrupt. It cannot be masked by software. IPL1 is the lowest priority interrupt. An interrupt priority level of 0 means no interrupts are pending. The following table lists the interrupts and their priority levels: Table 2-12 Interrupts and Their Priority Levels | IPL | Interrupt | |--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>6<br>5<br>4<br>3<br>2<br>1<br>0 | Nonmaskable interrupt Realtime interrupt Expansion Board Interrupt RS-232 interrupt Keyboard interrupt Floppy/hard disk/line-printer interrupt Expansion Board Interrupt No interrupts | ## Interrupts: Theory of Operation The interrupts operation is as follows: ### Sheet 6: - o The various interrupts are active low inputs to encoder 18F. Pin 4 is the NMI, the highest priority interrupt. If this interrupt is active, the encoder drives IPL0, IPL1, and IPL2 all high. This presents a binary-encoded, IPL7 interrupt to the processor. - o Because pin 10 of the encoder is grounded and if no interrupts are present, the encoder drives IPLO, IPL1, and IPL2 low. This informs the processor that no interrupts are present. The IPL signals input directly to the processor. ### Sheet 5: o If any of the IPL inputs to the processor are low, the 68010 detects an interrupt. The processor then acknowledges the interrupt and begins exception processing. - When the 68010 acknowledges an interrupt, it drives FCO, FC1, and FC2 high. Address bits A4-A23 are also driven high. - o Gate 13H generates a signal called INTA\*, which goes to sheet 3 and prevents an I/O request from being generated. - o 13H also partially enables 13E. When PAS\* is asserted, 13E generates VPA\* (valid peripheral address). During an interrupt acknowledge, this signal replaces DTACK\* and handshakes the processor. It also tells the processor that the interrupt being acknowledged is an autovector interrupt. Since this signal is generated with every interrupt being acknowledged, all interrupts are autovectored. Acknowledging the interrupting peripheral is the responsibility of the software. Typically, this is handled in the interrupt service routine. # Disk Direct Memory Access (DMA) This section explains logic-board circuitry that transfers information between a disk drive and RAM memory. ## Disk Format and Flow Data from a disk drive passes through three sections of hardware before it reaches RAM memory: - Serial data from the disk drive, consisting of both data and clock pulses, is separated into a clock signal and a data signal. For the hard disk, this is done by the data separation circuitry shown on sheet 12 of the schematics. For the floppy disk, it is done by the WD2797 floppy disk controller. - o Serial data is assembled into 8-bit bytes by the disk controller. The disk controller for the hard disk is the WD1010; for the floppy disk, it is the WD2797. - o The disk DMA bus interface assembles 8-bit bytes into 16-bit words and writes them into a RAM memory location. The RAM address is contained in the bus interface. # Disk Program Summary Data on disk is located by three parameters: cylinder, head, and sector. The disk DMA bus interface has two parameters: DMA starting address and word count. These parameters plus the disk commands are written in the following disk program sequence summary: o System register disk bits are set. These bits select the disk drive and head number; in the case of the floppy disk, they turn on the motor. Counters in the DMA disk bus interface are loaded with the starting address and number of words to be transferred. The disk controller registers are loaded with the track and sector to read. - o The 68010 starts the transfer of data from disk by writing a Read-Sector command to the disk controller. - o The disk DMA bus interface takes control of the bus through bus arbitration and transfers data from the disk controller into RAM memory. Data passes through the three sections of hardware as described above. One disk DMA bus interface unit is shared by both the floppy and hard-disk controllers. When the sector of a disk is being read, the disk DMA bus interface reads two 8-bit bytes from either the WD1010 hard disk controller or the WD2797 floppy-disk controller, assembles them into one 16-bit word, and writes the word into RAM memory. When data is being transferred from RAM memory to disk, the disk DMA bus interface reads a 16-bit word from RAM memory, separates it into two 8-bit bytes, and loads them into the data register of either the WD1010 hard disk controller or the WD2797 floppy disk controller. The disk DMA bus interface consists of two custom, gate-array chips: the DMA address IC shown on sheet 9 and the DMA data IC shown on sheet 10. Once a Read Sector command is written to the disk controller command register, the disk DMA bus interface takes control of the bus through bus arbitration each time a word is to be transferred to memory. Between word transfers, the 68010 can access the bus. The software must be written so that the 68010 does not write to the disk controllers while a command is in progress. o The disk controller informs the 68010 when it has completed a command by asserting its interrupt output. #### Definitions The following definitions describe the register and commands relationship. ### Disk Commands Disk commands control the movement of data to and from memory to the disk storage medium. The disk commands are described below. DMA read and DMA write are defined with respect to the disk DMA bus interface that is the bus master during the transfer. During a DMA read, data is moved from RAM to the word buffer in the bus interface. During a DMA write, data from the word buffer in the disk DMA bus interface is written to RAM. The disk controller Write-Sector and Read-Sector commands are defined with respect to the controller. A Read-Sector command moves data from the disk to the disk controller. A Write-Sector command moves data from the controller to the disk, and the controller writes to disk. Thus, to move data from RAM to disk requires a DMA read and a disk, Write-Sector command. To move data from disk to RAM requires a disk, Read-Sector command and a DMA write transfer. # System Register Disk Bits Disk operation is selected by writing instruction to the disk control register as explained below. Disk Control Register (Drive and Head Select), Table 2-13. Before a disk operation can occur, the drive and head must be selected. The processor does this by writing to address 4E0000, the disk control register (sheet 11). Table 2-13 Disk Control Register--Address 4E0000 (Write Only) | Data Bit | Signal | Description | | | |----------|------------|--------------------------------------------------------------------|--|--| | 07 | FDRST- | 0 = Floppy disk controller reset<br>1 = Not reset | | | | 06 | FDR0+ | 0 = Floppy drive 0not selected<br>1 = Floppy drive 0selected | | | | 05 | FDMTR+ | 0 = Floppy drive motor is not on<br>1 = Floppy drive motor is on | | | | 04 | HDRST- | 0 = Hard disk controller reset<br>1 = Not reset | | | | 03 | HDR0+ | 0 = Hard disk drive 0not selected<br>1 = Hard disk drive 0selected | | | | 00-02 | HDHSEL 0-2 | These three bits are decoded to select the head | | | Miscellaneous Control Register (DMA Read/Write), Table 2-14. This register controls the DMAR/W- bit used by the disk PAL shown on sheet ${\bf 2}$ and other bits shown in the following table: Table 2-14 Miscellaneous Control Register--Address 4A0000 (Write Only) | Data Bit | Signal | Description | |----------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 15 | CLRSINT- | This bit dismisses the level 6, 60-Hz interrupt. To dismiss the interrupt, the bit must be toggled from high to low and back to high. When this bit is low, it masks the interrupt. | | 14 | DMAR/W- | <pre>0 = Disk DMA write operation 1 = Disk DMA read operation. This bit, along with the IDMAR/W- bit in the disk DMA count register, should be updated before a disk DMA operation.</pre> | | 13 | LPSTR+ | This bit strobes data from the line printer data register to the line printer through Centronics interface protocol. After data is set up at the data register, LPSTB+ must be toggled from low to high and back to low to strobe the data to the printer. | | 12 | MCKSEL- | <pre>0 = Modem RX clock and TX clock are gated to the communication controller's RX clock and TX clock inputs. 1 = Programmable timer is selected to generate the clock pulses for the communication controller.</pre> | | 11<br>10<br>09<br>08 | LED3-<br>LED2-<br>LED1-<br>LED0- | <pre>0 = Red LED 3 (CR21) on; 1 = off 0 = Green LED 2 (CR22) on; 1 = off 0 = Yellow LED 1 (CR23) on; 1 = off 0 = Red LED 0 (CR24) on; 1 = off</pre> | Line Printer Status Register (Controller Interrupt), Table 2-15. Bits D2 and D3 of this register are set high when the disk controller completes a command. These bits may be polled by the 68010. They are reset when the status register of the controller is read. Table 2-15 Line Printer Status Register--Address 4A0000 (Write Only) | Data Bit | Signal | Description | |----------|------------|---------------------------------------------------------------------------------------------------------------------------------------| | 07 | LPBUSY+ | 1 = Line printer is busy | | 06 | LPSELECT+ | 1 = Line printer is selected | | 05 | LPNOPAPER+ | 1 = Line printer has no paper | | 04 | ERROR* | 0 = Line printer error condition | | 03 | FDINTRQ+ | 1 = Floppy disk controller interrupt | | 02 | HDINTRQ+ | 1 = Hard disk controller interrupt | | 01 | PERR* | <pre>0 = Main memory parity error has<br/>been detected; this bit can be<br/>cleared with the CSR command<br/>(write to 4C0000)</pre> | | 00 | DTDET* | 0 = Dial tone is detected | | 15 | CLRSINT- | This bit dismisses the level 6, 60-Hz interrupt | # Hard Disk Controller (WD1010) Hard disk control is provided by the Western Digital WD1010 Winchester disk controller chip. It provides MFM-encoded data and all of the control lines required by disks using the Seagate Technology ST506 or Shugart SA1000 interface standard. Pin Functions (sheet 11) for the WD1010 are listed in Table 2-16. Table 2-16 Pin Functions WD1010 | Pins | Signal Description | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12-19: | Winchester data bits 0-7; used during programming and while transferring data to and from the drive. | | 9-11: | Address bits 0-2; used by 68010 while programming and reading the chip's various registers. | | 1: | Buffer chip-select; asserted by WD1010 to enable the reading of or writing to the RAM data buffer. | | 8: | Chip-select; enabled by 68010 when reading of or writing to a WD1010 register is desired. When CS is low, pins 6 and 7 are used as inputs. | | 7: | Write-enable; when used as an input, it enables the bus master to write into the controller's internal registers. When used as an output, it allows the controller to write to the RAM buffer. | | 6: | Read-enable; when used as an input, it allows the bus master to read the controller's internal registers. As an output, it allows the controller to read from the data buffer. | | 31: | Track 000; asserted by selected drive when heads are located over track 0. | Table 2-16 Pin Functions WD1010 (Continued) | Pins | Signal Description | |--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <del> </del> | Signal Description | | 32: | Seek complete; asserted by selected drive when heads are settled over selected track. | | 28: | Drive ready; asserted by selected drive to signal its capability to do reads, writes, and seeks. When signal goes low, all commands are deactivated. | | 30: | Write fault; asserted by selected drive if a fault is detected. When low, all commands are deactivated. | | 29: | Index; pulsed when index mark is detected. Indicates beginning of track. | | 35: | Buffer ready; normally used by data buffer to signal to the controller that it is ready to be read (full) or written to (empty). As implemented in the UNIX PC, this input is tied to a 0.6144-MHz clock that constantly tells the controller that the buffer is accessible. | | 3: | Interrupt request; generated by WDC upon termination of a command; cleared when status register is read. | | 5: | System reset. | | 27: | Step; 8.4-us pulses to drive stepping motor. | | 26: | Direction; when high, the heads move inward toward higher cylinder numbers. When low, the opposite is true. | | 23: | Early; output used to derive delay value for write precompensation. Valid when write gate is active. | Table 2-16 Pin Functions WD1010 (Continued) | Pins | Signal Description | |------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | 22: | Late; output used to derive delay value for write precompensation. Valid when write gate is active. | | 33: | Reduced write current; goes high for all cylinder numbers greater than the value programmed into the write precompensation register. | | 24: | Write gate; an active high when write data is valid; used by drive to enable write current to data heads. | | 37: | Read data; MFM data pulses from disk. | | 25: | Write clock; 5-MHz clock used to derive write data rate. | | 34: | Data run; looks for a string of 0s in the read data, indicating the beginning of an ID field. If the 0s are detected, read gate (RG) is brought high. | | 38: | Read gate; set high for data and ID fields. | | 21: | Write data; open drain output that shifts out MFM data at the speed determined by the write clock input. | | 39: | Read clock; square-wave clock input derived from external data recovery circuits. | ## Task File Registers The WD1010 is similar to the other LSIs that have been discussed in that it must be programmed before hard disk operations. The 68010 is required to supply information—such as drive, head, sector, number of sectors to transfer, and so on—to the task file registers before writing a command to the command register. Table 2-17 Task File Registers | Address | Function | |-------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | Data register<br>(E00000) | Used during reads and writes to hold one byte of data | | Error register<br>(E00002) | Read by 68010 to determine what<br>type of error occurred during a<br>disk operation | | Sector count register (E00004) | Data bits 0-7 are used during reads and writes to indicate the number of sectors to transfer | | Sector number register (E00006) | Data bits 0-7 are used during reads and writes to indicate the sector address | | Cylinder number low register (E00008) | Data bits 0-7 are used during reads and writes to indicate the current cylinder number | | Cylinder number high<br>register (E0000A) | Holds the upper byte of the current cylinder address | | Sector drive head<br>register (E0000C) | Bits 0-2, head number; bits 5-6 will be 0 and 1 indicating 512-byte sector; bit 7 is set for ECC and reset for CRC | | Status register<br>(E0000E) | Read by 68010 to determine current status of hard disk control circuits and data buffer | | Command register<br>(E0000E) | Written into by the 68010 to control step rate and issue disk commands | Error Register--E00002 (Read Only) Bit 7: Bad block detect used for bad sector mapping. Bit 6: CRC error. Bit 5: Forced to 0. Bit 4: ID not found. This bit is set to indicate that the correct cylinder, head, sector number, or size parameter could not be found or that a CRC error occurred on the ID field. This bit is set on the first failure and remains set even if the error is recovered on a retry. When recovery is unsuccessful, the error status bit is set also. Bit 3: Forced to 0. Bit 2: Aborted command. This bit is set if command is issued while the DRDY is deasserted or the WF is asserted. The aborted command bit is also set if an undefined command code is written into the command register. Bit 1: Track 0 error. This bit is set only by the Restore command. It indicates that TK000 has not gone active after the issuance of 1K of stepping pulses. Bit 0: Data address mark not found. This bit is set during a Read-Sector command if the data address mark is not found after the proper sector ID is read. Status Register -- E0000E (Read Only) Bit 7: Busy. This bit is set whenever the WD1010 is accessing the disk. Commands should not be loaded into the command register while the busy is set. Bit 6: Ready. Bit 5: Write fault. Bit 4: Seek complete. Bit 3: Data request. Bit 2: Always 0. # Logic Board Theory of Operation Bit 1: Command in progress. Bit 0: Error. This bit indicates that a nonrecoverable error has occurred. If bit 0 is high, read the error register (E00002) to determine the type of error written into the control register. ### Commands The six commands that can be issued to the WD1010 are described in the following table: Table 2-18 WD1010 Commands | Command | Function | |--------------|-----------------------------------------------------| | Restore | Returns heads to track 0 | | Seek | Moves heads to cylinder in cylinder number register | | Read Sector | Reads the contents of a sector | | Write Sector | Writes data to a sector | | Scan ID | Updates head, sector, and cylinder registers | | Write Format | Formats one track | If the track selected in the cylinder registers is not the same as the track that the heads are currently positioned over, and a read or write command is issued, the controller executes an implied seek. Typically, the WD1010 can be commanded to seek a track and then write to a sector. It is important to remember that the controller has to do a read before it can write. The reason for the read is that the controller has to locate the requested sector before it can write information to that sector. The WD1010 does this by reading the ID fields. Once it locates the target sector, the controller reads the first byte from the data buffer, converts the parallel data to MFM data, and transfers this MFM data to the disk. ## Disk DMA Bus Interface Registers Address Register -- 4DXXXX When the DMA address counter is loaded, the four least-significant digits of the address bus contain the DMA address. The DMA address counter contains two sections: one to hold the two least-significant hexadecimal digits of DMA address and one to hold the four most-significant digits of DMA address. To load the counter requires two write cycles. Al4 selects the section to be loaded. When Al4 is low, the least-significant DMA address counter is selected, see Table 2-19. In this counter, Al-A8 of the address bus correspond to Al-A8 of DMA address. When Al4 is high, the most-significant DMA counter is selected. In this counter, Al-Al3 of the address bus correspond to A9-A21 of DMA address. Thus the maximum DMA address that can be loaded is 3FFFFF. This address is loaded in two writes as listed in the following table (note that the contents of the data bus are not used): | Address | Data | Description | |---------|------|--------------------------------------------------| | 4D00FF | xxxx | Al4 is low; two least significant digits loaded | | 4D7FFF | xxxx | Al4 is high; four most significant digits loaded | Table 2-19 DMA Address Count Register Selection The counter is read and incremented when DKBG is asserted during execution of a Read/Write Sector command. # Count Register The DMA count register is contained in the DMA data IC shown on sheet 10. The bit definitions for this counter are shown in Table 2-20. The DMA count is incremented after each DMA transfer. When the count reaches 3FFFx, DMA operation is terminated; thus, the maximum number of words to be transferred for a single DMA operation is 16K words. The content of this register should not be modified during a DMA operation unless DMA abortion is desired by deassertion DMAEN+. Table 2-20 Disk DMA Count Register--Address 460000 | Data Bit | Signal | Write Description | |----------|-----------|-------------------------------------------------------------| | 15 | DMAEN+ | 1 = Disk DMA enable<br>0 = Disable<br>Reset clears this bit | | 14 | IDMAR/W- | 1 = Disk DMA read operation<br>0 = Disk DMA write operation | | 00-13 | DC00-DC13 | These bits represent the current transfer count | | 15 | U/OERR- | 0 = Disk DMA underrun or overrun | | 00-13 | DC00-DC13 | These bits represent the current transfer count | # Initializing Hard Disk DMA Read This section lists the signal conditions necessary to initialize system register disk bits and the disk DMA bus interface and to load the WD1010 task file. # Loading Miscellaneous Control Register The DMA $R/W^*$ bit is set by the miscellaneous control register, shown on sheet 15. It is enabled by a signal called MREG $WR^*$ , which is asserted by signals shown on sheet 4. The signal conditions that enable $WREG WR^*$ are listed in Table 2-21. Table 2-21 Signal Status to Assert MREG WR\* | Sheet | Signal | Status | |-------|--------|--------| | 4 | A16 | o | | 4 | A17 | 1 | | 4 | A18 | 0 | | 4 | A19 | 1 | | 4 | FWR* | 0 | | 4 | BGC* | 1 | | 4 | SUP+ | 1 | | 4 | GATE1* | 0 | | 17 | PA22 | 1 | | 17 | SPA23 | 0 | | 17 | ENRAS* | 0 | # Loading Disk Control Register The disk drive and head-select bits are set by the disk control register, shown on sheet 11. It is enabled by HDCTLWR\*, which is asserted by signals shown on sheet 4. The signal conditions that enable HDCTLWR\* are listed in Table 2-22. Table 2-22 Signal Status to Assert HDCTLWR\* | Sheet | Signal | Status | |-------|--------|--------| | 4 | A16 | 0 | | 4 | A17 | 1 | | 4 | A18 | 1 | | 4 | A19 | 1 | | 4 | FWR* | 0 | | 4 | BGC* | 1 | | 4 | SUP+ | 1 | | 4 | GATE1* | 0 | | 17 | PA22 | 1 | | 17 | SPA23 | 0 | | 17 | ENRAS* | 0 | # Loading DMA Address Counter The status of address bits PA16-PA23 during the loading of the address counters is: | _ | PA23 | PA22 | PA21 | PA20 | PA19 | PA18 | PA17 | PA16 | | |---|------|------|------|------|------|------|------|------|--| | | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1. | | Listed below are the signal transitions to assert the DADD WR\* signal, which enables the DMA address counter: - On sheet 3, PA23 low and BGC+ inactive cause F/F 21E to clock, generating ENRAS\*. - On sheet 17, ENRAS\* enables one of four decoder 6J. SPA23 and PA22 are equal to 0 and 1, respectively, causing the decoder to assert GATE1\*. - On sheet 9, the DMA address IC asserts FWR\* for fast-cycle writes. - o On sheet 4, gate 25N is enabled because the 68010 is in supervisor mode and BGC\* is high. This partially enables gate 26F by putting a low at 26F pin 5. - O GATE1\* fully enables 26F, which outputs a low to pin 4 of decoder 28G. - o FWR\* enables pin 5 of 28G. - o PA19 is high and fully enables the decoder. - o The select inputs of the decoder are tied to address bits A16, A17, and A18, which are 1, 0, and 1, respectively. This causes the decoder to drive pin 10 low, generating DADD WR\*. DADD WR\* inputs to the DMA address IC. ## Loading DMA Count Register The DMA count register, located at address 460000, is loaded when DCNTCS\* is asserted. The signal status that asserts DCNTCS\* is shown in Table 2-23. | Sheet | Signal | Status | |-------|---------|--------| | 4 | A18 | High | | 4 | A17 | High | | 4 | A16 | Low | | 4 | GATE1* | Low | | 4 | SUPV+ | High | | 4 | BGC* | High | | 4 | DCNTCS* | Low | Table 2-23 Signal Status to Assert DCNTCS\* During a write, D15 is set to 1 to enable DMA and to a 0 to disable DMA. D14 is IDMAR/W; it is set to 1 for a DMA read and to 0 for a DMA write. Each time D15 goes from 0 to 1, a DMA disk request is generated. Since this is done before a Read/Write Sector command, the data transfer is invalid. If the request is for a DMA write, a transfer occurs to the current address in the DMA address counter. Thus the DMA address must be loaded before the DMA count so that the write goes to a known memory location. Data bits D0-D13 are loaded with the 2's complement of the number of words to be transferred. ## Loading WD1010 Task File Registers These registers must be loaded with information such as sector count, sector number, cylinder number, and command. The processor accesses the task file registers by running a slow bus cycle. The processor asserts chip select to the WD1010 by accessing port E0000X, where X is the address of the target task file register. The status of address bits PA16-PA23 during the loading of the task file register is: | PA | 23 PA | A22 PA | 21 PA2 | 20 PA1 | .9 PA1 | 8 PA1 | 7 PA16 | |----|-------|--------|--------|--------|--------|-------|--------| | 1 | | 1 : | L o | 0 | o | 0 | o | The signal sequence to assert the chip-select of the WD1010 controller follows: #### Sheet 3: o Gate 27F (pin 12) generates I/ORQ+ since PDS+, SPA23, and INTA\* = 1. #### Sheet 9: - o I/ORQ+ causes the DMA address IC to assert BGACK\* (refer to gate array schematics, sheet 5 of 6). - o I/ORQ+ feeds pin 1 of 1F, which outputs low to 6A. 6A steers F/F 4A to set on the next 1PCK+, generating BGACK\*. - o I/ORQ+ also feeds pin 3 of F/F 5B. BGACK+ removes the reset from all of the 5B F/Fs. The slow-cycle timing chain now begins its cycle. - o I/O DTACK+ is asserted by F/F 4B 650 ns after BGACK+. - o Gate 6A (pin 8) has been serving as a latch for BGACK\*. When the timing chain has run its course (800 ns after BGACK+), F/F 5B (pin 19) disables 6A and BGACK is dropped at the next 1PCK+. - o Gate 7A (pin 8) is used when writing to the disk controllers, and gate 3B (pin 6) is used when reading from the disk controllers. ## Sheet 6 of 6: o Logic element 8G is the command transceiver. It is enabled by DCS\*, which is HDCS\* ORed with FDCS\*. 8G transfers data between the system bus and the disk data bus when the processor is communicating with the disk controllers. ### Sheet 17: Decoder 6J is enabled by BGACK\* and asserts I/OEN\*. #### Sheet 4: - O Decoder 27G is enabled because BGC\* is inactive, SUPV+ is active, I/OEN\* is active, and address bit A21 = 1. - o A16, A17, and A18 are all equal to 0, causing 27G to assert HDCS\*. ### Sheet 11: - The WD1010 is being addressed by bits 1-3 from the system address bus. The data is on the DD bus from the DMA data IC. - All that is required to write data to the addressed task-file register is HDCS\* and WR\*. ## Executing Hard Disk DMA Read Listed below are signal exchange sequences that occur during a disk DMA Read Sector command. The first sequence begins the cycle, and the rest repeat until a complete sector of data has been read from memory to disk. ## Reading Sector Signal Cycles The cycle begins with a Write-Sector command: - o The 68010 writes the Write-Sector command to the WD1010 controller. - o The controller responds to the Write-Sector command by generating HDBCS\* (pin 1), shown on sheet 11. This signal is generated every time the disk controller is ready to receive a byte from the disk DMA bus interface. - o The disk PAL on sheet 2 responds to HDBCS\* by asserting TFER\* (transfer request). This first transfer request begins the following repeating cycles: Repeating signal exchange between DMA interface and the arbitration PAL: - o The DMA data array responds to TFER\* by asserting DKRQ\* (disk bus request), shown on sheet 10. DKRQ\* is the request to the bus arbitration PAL for a disk DMA machine cycle. Because the disk DMA bus interface receives 16-bit words from memory and the disk controller receives 8-bit bytes from the DMA data array, DKRQ is asserted once for every two times that TFER\* is asserted. - The arbitration PAL on sheet 2 responds to DKRQ by asserting DKBG\*. - o The DMA address array responds to the bus grant by asserting BGACK. - o After 200 ns, the DMA address array negates BGACK. Repeating signal exchange between disk DMA bus interface and the bus: - When DKBG\* is asserted, the DMA address array loads the DMA address on the bus. Each time the address is loaded on the bus, the address counter in the address array is incremented. - o When BGACK\* is asserted, the DMA data array loads DMA data on the bus. A 16-bit word is read into the word buffer in the data array from RAM memory. - When DKBGA\* is negated, both address and data are removed from the bus to complete the machine cycle. Repeating signal exchange between DMA interface and the disk controller: - When TFER goes high, the lower half of the 16-bit word stored in the DMA word buffer is transferred by the DMA data array to the disk controller. - o The next time TFER goes high, the upper half of the 16-bit word stored in the DMA data array is transferred to the disk controller. A new bus request is generated by the DMA data array, causing a new word to be written into the word buffer of the DMA data array. Repeating memory access using arbitration PAL: - Each time DKBG\* is asserted, the arbitration PAL asserts BGC+. - On sheet 3, BGC+ causes the assertion of ENRAS\*, which starts the memory timing sequence. Controller interrupt ends command execution: When the last byte has been written to disk, the controller asserts HDINTRQ, interrupt output pin 3. Sheet 15 shows this signal connected to the line printer status register. If the program is using polling, this register is read to detect command completion. If polling is not used, the interrupt (see sheet 6) generates a level 2 interrupt. #### Terminal Count Terminal count is reached when the DMA count register toggles from FFFF to C000. This means that the programmed number of words has been transferred. - When counter 7C contains FF and counter 7D contains FF, pin 14 of 7D goes low the next time the counters are clocked. This feeds pin 2 of 4E and pin 13 of 2B. 2PCK+ clocks 2B clear and pin 15 outputs low to the D input of F/F 2B. The following 2PCK+ clocks this F/F clear and TC\* is generated. - TC\* is tied to pins 1 and 10 of 1D. This disables 4D and no more disk bus requests are generated. - o The processor is informed of the completion of the disk operation by an interrupt from the disk controller. HDINTRQ+ is generated by the WD1010 upon completion of a command. If interrupts are being masked by the processor, such as during the bootstrap routine, the interrupts can be detected by polling the line printer status register (bit 2), address 470000. ## Underrun/Overrun Errors An underrun condition occurs when the DMA cannot send bytes to the disk controller fast enough. This is an error condition associated with a disk-write operation. An overrun occurs during a disk read operation when the DMA cannot read bytes from the disk controller fast enough. The disk controller transfers data to and from a disk spinning at a fixed speed (+ or -1%) and a minimum of 512 bytes must be moved during a Read/Write-Sector command. Thus the disk controller must read or write a byte when it is under the head in the drive. The drive motor cannot speed up or slow down for some other bus master to get off the bus. Thus bus arbitration gives highest priority to disk DMA; otherwise, an underrun/overrun error could occur. - o If the DMA requests the bus while a disk bus grant is still active, a U/OERR is generated. - The error is detected by the processor by sampling bit 15 of the DMA count register, address 460000. ## Separating Hard Disk Data Data separation is accomplished by a combination of a voltage controlled oscillator, phase detector, and a loop filter. These are called the data separation circuits and they operate as described below. ### Modified Frequency Modulation (MFM) MFM is the method used to encode serial data and clock data written on disk. This method allows the disk controller to distinguish 1s from 0s when the data is read back. Encoding is done by positioning pulses at the beginning or middle of a sequence of 200-ns bit cells, one cell for each binary bit to be written. No more than one pulse can be written in each cell, and certain cells will be empty. A pulse at the beginning of a cell indicates a 0 bit stored in that cell, and a pulse in the middle of the cell indicates a 1 stored in that cell. An empty cell indicates a 0 preceded by a 1. In this last case, the previous cell must contain a pulse in the middle, which ensures that the time between pulses is always equal to or larger than one cell The pulse at the beginning of the cell also serves as a clock pulse. When data is read back, a phase locked loop (PLL) is locked to this pulse. The width of the bit cell is fixed by the speed of the disk drive motor, which is 200 ns for the hard The alignment of the bit cell with respect to the data is maintained by the phase-locked loop. An example of MFM coding follows. #### 200-ns Bit Cells - An 0 is written at the beginning of a bit cell; 0s also serve as clocks. - o A 1 is written in the center of bit cells. - A 0 following a 1 is not written because the flux density on the media would be too great. MFM data bits must be separated by at least one bit cell. If a bit cell is empty, the controller knows that it must have been a 0 following a 1. ## Data Separation Circuits The circuits that make up the data separator are: - o Voltage-controlled oscillator (VCO) (IC 14N) - o Phase detector (output at IC 18M, pins 11 and 8) - o Loop filter (output at IC 17N, pin 1) ### Voltage-Controlled Oscillator During a Read Sector command, the VCO is phase locked to the incoming data. Pin 1 is the voltage control pin. When pin 1 is 0 volts, the oscillator output frequency is about 3 MHz. When it is 5 volts, the output frequency is about 18 MHz. #### Phase Detector The phase detector includes the two data flipflops in IC17M, whose outputs are labeled REF and VAR. The REF and VAR F/Fs are used to compare the reference frequency to the variable VCO frequency. NAND gate 18M is connected so that, when REF and VAR are not both set or reset, a pullup or pulldown pulse is generated. At the beginning of a cycle, both REF and VAR are low. If the frequency of the PLL is too high, the PLL clock goes high at pin 3 of 17M before the delayed reference at pin 11 of 17M goes high. In this case, 18M pins 9 and 10 are both high and a pulldown pulse is generated to pull the frequency back down. If the frequency of the VCO is too low, pin 3 of 17M goes high after pin 11 of 17M goes high. In this case, pins 12 and 13 of 18M are both high, generating a pullup pulse at 11. In either case, following pulses set whichever flipflop is not set first, and then reset them both. ## Loop Filter Operational amplifiers (17N) implement a loop filter. The filter is slow in responding to the error pulses produced by the REF and VAR F/Fs and prevents the VCO from reacting to random phase differences. A pullup pulse turns on Q7, which makes the junction of R68 and R67 +5 volts. This makes the output of 17N at pin 7 swing negative at a rate dependent on the value of C253 and R68. Pin 7 of 17N is connected to the input of an operational amplifier whose output is 17N at pin 1. This operational amplifier is configured as a 2:1 inverting amplifier. Its output is connected to the voltage control pin 1 of the VCO. RP24 adds a positive bias to the output of 17N so that, if pulldown is grounded, pin 1 of the VCO drops to a minimum of 0 volts. If pullup is grounded, pin 1 of the VCO goes to a maximum of +5 volts. ## Finding a Valid Address and Data Mark Beginning the ID field and preceding the data field of a disk sector, there are 14 bytes of 0s. This string of 0s is used by the read circuitry to synchronize the read clock with the read data (remember, 0s double as clocks). After the 14 bytes of 0s, there is a byte containing Al. This byte is used to validate the 0 string. It is not impossible to have 14 bytes of 0s followed by a byte containing Al as data. Therefore, to guarantee that the 0s preceding an ID field are indeed marking the beginning of an ID field, a trick is performed on the byte containing Al: #### 200-ns Bit Cells This example illustrates the special byte following the 0 string (A1). Normally, a 0 following a 1 is not written; in this case, however, the rule is broken. Notice that in the second instance of a 0 following a 1, the 0 is written. This is the only time that this is true. It guarantees that the preceding 14 bytes of 0s are truly marking an ID field. The DRUN signal shown on sheet 12 is used to detect strings of 1s and 0s. DRUN is high during a continuous string of either 1s or 0s. It goes low if a data stream that contains both 1s and 0s is present. The WD1010 checks DRUN during a Read or Write-Sector command. HDRCATE is an output of the WD1010 controller. It is set high when the WD1010 is inspecting data. When HDRCATE is high, the DRUN one-shot input is connected to data from disk. When HDRCATE is low, the DRUN one-shot input is connected to PCK. These signals are used when the WD1010 is searching for a valid address and data mark. When the WD1010 starts executing a Read-Sector command, it sets HDRGATE low and checks DRUN. DRUN must go high since PCK will look like a continuous string of 0s. The WD1010 sets HDRGATE high and checks DRUN. If DRUN goes low within five byte times, the WD1010 resets HDRGATE and the sequence starts over. If DRUN remains high for five byte times, the WD1010 starts searching the data for an address mark. If DRUN goes low during this search, the WD1010 deasserts HDRGATE and the sequence starts over. If an address mark is found, a similar search for a data mark begins. If a data mark is found, the sector is read. If both address and data marks are not found within eight index pulses, bit 4 in the error register at E00002 is set and the command is aborted. ## Write Compensation The write compensation circuitry is shown on sheet 12. These circuits are used when data is written to disk. They compensate for timing errors that would otherwise occur when data is written to inner sectors. In the inner sectors, the distance between bit cells is reduced. If not compensated for, the read pulse produced by a bit in one cell reduces the distance between it and the read pulse produced by the bit in the next cell to an unacceptable point. To compensate for this, the time between pulses during write is increased. The signals EARLY\* and LATE\* control the delay. Associated circuitry is described below: - o The write data is synchronized with PCK+ at latch 16K. It then feeds the D input to F/F 16M. - o The hard disk separator PAL (14M) outputs a signal named MUX on pin 19. During a write operation, MUX has the same phase and frequency as $PCK^*$ . - o Since MUX is derived from PCK\* in this case, it is a 10-MHz signal. MUX is tied to the clock input (pin 11) F/F 15K. - o This signal inputs to a 50-ns, multitap delay line. Pin 12 is the 10-ns tapoff, pin 4 is the 20-ns tapoff, and pin 10 is the 30-ns tapoff. These outputs are tied to one of four decoders 14K. The 20-ns tapoff also clears F/F 15K. - o The select inputs of 14K are tied to LATE\* and EARLY\*. These two signals decide how long to delay the data, as dictated by the write precompensation circuitry in the WD1010. ## Floppy Disk Direct Memory Access The Western Digital WD2797 performs the functions of the floppy disk controller/formatter. This device contains a high-performance phase-lock-loop data separator and write precompensation logic. An on-chip VCO and phase comparitor allows adjustable frequency range for 5.25-inch and 8-inch floppy disk interfacing. Pin Functions (Sheet 13) for the WD2797 are listed in Table 2-24. Table 2-24 Pin Functions WD2797 | Pins | Signal Description | |-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-14: | D0-D7; eight bidirectional buses used for transfer of commands, status, and data. | | 5-6: | A0-A1; these inputs select the register to transmit/receive data on the data bus under control of WE-/RE | | 4: | Read-enable; a low on this input controls the placement of data from a selected register on the data bus when CS is low. | | 2: | Write-enable; a low on this input gates the data on the data bus into the selected register when CS is low. | | 3: | Chip-select; a low on this input selects the chip and allows computer communication with the device. | | 22: | Test; a low on this input allows adjustment of external resisters by enabling internal signals to appear on selected pins. | | 27: | Read data; digitized read-back of the flux reversals on the floppy disk. | | 32: | Ready; because of strapping, this signal goes low when the door is closed and the drive is selected; it goes high when the door is open and the drive is selected. The 2797 disk controller does not interrupt the processor when the ready signal changes states, so the processor must poll the controller periodically to determine when a floppy disk has been mounted or dismounted. | | 34: | Track 0; asserted by the selected drive when the head is positioned over track 0. | Table 2-24 Pin Functions WD2797 (Continued) | Pins | Signal Description | |------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 35: | Index; asserted by the selected drive when the index hole is passing over the index sensor. This signal pulses every 200 ms and has a nominal duration of 4 ms. | | 36: | Write-protect; asserted by the selected drive to indicate that a write-protected floppy disk is mounted. | | 23: | Pump; high-impedance output signal that is forced high or low to increase/decrease the VCO frequency. | | 26: | VCO; an external capacitor tied to this pin adjusts the VCO center frequency. | | 15: | Step; pulsed low by the controller to move the head one track in the direction indicated by the direction signal. The 2797 disk controller issues one step pulse every 3 ms. The drive ignores step pulses that would force the head to a negative track number or beyond track 79. The drive also ignores step pulses that occur when write-enable is active or the select line is inactive. | | 16: | Direction-select; driven low by the controller when stepping to a larger track number; driven high when stepping toward track 0. | | 25: | Side-select; when driven low by the controller, head 1 is selected; when driven high, head 0 is selected. | | 29: | Track greater than 43; enables write precompensation for tracks 44-76. | | 28: | Heads load; controls the loading of the read/write heads against the media. | Table 2-24 Pin Functions WD2797 (Continued) | Pins | Signal Description | |------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 30: | Write gate; enables the write circuits on the drive, provided the floppy disk is not write protected. | | 31: | Write data; MFM or FM output pulse per flux transition. WD contains the unique address marks as well as data and clock in both FM and MFM formats. | # WD2797 Registers The WD2797 has the following internal registers that must be programmed before disk operations: Table 2-25 WD2797 Registers | Address | Read Information | Write Information | |---------|------------------|-------------------| | E10000 | Status register | Command register | | E10002 | Track register | Track register | | E10004 | Sector register | Sector register | | E10006 | Data register | Data register | ### WD2797 Commands The WD2797 floppy disk controller executes a total of 11 commands. It does not have the implied seek function of the hard disk controller, but it does have a Read-Track command that allows examination of an entire track of data for debugging purposes. The commands are listed in Table 2-26. Table 2-26 WD2797 Commands | Command | Function | |--------------------|------------------------------------------------| | Restore | Moves heads to track 0 | | Seek | Steps heads to track number in track register | | Step | Moves heads one step in same direction as last | | Step-in | Moves heads in one track | | Step-out | Moves heads out one track | | Read<br>Sector | Reads one or multiple sectorsaborts if error | | Write<br>Sector | Write, same as read | | Read<br>Address | Reads first ADX mark and ID field past index | | Read Track | Reads track, reports errorsno abort | | Write<br>Format | Formats system, provides data for gap and ID | | Force<br>Interrupt | Drives interrupt line | ### Initializing Floppy Disk Write The following list describes the operations a program must perform to initialize the system before sending a Read Sector command to a disk controller: Loading System Disk Bits and DMA Interface - o Selects the drive by writing to the disk control register. - Loads the DMA address registers with the starting logical address. (The address is incremented from low memory to high memory.) - o Loads a 0 to D14 (DMAR/W-) of the miscellaneous register. - o Loads the DMA count register with DMAEN+ = 1, IDMAR/W- = 0, and the 2's complement form of the number of words to be transferred. This causes an invalid transfer of one word and thus requires the reloading of the address register. - o Reloads the DMA address register with the starting logical address. - o Reloads the DMA count register with DMAEN+ = 1, IDMAR/W- = 0, and the 2's complement form of the number of words to be transferred. The reason for reloading the DMA address register and the DMA count register is that, when the DMA count was initially loaded, the DMAEN+ bit was toggled from low to high. This generates a false disk bus request, and the system does a DMA write to memory. The transfer is false because we have not yet received any bytes from the disk controller. Whatever was latched in the disk buffer was written to memory. The U/OERR- (bit 15, read) in the DMA count register indicates an underrun or overrun has occurred. With the bus bandwidth and the priority setting of the bus masters, disk DMA should not experience any underrun or overrun error in any bus traffic condition. ### Setting Up the Disk Controller - Loads the controller registers with the desired sector and track number using the disk data bus DDO-DD7. - Writes the Read-Sector command to the disk controller. Execution of the DMA read begins as soon as the controller receives this command. The same DMA circuit is being used with the floppy disk as was used with the hard disk. The DMA count register and the DMA address register are loaded in the same manner as discussed earlier. The major difference between the disk-write operation discussed earlier and a disk-read operation is that, with a read operation, data is transferred from the disk in bytes, assembled into words at the disk buffer, and written to memory. # Executing Floppy Disk Write Once the DMA has been set up and the WD2797 has been commanded to read, the floppy controller finds the programmed sector and begins to read the MFM data. It then converts the MFM data into binary data and assembles a byte. The byte is placed in the 2797 data register, and a data request is presented to the system. #### Sheet 13: Read data is input to the floppy controller on pin 27. When a byte has been assembled, the 2797 asserts FDDRQ+ from pin 38. #### Sheet 2: - o FDDRQ+ is tied to the D input of F/F 16K. This is an asynchronous signal that is synchronized with the system by 1PCK+ generating FDDRQL+. - o FDDRQL+ inputs to the disk PAL 24H. The PAL generates TFER\*. - o FDTFER\* starts a timing sequence; QB\* is generated on the 1PCK+ following FDTFER\*, the next 1PCK+ generates QC\*, and the next 1PCK+ generates QD\*. • TFER\* goes active at QB\* time and generates FDRE\*; TFER\* and FDRE\* remain active until QD\* time. Timing diagram, Figure 2-3, shows the relationship between the preceding signals: Figure 2-3 Floppy Disk Write Timing Diagram ### Sheet 13: o Chip-select\* (pin 3) on the WD2797 is tied low. FDRE\* causes the controller to drive the byte onto the DD bus and to disable FDDRQ\*. Now that there is a byte of data on the DD bus, the DMA circuitry must latch the byte in the stacking portion of the data buffer. The DMA waits for another byte and stacks it with the first byte, forming a word. Then a disk bus request is generated. When the bus grant is received, the word is written to a memory address specified by the DMA address counter. (Refer to sheet 6 of 6 in the gate array schematics.) As mentioned earlier, the first DMA transfer is a false write to memory. The following sequence describes the generation of DKRQ\*: - O Gate 1D pin 10 is high as long as it is not terminal count. Pin 9 is high because F/F 4A is previously clear. Pin 13 is high because we are doing a DMA write. When the DMA is enabled by setting bit 15 in the DMA count register, pin 12 goes from low to high. - This causes a low to high transition on 4D pin 8, which clocks pin 11 of F/F 4C. The F/F clears and pin 9 goes low. - o The low from pin 9 forces a high from gate 1E pin 3. Pin 3 is tied to the D input (pin 12) of F/F 1C. The trailing edge of the next 2PCK+ clears this F/F, generating DKRQ\*. At this point, the software is reading the DMA count register until it is incremented. This is done to tell when this false transfer has been accomplished. After the software has determined that the count register has incremented, the DMA address register and count register are reloaded. Then the controller is issued a command sequence, and a genuine DMA write operation begins. - o F/F 4A is clear initially (inactive DMAEN+). The Q output is low, partially enabling 4E. TFER\* fully enables 4E (pin 13) and pin 11 is driven low. - o TFER\* is a 200-ns signal. When it goes inactive, pin 11 of 4E goes from low to high. This latches the byte in the high byte of the buffer and toggles the TFER F/F (4A) set. The DMA waits for another request (FDDRQ+) from the controller. When the controller requests, the disk PAL again asserts FDRE\* and TFER\*. FDRE\* reads the next byte, which is latched in the low byte of the data buffer when TFER\* goes inactive. o When TFER\* goes inactive, the TFER F/F toggles from set to clear. This enables pin 9 of gate 1D (the other pins are still enabled as before), which causes a legitimate DKRQ. From this point, the operation proceeds the same as the DMA read operation, except that the data is going in the opposite direction. ### Video Bit Map The video circuits appear on two sheets of the schematics. The circuits on sheet 8 contain bit map memory ICs 14-17 and video shift register ICs 14-15. The video IC is shown on sheet 7 and on sheets 2 and 3 of 6. The IC generates timing and control signals, including vertical and horizontal synchronization for the composite video and bit map address and read/write control signals for the bit map memory. # Screen Layout Video is bit mapped. The screen is divided into thousands of points. Each point is assigned an address and a binary value of 1 or 0 in a 16-bit word. These words are stored in bit map memory. Adjacent points are grouped together so they can be stored in the same 16-bit word. To create a display, an electron beam scans the screen as shown in Figure 2-4, moving from left to right and top to bottom. The display produced in this way is called a <u>raster scan</u>, and each picture produced is called a <u>field</u>. The bit map memory holds one field; 60 fields per second are produced. The relationship between bit map address and screen position is shown on the next page. At the beginning of a scan, the beam points to the upper-left corner of the screen. The contents of the video RAM at address 420000 are loaded into a 16-bit shift register. As the beam moves from left to right, the contents of the shift register are shifted out to the monitor. If the current bit is a 1, the beam is on and a point of light appears on the screen. If it is a 0, the beam is turned off and the screen is dark at that point. The horizontal sweep circuit moves the beam to the right until it reaches the right side of the screen. Then the horizontal sync pulse causes the horizontal sweep circuit to swing the beam back to the left side of the screen to start the next horizontal sweep. At the same time that the horizontal sweep circuit is causing the beam to scan from left to right, the vertical sweep circuit is causing the beam to move from top to bottom. The rate of vertical sweep is such that the beam moves down the screen the width of one line for each horizontal sweep. When the last bit is displayed in the lower-right corner of the screen, the vertical synchronization pulse and the horizontal synchronization pulse turn on. This causes the beam to return to the upper-left corner to start the next field. In the <code>UNIX PC raster</code>, there are 348 horizontal lines, each line containing 720 bits. Each point is called a <code>pixel</code>. Thus, there are 720 x 348 or 250,560 pixels. Figure 2-4 Screen Layout Bit map memory is composed of dynamic RAM. Reading and displaying an address serves a dual purpose of refreshing and displaying the contents of the bit map. The UNIX PC allocates 32 KB of system address space for the bit map. This is implemented by a 16K x 16 bit dynamic RAM array. The screen layout above illustrates how the processor must address the bit map. Data written to address 420000 produces the pixels on the first line at the upper-left portion of the screen. The refresh circuit reads 16-bit words from the bit map, addressing the bit map with an address counter. It then loads the word into a shift register and shifts it out at the speed of a 20-MHz pixel clock. This creates a serial video stream. A 20-MHz clock has a cycle duration of 50 ns, so one word is shifted out every 800 ns. There are 45 words (720 pixels) in each row. The refresh logic reads them consecutively and shifts them out to the deflection board. After all of the pixels on a line have been displayed, horizontal retrace occurs. This lasts 11 word times (176 pixels) or 8.8 us. Vertical retrace lasts 1079 word times. The beam must be turned off during retrace to prevent diagonal retrace lines from appearing on the screen. If the intensity is turned up too high, retrace lines may appear even though the video signal from the logic board is correct. #### State Generator The state generator circuit is shown on Video IC sheet 1. The state generator produces four state signals: S0-S3, see Figure 2-5. These signals generate timing signals that allow the 68010 to write to the bit map and the refresh address generator to read. The effect is such that a person looking at the screen is not aware of the loading operation. The screen appears to change instantaneously. The state signals constantly repeat the same sequence of state conditions shown below. Each state lasts 50 ns clocked by the 20-MHz signal. Each state is given a number by assigning binary weight values to the state signals: S0 has a weight of 1, S1 a weight of 2, S2 a weight of 4, and S3 a weight of 8. Thus, each 50-ns period has a state value, calculated by adding weights, that repeats over and over. The period of 0-50 has a state value of 1. The period of 50-100 has a value of 3. Thus, the repeating sequence of state values is 1, 3, 7, 15, 14, 12, 8, 0. Figure 2-5 State Signal Generator Timing These states are used to perform the following timing functions: - o Generation of a signal called BMWINDOW, which allows the 68010 and the refresh address counter to write to the bit map by switching the select input to the address multiplexer. - O Generation of BMRAS (bit map row address strobe) and BMCAS (bit map column address strobe) signals to load and refresh 68010 row and column address into the bit map. - Generation of BMACK, which in turn generates DTACK to tell the 68010 to finish a bit map write machine cycle. - Generation of SRLD to load 16-bit words from the bit map into the shift register. ### 68010 Loading of Bit Map 32 KB of system address space is allocated for the video bit map, addresses 420000-427FFF. When the processor needs to alter information on the monitor, it does so by loading data into the video bit map RAM chips. The processor must be in supervisor mode to do this. The following discussion describes a 68010 write operation to the bit map. First, the signal BMSEL (bit map select) is generated by address decoding. This signal tells the video IC that the 68010 wants to address the bit map. The signals to generate BMSEL are listed in Table 2-27. | Table 2-27 Signal Status to Generate BM | |-----------------------------------------| |-----------------------------------------| | Sheet | Signal | Status | |-----------------------------------------|-------------------------------------------------|---------------------------------| | 17<br>17<br>17<br>4<br>4<br>4<br>4<br>4 | SPA23 PA22 GATE1* PA16 PA17 PA18 PA19 BGC* SUPV | 0<br>1<br>0<br>0<br>1<br>0<br>0 | On sheet 2 of 6, a signal called CCK is combined with the output of flipflop 2F (pin 6) to generate BMWINDOW\*. The F/F 2F (pin 9) is set for one cycle through the states and cleared for the next cycle. It keeps toggling with every cycle, so it generates CCK every other cycle through the states. CCK switches the video RAM address input between the processor and the raster refresh circuitry. This is done by the output of IC 1F (pin 8). When 1F (pin 8) is low, multiplex chips select address input from the system address bus. 1F (pin 8) is low when CCK\* and 2F (pin 6) are high. 2F (pin 6) is clocked high within 800 ns after BMSEL\* goes low. A processor reference to video RAM can be a fast cycle (400 ns), but if CCK is active when BMSEL\* arrives, the processor has to wait until the next cycle of states. For the longest possible cycle, it could take the processor 800 ns to reference the bit map. Gate 1F (pin 8) low switches address multiplex chips IC2J, 2K, 2L, and 2M so that bit map address output BRA0-BRA7 is loaded from address bus A1-A14. BMACK+ is generated at S3 (150 ns) and is used on sheet 2 to assert DTACK\* to the 68010 to complete the machine cycle. BMWINDOW\* enables bit map data transceivers 13A and 17B on sheet 8. It also gates the R/W\* signal through 26F, creating BMR/W\*. The direction of the transceivers is controlled by R/W\*. For our discussion, that signal will be low, causing the transceivers to pass the data from the system data bus to the bit map data bus. On sheet 8 the bit map is set up for a read operation unless the 68010 is performing a write. Gate 26F controls bit map read/write (BMR/W\*) at pin 3. BMRAS\* and BMCAS\* strobe in the address, and the data is output 120 ns after RAS is asserted. # Bit Map Address Multiplex The bit map address MUXs are 2J, 2K, 2L, and 2M. They select an address from the system address bus when the 68010 is accessing the bit map, or they select the address from the refresh address counter (1K, 1L) during raster refresh. The MUX's output row address when S2 is low and column address when S2 is high. In other words, the row address is gated until the 100-ns mark, and then the column address is gated. Tables 2-28 and 2-29 illustrate which address bits are selected and the functions of these bits with respect to the select inputs (A and B) of the bit map address MUXs: Table 2-28 Multiple Select Status | Α | Function | |---|------------------------| | 0 | 68010 row address | | 1 | 68010 column address | | 0 | Refresh row address | | 1 | Refresh column address | | | 0 1 0 | | В | A | 7 | 6 | 5 | 4 | 3 | 2 | 1 | o | |---|---|------|------------|------------|------|------|-----|-----|------| | 0 | 0 | A14 | A13 | A12 | A11 | A10 | Α9 | A7 | A6 | | 0 | 1 | GRND | <b>A</b> 6 | <b>A</b> 5 | A4 | АЗ | A2 | A1 | GRND | | 1 | 0 | BA14 | BA13 | BA12 | BA11 | BA10 | BA9 | BA8 | BA7 | | 1 | 1 | GRND | BA6 | BA5 | BA4 | ваз | BA2 | BA1 | GRND | Table 2-29 Bit Map Address Multiplex Assignments The row address and column address strobe signals are generated as described below on sheet 2 of 6. Gate 2E (pin 6) enables RAS and CAS. Pin 5 is used during a 68010 reference and pin 4 is used during screen refresh. Gate 1J (pins 3 and 5) is enabled by S1 and/or S2, and it outputs BMRAS\* at 50-300 ns. Gate 1J (pins 9 and 13) is enabled by S0 and/or S3, and it outputs BMCAS\* at 150-400 ns. Gate 2E (pin 6) enables the 1J gates to generate BMRAS\* and BMCAS\* when CCK+ is high, as previously described (BMRAS\* at 50-300 ns, BMCAS\* at 150-400 ns). On sheet 8, ICs 14A, 15A, 16A, and 17A are $16K \times 4$ , 120-ns dynamic RAM chips that compose the bit map. BMRAS\* strobes in the row address, BMCAS\* strobes in column address, and BMR/W\* causes the data on the BD bus to be written into memory. ### Refresh Address Counter On sheet 3 of 6, chips 1K and 1L make up a 16-bit binary counter. These logic elements are used as the refresh address counter, which addresses the bit map during a refresh operation. The counter is incremented at the end of each video window when HSYNC\* is inactive. HSYNC\* is active only during horizontal retrace. The counter is cleared by CLR RFADD+ at the end of vertical retrace. The counter generates addresses 0000-4163 hex before it is reset. Addresses 0000-3D2A are valid screen addresses. Addresses 3D2C-4163 are generated during vertical retrace and therefore are not used for obtaining pixels. # Horizontal Synchronization On sheet 3 of 6, logic element 1G, the horizontal counter, generates the timing for horizontal synchronization/retrace. It is clocked by CCK+. It executes a repeating cycle as follows. Assume that this counter starts counting from 0 and that HSYNC is high. This starts the horizontal retrace. It is clocked by CCK+ when it reaches a count of 10. Gate 3G (pin 8) outputs a low and resets HSYNC low. When the counter reaches a count of 54, IC1H (pin 8) goes low. This sets HSYNC high and resets the counter, thus starting the cycle over. Note that HSYNC inhibits the bit map address counter during horizontal retrace. ### Vertical Synchronization Gate 1N decodes the selected address bit from the BA bus. It outputs low at address 3D2C. This address is driven from the refresh address counter after the last word has been displayed in the lower-right portion of the screen. At this time, 1N clears F/F 1A, causing the generation of VSYNC+, which marks the beginning of vertical retrace. F/F 1A also disables DISPEN\*. The refresh address counter is not disabled during vertical retrace. It is incremented 1079 times. The highest address generated is 4163H. Gate 1H outputs low at refresh address 4163H, marking the end of vertical retrace. VSYNC+ is disabled using F/F 2H (pin 2). This flop also generates CLR RFADD+, which resets the refresh address counter. # Shift Register On sheet 2 of 6, gate 2D (pin 6) generates SRLD\* at 300-350 ns. This signal causes the data output from the video RAMs to be loaded into a shift register, IC14B and 15B on sheet 8. The shift register serializes the data, creating the video stream. SRLD+ latches the word from the bit map into shift registers 14B and 15B. The data is then shifted out at the speed of 20MCK+, which is sometimes referred to as a <u>pixel clock</u>. The pixels leave the shift register from pin 17 of 15B. The video stream is synchronized again with 20MCK+ at F/F 18D (pin 2). After the video passes through XOR gate 26B (pin 8), it is routed directly to the CRT deflection board. # Telephony There are three telephone line connections to the **UNIX** PC. One is for a user telephone, which is referred to as the handset. The other two are active telephone lines, designated L1 and L2. These lines are controlled by circuitry shown on sheet 25. JPH3 is the handset connector for the user telephone. The UNIX PC telephony circuitry supports the following functions: - o Data transmission--through the switched capacitor modem 882A modem shown on sheet 26 - Number dialing--dial network 838A chip on sheet 26; serial dial data generation on sheet 7 (DIALER EN\* and DIALER TXD) - o Telephone line management functions and control signals-through circuitry on sheets 25 and 26 listed below: Detection of ringing on line 1 or line 2--L1 RING, L2 RING (sheet 25) Message waiting detection on line 1--MSG WAIT\* (sheet 25) Handset offhook detection--OFF HOOK\* (sheet 25) Line 1 or line 2 on hold--L2 HOLD, L1 HOLD (sheet 25) Dial-tone detection on line selected for data transmission--DT DET (sheet 26) Handset line select--HDSET RELAY\* (sheet 25) Modem line select--L1 MODEM, L2 MODEM (sheet 25). #### Line Control Line control circuits shown on sheet 25 are described below. There can be two lines coming in, as well as one handset attached. Line 1 comes in at location 8C (see guides on margins of schematics). If we follow tip (T/R1) and ring (R/T1), we find that they come into bridge rectifier (CSB1) at 6C. This rectifies the 90VAC ringing signal. The time constant of R35-C240 blocks short pulses. The long ringing time causes optoisolator 7P to conduct, giving us L1 RING\*. This is a status line back to sheet 4/C7, to register 9K, which is available to the CPU as a read-only register at 450000. The opto-isolator prevents potentially hazardous line voltages from coupling into the circuit. A similar circuit is at 4D, except that there is no R-C time constant, so that MSG WAIT-\* appears with a short pulse. This pulse is so short that it is latched into the status register by an extra flop on sheet 4/C6, so that its presence can be observed by the CPU without a prohibitively high polling rate. The CPU looks for a change in status on this line, rather than a high or low. Sheet 4/3B is the telephony control register. Unlike the status register, which is four bits read at a specific address, this register is treated as eight addresses, 490000-497000. PD14 is written to the appropriate addresses to control telephony. Writing a 0 to 492000 gives HOOK RELAY 1\*, which turns on Q14 at sheet 25/D6, energizing relay K1. This connects the primary of the audio transformer T1 across tip and ring, presenting a 600-ohm load to the CO and drawing loop current. Audio is passed through T1, safety limited by CR5, and then down to analog switch 5M. The DG201 analog switch is controlled by inputs from sheet 6/5C, a control register at address E4X000. A low at pin 1 (A1) causes a bidirectional link from pin 2 to 3 (IN1 to OUT1). Audio then passes to sheet 26/C8 and into the 838A dial/network. The signal L1 HOLD+ at sheet 25/C1 turns on Q4, supplying a 510-ohm path to ground and making line 1 quiet while on hold. Most of this circuitry is duplicated for the line 2 interface, with the exception of MSG WAIT\*. At 7C, relay K3 determines which line is routed toward the handset, with line 1 being the power-loss default, and K6 at 4B determines whether the handset is attached to the active line. The assemblage at 4C detects current drawn from the line as an indicator that the handset is offhook. If K6 has the handset disconnected from the line, this offhook signal is provided through CR12, at the bottom of K6, which also provides enough voltage so that the handset does not appear dead. Line control signals are written by the 68010 on sheet 4 by first decoding address bits A16-A23 for status as shown below: Address Status to Enable Telephone Control Register | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address bits | |----|----|----|----|----|----|----|----|------------------| | 0 | 1. | Х | Х | 1 | 0 | 0 | 1 | Control register | After status is determined, address bits A12, A13, and A14 are used to address the 74LS138. Processor data bit PD14 then writes a high or low into whichever bit is addressed, as shown in table 2-30. Table 2-30 Address Status to Select Telephony Control Register | Addı | ress l | Bits | Control Bit | | |----------------------------|---------------------------------|---------------------------------|----------------------------|-------------------------------------------------------------------------------------------| | 15 | 14 | 13 | 12 | Selected | | X<br>X<br>X<br>X<br>X<br>X | 0<br>0<br>0<br>0<br>1<br>1<br>1 | 0<br>0<br>1<br>1<br>0<br>0<br>1 | 0<br>1<br>0<br>1<br>0<br>1 | HDSET RELAY+ LINE SEL2* HOOK RELAY1* HOOK RELAY2* L1 HOLD+ L2 HOLD+ L1 A-LEAD* L2 A-LEAD* | Table 2-31 shows hex addresses that can be used to write to the telephony control register. Table 2-31 Telephony Control Register--Address 49X000 | Address | Bit | Signal | Description | |------------------------------------------------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 490000<br>491000<br>492000<br>493000<br>494000<br>495000<br>496000<br>497000 | 14<br>14<br>14<br>14<br>14<br>14<br>14 | HDSET RELAY+ LINE SEL2* HOOK RELAY1* HOOK RELAY2* L1 HOLD+ L2 HOLD+ L1 A-LEAD* L2 A-LEAD* | <pre>1 = Handset on line 0 = Line 2 select 0 = Hook relay 1 on 0 = Hook relay 2 on 1 = Line 1 hold 1 = Line 2 hold 0 = Line 1 A-lead connect 0 = Line 2 A-lead connect</pre> | This register is forced with 0s after reset. # Telephony Status Register Also on sheet 4 is circuitry used by the 68010 to read the status of four line control outputs by loading an address on the system address bus. This enables a buffer that loads the status of these bits on data bus bits D0-D3. The address status to enable this buffer is: Address to Enable 68010 Line Status Read | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address bits | | |----|----|----|----|----|----|----|----|--------------|---| | 0 | 1 | х | х | 0 | 1 | 0 | 1 | Status | _ | The status bits read and the corresponding processor data bus bits are shown in Table 2-32. Table 2-32 Telephony Status Register--Address 450000 (Read Only) | Data Bit | Description | Signal | |----------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------| | 00<br>01<br>02<br>03 | OFF HOOK*<br>L1 RING*<br>L2 RING*<br>MSG WAIT* | <pre>0 = Offhook 0 = Line 1 ring 0 = Line 2 ring Toggled each time a message waiting pulse is detected</pre> | #### Dialer Interface On sheet 4 a control signal called TM/DIAL WR\* is decoded to enable circuitry used on sheet 7 to load data from the system address bus and to convert it to a serial data stream for the dial network chip on sheet 26. TM/DIAL WR\* is asserted when the address bits have the following status: #### Address Bus Status to Enable Serial Dial Data | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address bits | |----|----|----|----|----|----|----|----|--------------| | 0 | 1 | Х | Х | 1 | 0 | 0 | 1 | Status | On sheet 4 of the Video IC schematic, TM/DIAL WR\* enables a three-to eight-line decoder inside the video IC. Address bits A10 and A11 are decoded by the decoder to select one of two functions. First, if Al0 = 1 and Al1 = 0, then eight bits of data from the address bus are loaded into a shift register whose output is named DIALER TXD. This is the lower byte. Then with address bits A10 = 0 and A11 = 1, a load signal loads a second set of eight bits (upper byte) of data from the address bus into a second shift register. This load also starts the shift registers shifting data out at DIALER TXD at the rate of 4800 baud. At the same time, an internal counter is counting. After the sixteenth pulse, the registers are disabled. ### Serial Communication The UNIX PC provides an RS-232-C channel that is capable of making either synchronous or asynchronous serial data transfers. #### RS-232 Serial Port Serial data at the RS-232-C port is converted to parallel data by a 7201 dual universal synchronous/asynchronous receiver/transmitter (USART). # RS-232-C Signal Levels Voltage levels on the RS-232-C interface are +/-12V without load. ### RS-232-C Signals Table 2-33 lists the signals applied to the DB-25, RS-232-C connector. The list gives the pin number, signal name, and direction with respect to the $UNIX\ PC$ . Table 2-33 RS-232-C Signals | Pin | Name | Direction | |--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>15<br>17<br>20<br>22<br>24 | Ground (shield) Transmit data Receive data Request to send Clear to send Data set ready Ground Carrier detect Transmit clock Receive clock Data terminal ready Ring indicator DTE transmit clock | Bidirectional Output Input Output Input Input Bidirectional Input Input Input Input Input Input Input Output Input Output | Figure 2-6 shows an example of RS-232-C terminal cable pin assignments. UNIX PC # 1 ------ 1 2 ------ 3 3 <----- 2 4-5-6 4-5-6 7 ------ 7 8 -----> 20 20 <---- 8 Terminal Figure 2-6 UNIX PC to Terminal Cable Pinning Standalone Diagnostic Loopback Plug The standalone diagnostics test RS-232-C functions through the use of a diagnostic loopback plug, which must be installed when a channel is being tested. Figure 2-7 shows the loopback plug pin assignments. ### Loopback Plug Pinning (2) Transmit data --- (3) Receive data (4) Request to send --- (5) Clear to send (4) Request to send --- (8) Carrier detect (20) Data terminal ready --- (6) Data set ready (20) Data terminal ready --- (22) Ring indicator Figure 2-7 Loopback Plug Pinning #### Baud Rate Generation The baud rates are generated in the video IC. The baud rate generation circuitry consists of binary counters 4F and 3D, latch 4L, and comparitors 4G and 4J. The baud rate is programmable to provide a wide frequency range (307 KHz-1.2 KHz). The baud rate is selected by loading a value into latch 4L. The latch is loaded when the processor refers to address 4B0XXX, where XXX is the value to be loaded (the latch receives its data from the address bus). Once the latch has been programmed, the baud rate generation circuit outputs a signal named TMOUT, the resultant baud rate. The frequency is computed using the following formula (where N is a value between 0 and 255, previously loaded into latch 4L): $$TMOUT = [1/(4 \times N)] \times 1.2288 MHz$$ The input to counter 4F is a 614-KHz clock. This frequency is easily divisible to obtain the range of internally generated baud rates. Comparitors 4G and 4J compare the variable count from counter 4F with the reference count from latch 4L. When the variable count equals the reference count, 4G outputs a high on pin 6. This high is synchronized with the 1.2288 MHz COMMOSC frequency at F/F 3H (pin 3). When this F/F sets, pin 5 outputs a high that clears counter 4F and clocks F/F 3H (pin 11). The signal generated from pin 11 is the baud rate. #### 7201 Serial Controller The 7201 Multi-Protocol Serial Controller performs all RS-232-C communications control, including serial data in/out, status update, and CPU interrupts. This chip can be used in either interrupt-driven mode or polled mode. UNIX PC software uses interrupt-driven RS-232-C communications. #### 7201 Functions The controller must be loaded with a set of parameters before actual data transfers are executed. Once programmed with data length, parity generation/detection, number of stop bits, and so on, the chip is capable of transmitting bytes written into its data register by the 68010. During receive operations, the controller assembles characters received from the serial line and places them in its data register so the 68010 can read them. The controller operates in interrupt-driven mode. When a byte is needed for transmission or when receive serial data has been assembled into a byte, the controller interrupts the processor. Upon receiving the interrupt, the 68010 vectors itself to the appropriate RS-232-C interrupt handler (software). The 7201 controller is shown on sheet 14. The 68010 transfers data to the controller using the lower eight bits of the data bus, and it addresses control registers in the controller using system address bits A1 and A2. The chip-enable and interrupt signals are described later in the "Modem" section of this chapter. The controller features two serial channels: channel A interfaces the RS-232-C port, and channel B interfaces the UNIX Pc's internal modem. # 7201 Clock Selection The 7201 controller chip is divided into two separate channels. Each channel has the option of communicating either synchronously or asynchronously. If a channel is programmed for synchronous operation, it must use the clock rate produced by the baud rate generation circuitry. If a channel is programmed for synchronous operation, it can use an external clock provided by the device with which it is communicating. This device is generally a modem. The TXCKA and RXCKA clocks to channel A are selectable between the TXCK and RXCK clocks, respectively, or the programmable baud rate generator described above. The output of the baud rate generator is called TMOUT. The select control is controlled by the DTR output at channel B. A 0 selects the RS-232 clock, and a 1 selects the baud rate generator. The TXCKB and RXCKB clocks to channel B are selectable between the MODEM TXCK and MODEM RXCK clocks, respectively, or a fixed 19.2K-baud generator. The select control is controlled by the MCKSEL bit at the miscellaneous register. A 0 selects the modem clock, and a 1 selects the fixed 19.2K-baud generator. ### 7201 Registers Table 2-34 lists addresses that access the internal registers of the 7201 controller: Address Read Write E50000 Ch. A: data read Ch. A: data write E50002 Ch. B: data read Ch. B: data write E50004 Ch. A: status read Ch. A: command/parameter E50006 Ch. B: status read Ch. B: command/parameter E68000 Transceiver control 1 E69000 Transceiver control 2 E6A000 Transceiver status Table 2-34 7201 Registers #### Modem The bandwidth available on a common telephone line supports frequencies of 300-3300 Hz. Since the dc levels 0 and 1 cannot be sent on the telephone line, frequencies representing those levels are sent. This method is called <u>frequency shift keying</u>. The frequencies used must be twice the desired data change rate to be deciphered accurately. They also cannot exceed 3300 Hz, the top of the bandwidth window. At speeds of 1200 baud and higher, this scheme no longer works, because a frequency above 2400 Hz must be used to signal in one direction and insufficient bandwidth is left for signaling in the other direction, at least not simultaneously. So a method called phase shift keying is used, in which the modem sends out a continuous carrier during transmit time. Data is signaled by changes in the phase of this carrier, rather than its presence or absence. The two modems must be in sync with each other, so that a change in phase can be detected. By using high-quality modems, speeds of 9600 can be obtained, but 300, 1200, and 2400 baud are the most popular. On the UNIX PC, 1200 baud and full duplex are used. RS-232 data transmission is described as being either <u>sync</u> or <u>async</u>. The UNIX PC uses async data transmission. Async data has a start bit and a stop bit associated with every character, whereas sync data has phase sync fields at the beginning and end of each burst of characters. When a modem auto-answers, it is quiet for two seconds, and then it sends a 2025-Hz answer tone. At this point, the originating modem detects the answer tone and responds with a mark signal, either at 1270 Hz, indicating a 300-baud transmission, or 1200 Hz, indicating a 1200-baud transmission. At 300 baud, the modem transmits full duplex (both directions simultaneously) by dividing the frequency range into two distinct bands, <u>originate</u> and <u>answer</u>. The modem that originates the call transmits 1070 Hz to indicate a space and 1270 Hz to indicate a mark. The modem that answers the call transmits 2025 Hz to indicate a space and 2225 Hz to indicate a mark. At 1200 baud, the RS-232 data delivered to the modem is still in async format, but data delivered onto the telephone line by the modem is actually sync format. The originating modem sends carrier at 1200 Hz, whereas the answer modem sends carrier at 2400 Hz. Data is indicated by changes in the phase of the carrier. #### Modem Bus On sheet 26 the processor data bus is connected to the modem data bus. The processor data bus loads control data into the modem before data transmission. When data transmission takes place, the 68010 sends parallel data to the 7201 serial port controller, channel B on sheet 14. The serial port then provides serial data to the modem. The chip select for the modem (MODEM CS\*) and the 7201 are generated on sheet 4. The status of data bus bits to address the modem and the 7201 are: ### Address Status for Modem and Serial Controller Enable | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address bus bits | |-------|----|----|----|----|----|----|----|-------------------| | <br>1 | 1 | 1 | 0 | Х | 1 | 0 | 1 | 7201 chip select | | 1 | 1 | 1 | 0 | Х | 1 | 1 | 0 | Modem chip select | Bits A23 and A22 are decoded on sheet 17 to produce I/OEN used on sheet 4. #### Modem Clock Select On sheet 14, a signal called MODEM CK SEL\* selects clock signals to send to the 7201 serial controller when the serial controller is being used with the modem. MODEM CK SEL\* is generated on sheet 15 using system bus data bit D12 and chip-enable signal MREG WR\* generated on sheet 3. MREG WR\* is part of the miscellaneous control register. It selects the programmable baud rate generator clocks from the modem when low or a fixed 19.2K-baud clock when high. Address bus status to assert MREG WR\* is: | Address | Status | to | Assert | MREG | WR* | |---------|--------|----|--------|------|-----| | | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address | |-----------------------------------------|----|----|----|----|----|----|----|----|----------| | *************************************** | 1 | 1 | Х | Х | 1 | 0 | 1 | 0 | MREG WR* | ### Modem Registers Table 2-35 lists the addresses that access the internal registers of the modem: | Address | Write | |------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | E60000<br>E63000<br>E64000<br>E65000<br>E66000 | Line control Relay and lamp drivers Options A/S and handshake Options CCITT and disconnect RD, SD control, and chip test | Table 2-35 Modem Registers # Modem Line Select On sheet 4 the 68010 writes to the general control register using a control signal called GCRWR\* (general control register write) from sheet 4. This signal enables a 74LS259 addressable latch, shown on sheet 6. The latch receives inputs from system address bus bits A12, A13, and A14, which are decoded to select an output. The status of the output is determined by the logic level on 68010 data bus bit PD15. In this way the 68010 can use the status of PD15 to enable the modem line select bits L1 MODEM or L2 MODEM or the dial network control signal D/N CONNECT (dial network connect). These signals listed in Table 2-36 are used on sheet 25. The status of the system address lines to generate GCRWR\* and select a given modem line is: | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address | |----|----|----|----|----|----|----|----|---------| | 1 | 1 | 1 | х | х | 1 | 0 | 0 | GCRWR* | Address Status to Enable GCRWR\* Table 2-36 Address Status to Select Modem and Dialer Network Control Signals | Ad | Address Bits | | | | | | | | | |-------------|--------------|-------------|-------------|-------------------------------------|--|--|--|--|--| | 15 | 14 | 13 | 12 | Control Written to | | | | | | | X<br>X<br>X | 1<br>1<br>1 | 0<br>0<br>1 | 0<br>1<br>1 | L1 MODEM<br>L2 MODEM<br>D/N CONNECT | | | | | | ### Modem/7201 Signals Channel B of the 7201 is connected to the modem. The following list describes the usage of the signals associated with channel B: 7201 carrier detect <----- RS-232 ring indicator 7201 receive clock <----- Modem receive clock/19.2K baud 7201 clear to send <----- RS-232 data set ready 7201 transmit data -----> Modem transmit data 7201 transmit clock <----- Modem transmit clock/19.2K baud 7201 receive data <----- Modem receive data In addition to the preceding RS-232 signals, the communications interface also supports the external transmitter clock output, which is pin 24 of the RS-232 connector. This signal is the programmable baud rate generator output. With the RS-232 DSR (data set ready) and RI (ring indicator) connected to channel B port bits, channel B port bit interrupt should not be used to prevent invalid interrupt being generated by the floating condition of DSR and RI. # Line Printer There is one parallel printer interface connector on the UNIX PC. It is located at the rear of the machine and is controlled by the printer data register. #### Ports The three input/output ports associated with the parallel printer interface are listed in Table 2-37. Table 2-37 I/O Ports | Port | Description | Read/Write | |--------|--------------------------------|------------| | 4F0000 | Line printer data register | Write | | 470000 | Line printer status register | Read | | 4A0000 | Miscellaneous control register | Write | Data on data bus bits D0-D7 are strobed into line printer data register bits PRD1-PRD8. ### Control Signals The printer port is shown on sheet 15 of the schematics. To send data to the printer, this circuitry performs the following three functions: - Sends eight bits of data from the lower eight bits of the system data bus to the 74LS374 eight-bit data buffer - o Reads the printer status from the 74LS244 eight-bit buffer - o Responds to interrupts from the printer Address status to decode LPDATAWR\* and LPSTATUS RD\* is: #### Line Printer Status and Data Address Decode | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address | |----|----|----|----|----|----|----|----|--------------| | 0 | 1 | Х | Х | 1 | 1 | 1 | 1 | LPDATAWR* | | 0 | 1 | х | х | 0 | 1 | 1 | 1 | LPSTATUS RD* | The line printer is operated through an eight-bit parallel Centronics interface. The line printer interface is interrupt driven and operates in byte mode transfers only. ### Write Sequence The write sequence that initiates the output to the printer is shown on sheet 15 of the schematics. Timing characteristics are shown in Figure 2-8. #### Sheet 15: - Latch 16P is the line printer data register, address 4F0000. The first step necessary to output to the printer is to write a byte to the data register. This is a normal fastcycle transfer. - o The next step is to toggle bit 13 in the miscellaneous control register (27B). The processor must write a 1 to bit 13 and then a 0. This strobes the word to the line printer. LPSTROBE must be active for at least 1 us. - When the printer detects LPSTROBE\*, it latches the byte and responds with LPACK\*. The trailing edge of LPACK\* clocks F/F 25H clear and generates LPINT+. Figure 2-8 Write Sequence Timing # Status Signal Description Status signals that are sent from the printer to the ${\tt UNIX}$ PC are listed in Table 2-38. Table 2-38 Line Printer Status Register--Address 470000 (Read Only) | Data Bit | Signal | Description | |----------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 07<br>06<br>05<br>04<br>03<br>02<br>01 | LPBUSY+ LPSELECT+ LPNOPAPER+ ERROR* FDINTRQ+ HDINTRQ+ PERR* | <pre>1 = Line printer is busy 1 = Line printer is selected 1 = Line printer has no paper 0 = Line printer error condition 1 = Floppy disk controller interrupt 1 = Hard disk controller interrupt 0 = Main memory parity error has been detected; this bit can be</pre> | | 00 | DTDET* | cleared with the CSR command (write to 4C0000) 0 = Dial tone is detected | The 68010 reads the status of the line printer by asserting LPSTATUS $RD^{\star}$ . # Serial Printer Cables The cable pinning for typical serial interface printers is as follows: Diablo 630 API Cable Pinning | UNIX | РС | Pri | nter | |------------------------------------|----|-----|------| | 1<br>2<br>3<br>4<br>7<br>6-8<br>20 | | | _ | UNIX PC to Printer with CTS Control | UNIX | PC | Printer | |--------|--------|----------------------| | 3<br>4 | <<br>< | > 3<br>2<br>> 4<br>5 | | | | | Figure 2-9 Printer Cable Pinning # Realtime Clock Interface The realtime clock integrated circuit is the Toshiba TC8250 with power-down battery backup. The TC8250 interface protocol, as listed in Table 2-39, is implemented with software. Table 2-39 Realtime Clock Interface--Address 480000 | Data Bit | Signal | Description | | |----------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--| | 15<br>14 | RTCCE+<br>RTCALE+ | <pre>1 = Realtime clock chip-enable (write-only) 1 = Realtime clock address</pre> | | | 13<br>08-11 | RTCR/W+ | latch enable (write-only) 0 = Realtime clock-read 1 = Realtime clock-write (write only) Realtime clock data bits 0-3 (write-only) | | | Address E30000 (Read-Only) | | | | | 00-03 | RTCD 0-3 | Realtime clock data bits 0-3 | | # Keyboard Controller The 6850 serial keyboard controller is shown on sheet 14 of the schematics. The keyboard controller alerts the 68010 to read data by generating an interrupt KBINT. The keyboard sends serial data to the controller with a signal called KBTXD. The 68010 then reads data from the controller with processor data bits PD8-PD15. The 68010 enables the controller with KBEN generated on sheet 4. On sheet 4, KBEN is derived from a signal called 6850 CS\*, which is decoded from the processor address bits as shown below: #### Address Status to Assert KBEN | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | Address | |----|----|----|----|----|----|----|----|---------| | 1 | 1 | 1 | х | x | 1 | 1 | 1 | GCRWR* | Table 2-40 lists addresses to access the internal registers of the controller: Table 2-40 Keyboard Controller Addresses | Address | Read | Write | |---------|-----------------------|------------------------| | E70000 | Status register | Control register | | E70002 | Receive data register | Transmit data register |