# BajaPPC-750 PowerPC-Based, Single-Board Computer User's Manual May 2002 Artesyn Communication Products 8310 Excelsior Dr. Madison, WI 53717 Web Site: www.artesyncp.com Sales: (800) 356-9602 pport: (800) 327-1251 Technical Support: (800) 327-1251 BajaPPC-750 User's Manual—Artesyn Part Number: 0002M621-15 ## BajaPPC-750 PowerPC-Based, Single-Board Computer User's Manual May 2002 The information in this manual has been checked and is believed to be accurate and reliable. HOWEVER, NO RESPONSIBILITY IS ASSUMED BY ARTESYN COMMUNICATION PRODUCTS FOR ITS USE OR FOR ANY INACCURACIES. Specifications are subject to change without notice. ARTESYN COMMUNICATION PRODUCTS DOES NOT ASSUME ANY LIABILITY ARISING OUT OF USE OR OTHER APPLICATION OF ANY PRODUCT, CIRCUIT, OR PROGRAM DESCRIBED HEREIN. This document does not convey any license under Artesyn Communication Products patents or the rights of others. Artesyn and the Artesyn logo are registered trademarks of Artesyn Technologies and are used by Artesyn Communication Products under licence from Artesyn Technologies. All other trademarks are property of their respective owners. #### **Revision History** | Revision Level | Principal Changes | Publication Date | Board Rev. | |----------------|----------------------------------------|------------------|------------| | 0002M621-A | First publication | July 1999 | 1 | | 0002M621-10 | Update jumper settings | October 1999 | 1 | | 0002M621-11 | Updated PCB artwork | February 2000 | 21 | | 0002M621-12 | Update Fig. 2-5 and Section 4.4 | July 2000 | 21 | | 0002M621-13 | Remove reference to software reset bit | November 2000 | 21 | | 0002M621-14 | Update for board revision | August 2001 | 22 | | 0002M621-15 | New board rev. & update Table 10-3 | May 2002 | 23 | Copyright © 1999–2002 Artesyn Communication Products All rights reserved. ### Regulatory Agency Warnings & Notices The Artesyn BajaPPC-750 is certified by the Federal Communications Commission (FCC) according to Title 47 of the Code of Federal Regulations, Part 15. The following information is provided as required by this agency. #### FCC Rules and Regulations - Part 15 This equipment has been tested and found to comply with the limits for a Class B digital device, pursuant to part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a residential installation. This equipment generates, uses and can radiate radio frequency energy and, if not installed and used in accordance with the instructions, may cause harmful interference to radio communications. However, there is no guarantee that interference will not occur in a particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures: - Reorient or relocate the receiving antenna - Increase the separation between the equipment and receiver - Connect the equipment into an outlet on a circuit different from that to which the receiver is connected - Consult the dealer or an experienced radio/TV technician for help CAUTION. Making changes or modifications to the BajaPPC-750 without the explicit consent of Artesyn Communication Products could invalidate the user's authority to operate this equipment. ### Contents | 1. | Over | riew | | |----|-------|--------------------------------------------------|---------------| | | 1.1 | Components and Features | .1-1 | | | 1.2 | Functional Description | .1-3 | | | 1.3 | Physical Memory Map | .1-4 | | | 1.4 | Additional Information | .1- <i>6</i> | | | | 1.4.1 Product Certifications | .1- <i>6</i> | | | | 1.4.2 Terminology and Notation | .1-7 | | | | 1.4.3 Technical References | .1-7 | | 2. | Setup | | | | | 2.1 | Electrostatic Discharge | . 2-1 | | | 2.2 | BajaPPC-750 Circuit Board | . 2-2 | | | | 2.2.1 Component Maps and Jumpers | . 2-2 | | | | 2.2.2 Serial Numbers | 2-12 | | | | 2.2.3 Connectors | 2-12 | | | | 2.2.4 Reset/Interrupt Switch | 2-13 | | | | 2.2.5 LED | 2-13 | | | | 2.2.6 Optional VMEbus Configurations | 2-14 | | | 2.3 | BajaPPC-750 Setup | 2-14 | | | | 2.3.1 Providing Power | 2-15 | | | | 2.3.2 Providing Air Flow | 2-15 | | | 2.4 | Operational Checks | 2-16 | | | 2.5 | Reset Methods | 2-16 | | | 2.6 | Troubleshooting | 2-17 | | | | 2.6.1 Technical Support | 2-18 | | | | 2.6.2 Service Information | 2-18 | | 3. | Cent | al Processing Unit | | | | 3.1 | Processor Reset | . 3-2 | | | 3.2 | Processor Initialization | . 3-2 | | | | 3.2.1 Hardware Implementation Dependent Register | . 3-3 | | | | 3.2.2 Machine State Register | . 3-4 | | | 3.3 | Exception Handling | . 3- <i>6</i> | | | 3.4 | Interrupt Handling | . 3-7 | | | | | | 0002M621-15 | | 3.5 | Bus Speed | 3-8 | |----|------|---------------------------------------------------|------| | | 3.6 | Cache Memory | 3-8 | | | | 3.6.1 Integrated Level 2 Cache | 3-9 | | | 3.7 | JTAG/COP Interface | 3-10 | | | 3.8 | Debug Header | 3-11 | | 4. | On-C | Card Memory Configuration | | | | 4.1 | MPC106 Memory Interface | 4-1 | | | 4.2 | Boot Memory Configuration | 4-2 | | | 4.3 | User Flash | 4-3 | | | 4.4 | On-Card SDRAM | 4-3 | | | | 4.4.1 SDRAM Configuration | 4-4 | | | | 4.4.2 SDRAM Timing | 4-4 | | | 4.5 | Real-Time Clock | 4-6 | | | 4.6 | Nonvolatile Memory Map | 4-8 | | 5. | PMC | /PCI Interface | | | | 5.1 | Features | 5-1 | | | 5.2 | PMC Module Installation | 5-2 | | | 5.3 | PCI Bridge Configuration Registers | 5-3 | | | | 5.3.1 PCI Command Register | 5-4 | | | | 5.3.2 PCI Status Register | 5-5 | | | 5.4 | PCI Interface | | | | | 5.4.1 Device Mapping | 5-6 | | | | 5.4.2 Timing | 5-7 | | | | 5.4.3 Interrupts | 5-7 | | | | 5.4.4 Arbitration | | | | 5.5 | PCI Bus Control Signals | 5-8 | | | 5.6 | PMC Connector Pin Assignments | 5-10 | | 6. | VME | bus Interface | | | | 6.1 | Features | | | | 6.2 | gg | | | | | 6.2.1 Initialization Values | | | | | 6.2.2 PCI Base Address Register | | | | | 6.2.3 PCI Configuration Space and Status Register | | | | | 6.2.4 Master Control Register | 6-10 | | | | 6.2.5 Miscellaneous Control Register | | | | | 6.2.6 VMEbus Master Image Registers | | | | | 6.2.7 VMEbus Slave Image Registers | | | | 6.3 | VMEbus Master Interface | | | | | 6.3.1 Addressing | 6-16 | | | | 6.3.2 Data Transfers | 6-17 | ii BajaPPC-750: Contents | | 6.4 | VMEDUS Slave Interface | 6-1/ | |----|-------|----------------------------------|------| | | | 6.4.1 Slave Mapping Example | 6-18 | | | 6.5 | VMEbus Interrupts | 6-20 | | | | 6.5.1 Interrupter | 6-21 | | | | 6.5.2 Interrupt Handler | 6-21 | | | 6.6 | VMEbus System Controller | 6-22 | | | 6.7 | SYSFAIL Control | | | | 6.8 | Bus Timer | 6-22 | | | 6.9 | Mailboxes | 6-22 | | | 6.10 | Location Monitor | 6-24 | | | 6.11 | Semaphores | 6-25 | | | 6.12 | VMEbus Control Signals | 6-25 | | | 6.13 | VMEbus Connector Pin Assignments | 6-28 | | 7. | Ether | rnet Interface | | | | 7.1 | 21143 Registers | 7-1 | | | | 7.1.1 Configuration | 7-2 | | | | 7.1.2 Command/Status | 7-2 | | | 7.2 | Ethernet Address | 7-3 | | | 7.3 | Default Ethernet Boot Device | 7-4 | | | 7.4 | 21143 Errata | 7-4 | | | 7.5 | Ethernet Ports | 7-5 | | | | 7.5.1 Fast Ethernet | 7-5 | | | | 7.5.2 AUI Ethernet | 7-5 | | | 7.6 | Cabling Considerations | 7-6 | | 8. | Seria | l and Parallel I/O | | | | 8.1 | PCI to ISA Bridge | 8-1 | | | | 8.1.1 Basic Operation | 8-2 | | | | 8.1.2 Registers | 8-2 | | | 8.2 | I/O Controller | 8-4 | | | | 8.2.1 Block Addressing | | | | | 8.2.2 Configuration | 8-5 | | | 8.3 | Serial Ports | 8-8 | | | | 8.3.1 Serial Port Addressing | 8-8 | | | | 8.3.2 Serial Port Registers | 8-8 | | | | 8.3.3 Programmable Baud Rate | 8-12 | | | | 8.3.4 Connectors and Cabling | 8-13 | | | | 8.3.5 Handshaking Jumper | 8-15 | | | 8.4 | Parallel Port (Optional) | 8-15 | | | | 8.4.1 Parallel Port Addressing | 8-16 | | | | 8.4.2 Parallel Port Registers | 8-16 | 0002M621-15 #### 9. Counter/Timers | | 9.1 | Counter | /Timers | 9-1 | |-----|------|----------|--------------------------------|--------| | | 9.2 | Counter | /Timer Registers | 9-1 | | | | 9.2.1 | Period Register | 9-2 | | | | 9.2.2 | Count Register | 9-2 | | | | 9.2.3 | Status Register | 9-2 | | | | 9.2.4 | Interrupt Acknowledge Register | 9-3 | | | | 9.2.5 | Mode Register | 9-4 | | 10. | Moi | nitor | | | | | 10.1 | Monitor | Features | 10-1 | | | | 10.1.1 | Start-Up Display | 10-1 | | | | 10.1.2 | Command-Line History | 10-3 | | | | 10.1.3 | Command-Line Editor | 10-3 | | | | 10.1.4 | PowerPC Debugger | 10-4 | | | 10.2 | Basic Op | peration | 10-5 | | | | 10.2.1 | Power-Up/Reset Sequence | 10-5 | | | | 10.2.2 | Initializing Memory | .10-13 | | | 10.3 | Monitor | Command Reference | .10-13 | | | | 10.3.1 | Command Syntax | .10-13 | | | | 10.3.2 | Typographic Conventions | .10-14 | | | 10.4 | Boot Cor | mmands | .10-14 | | | | 10.4.1 | bootbus | .10-14 | | | | 10.4.2 | booteprom | .10-15 | | | | 10.4.3 | bootrom | .10-16 | | | | 10.4.4 | bootflash | .10-16 | | | | 10.4.5 | bootserial | .10-17 | | | 10.5 | Memory | Commands | .10-18 | | | | 10.5.1 | checksummem | .10-18 | | | | 10.5.2 | clearmem | .10-18 | | | | 10.5.3 | cmpmem | .10-18 | | | | 10.5.4 | copymem | .10-19 | | | | 10.5.5 | displaymem | .10-19 | | | | 10.5.6 | fillmem | .10-19 | | | | 10.5.7 | findmem | .10-20 | | | | 10.5.8 | findnotmem | .10-20 | | | | 10.5.9 | findstr | .10-20 | | | | 10.5.10 | readmem | .10-20 | | | | 10.5.11 | setmem | .10-21 | | | | 10.5.12 | swapmem | | | | | 10.5.13 | testmem | .10-21 | | | | 10.5.14 | um | .10-22 | iv BajaPPC-750: Contents | | 10.5.15 | writemem | 10-22 | |-------|----------|-------------------------------------------|-------| | | 10.5.16 | writestr | 10-22 | | 10.6 | Flash Co | mmands | 10-23 | | | 10.6.1 | flashblkwr | 10-23 | | | 10.6.2 | flashbytewrite | 10-23 | | | 10.6.3 | flashclrstat | 10-23 | | | 10.6.4 | flasheraseblk | 10-24 | | | 10.6.5 | wideflashblkwr | 10-24 | | | 10.6.6 | wideflashclrstat | 10-24 | | | 10.6.7 | wideflasheraseblk | 10-24 | | | 10.6.8 | rewritemonitor | 10-25 | | 10.7 | NVRAM | Commands | 10-25 | | | 10.7.1 | nvdisplay | 10-25 | | | 10.7.2 | nvinit | 10-30 | | | 10.7.3 | nvopen | 10-30 | | | 10.7.4 | nvset | 10-30 | | | 10.7.5 | nvupdate | 10-31 | | | 10.7.6 | Default Boot Device Configuration Example | 10-31 | | | 10.7.7 | Download Port Configuration Example | 10-33 | | 10.8 | Test Con | mmands | 10-34 | | | 10.8.1 | itctest | 10-34 | | | 10.8.2 | ethertest | 10-34 | | | 10.8.3 | serialtest | 10-35 | | | 10.8.4 | nvramtest | 10-35 | | | 10.8.5 | cachetest | 10-35 | | 10.9 | Remote I | Host Commands | 10-36 | | | 10.9.1 | call | 10-36 | | | 10.9.2 | download | | | | 10.9.3 | Binary Download Format | 10-37 | | | 10.9.4 | Hex-Intel Download Format | 10-37 | | | 10.9.5 | Motorola S-Record Download Format | 10-40 | | 10.10 | Arithmet | tic Commands | 10-43 | | | | add | | | | 10.10.2 | div | 10-43 | | | 10.10.3 | mul | 10-44 | | | 10.10.4 | rand | 10-44 | | | 10.10.5 | sub | 10-44 | | 10.11 | Other Co | ommands | 10-44 | | | 10.11.1 | configboard | 10-44 | | | 10.11.2 | <b>3–</b> | | | | 10.11.3 | ethernetaddr | | | | 10.11.4 | getboardconfig | 10-45 | | | 10.11.5 | help | 10-45 | 0002M621-15 | 10.12 | Commar | nd Errors and Screen Messages | 10-46 | |-------|----------|--------------------------------------------|-------| | 10.13 | Monitor | Function Reference | 10-47 | | 10.14 | BajaPPC- | 750-Specific Functions | 10-47 | | | 10.14.1 | Grackle Read/Write | 10-47 | | | 10.14.2 | Hardware Implementation Dependent Register | 10-48 | | | 10.14.3 | Miscellaneous | 10-48 | | | 10.14.4 | Read/Write Configuration | 10-49 | | | 10.14.5 | Display Processor Temperature | 10-49 | | 10.15 | Standard | Artesyn Functions | 10-50 | | | 10.15.1 | Conversions | 10-50 | | | 10.15.2 | Booting | 10-51 | | | 10.15.3 | Cache Control | 10-51 | | | 10.15.4 | MMU Control | 10-52 | | | 10.15.5 | Baud Rate | 10-52 | | | 10.15.6 | Exceptions | 10-53 | | | 10.15.7 | Serial I/O | 10-54 | | | 10.15.8 | Initialize Board | 10-55 | | | 10.15.9 | Initialize FIFO | 10-55 | | | 10.15.10 | Initialize Ethernet Address | 10-56 | | | 10.15.11 | Interrupts | 10-56 | | | 10.15.12 | Interrupt Error | 10-57 | | | 10.15.13 | Legal Value Check | 10-57 | | | 10.15.14 | Memory Management | 10-58 | | | 10.15.15 | Miscellaneous | 10-59 | | | 10.15.16 | Artesyn Monitor | 10-59 | | | 10.15.17 | Support Functions | 10-60 | | | 10.15.18 | Seed | 10-62 | | | 10.15.19 | Serial Support | 10-63 | | | 10.15.20 | Unexpected Interrupt Handler | 10-64 | | | 10.15.21 | Strings | 10-64 | | | 10.15.22 | Test Suite | 10-65 | | | 10.15.23 | Timer | 10-66 | | | 10.15.24 | Printing | 10-66 | vi BajaPPC-750: Contents #### Figures | Figure 1-1. | General System Block Diagram | 1-3 | |--------------|-----------------------------------------------|-------| | Figure 1-2. | Physical Memory Map | 1-4 | | Figure 2-1. | Component Map, Top (Board Rev. 23) | 2-3 | | Figure 2-2. | Component Map, Bottom (Board Rev. 23) | 2-4 | | Figure 2-3. | Component Map, Top (Board Rev. 22) | 2-5 | | Figure 2-4. | Component Map, Bottom (Board Rev. 22) | 2-6 | | Figure 2-5. | Component Map, Top (Board Rev. 21) | 2-7 | | Figure 2-6. | Component Map, Bottom (Board Rev. 21) | 2-8 | | Figure 2-7. | Component Map, Top (Board Rev. 1) | 2-9 | | Figure 2-8. | Component Map, Bottom (Board Rev. 1) | 2-10 | | Figure 2-9. | Jumper and Fuse Locations | 2-11 | | Figure 5-1. | Single-Width PMC Module Configuration | 5-2 | | Figure 5-2. | Double-Width PMC Module Configuration | 5-2 | | Figure 5-3. | PCI Bridge Memory Space | 5-6 | | Figure 6-1. | VMEbus Connectors (P0, P1, P2) | 6-28 | | Figure 7-1. | Fast Ethernet Connector (P3, RJ45) | 7-5 | | Figure 8-1. | Serial Port-A Connector (P4, RJ45) | 8-13 | | Figure 8-2. | Console Adapter #308A006-48 for Serial Port A | 8-14 | | Figure 8-3. | Cable Assembly #314A002-12 for Serial Port B | 8-15 | | Figure 10-1. | Monitor Start-up Display | 10-2 | | Figure 10-2. | Monitor Startup Flowchart (1 of 4) | 10-9 | | Figure 10-3. | Monitor Startup Flowchart (2 of 4) | 10-10 | | Figure 10-4. | Monitor Startup Flowchart (3 of 4) | 10-11 | | Figure 10-5. | Monitor Startup Flowchart (4 of 4) | 10-12 | 0002M621-15 vii #### Register Maps | Register Map 2-1. | BajaPPC-750 Board Configuration (P2 Configuration) | 2-14 | |--------------------|---------------------------------------------------------|------| | Register Map 3-1. | BajaPPC-750 Board Configuration (Reset) | 3-2 | | Register Map 3-2. | PPC750 Hardware Implementation Dependent, HID0 | 3-3 | | Register Map 3-3. | CPU Machine State, MSR | 3-4 | | Register Map 3-4. | BajaPPC-750 Interrupt Status | 3-8 | | Register Map 3-5. | BajaPPC-750 Board Configuration (Bus Speed) | 3-8 | | Register Map 3-6. | BajaPPC-750 L2 Cache/PMC Bus Mode | 3-9 | | Register Map 4-1. | BajaPPC-750 Flash Bank Select | 4-3 | | Register Map 4-2. | BajaPPC-750 Board Configuration (Memory) | 4-4 | | Register Map 4-3. | BajaPPC-750 Real-Time Clock | 4-6 | | Register Map 5-1. | MPC106 PCI Command | 5-4 | | Register Map 5-2. | MPC106 PCI Status | 5-5 | | Register Map 5-3. | Winbond PCI Priority Control | 5-7 | | Register Map 6-1. | Universe PCI Base Address, PCI_BS | 6-8 | | Register Map 6-2. | Universe PCI Configuration Space and Status, PCI_CSR | 6-9 | | Register Map 6-3. | Universe Master Control, MAST_CTL | 6-10 | | Register Map 6-4. | Universe Miscellaneous Control, MISC_CTL | 6-11 | | Register Map 6-5. | Universe PCI Slave Image 0 Control, LSI0_CTL | 6-13 | | Register Map 6-6. | Universe VME Slave Image 0 Control, VSI0_CTL | 6-14 | | Register Map 6-7. | Universe PCI Miscellaneous, LMISC | 6-15 | | Register Map 6-8. | Universe VME Interrupt Enable, VINT_EN | 6-20 | | Register Map 6-9. | Universe VMEbus Register Access Image Control, VRAI_CTL | 6-23 | | Register Map 6-10. | Universe Location Monitor Control, LM_CTL | 6-24 | | Register Map 7-1. | Intel 21143 General Purpose Command/Status, CSR9 | 7-4 | | Register Map 8-1. | Ultra I/O Serial Port Interrupt Enable, IER | 8-8 | | Register Map 8-2. | Ultra I/O Serial Port Interrupt Identification, IIR | 8-9 | | Register Map 8-3. | Ultra I/O Serial Port Line Control, LCR | 8-9 | | Register Map 8-4. | Ultra I/O Serial Port Modem Control, MCR | 8-10 | | Register Map 8-5. | Ultra I/O Serial Port Line Status, LSR | 8-10 | | Register Map 8-6. | Ultra I/O Serial Port Modem Status, MSR | 8-11 | | Register Map 8-7. | Ultra I/O Parallel Port Data | 8-16 | | Register Map 8-8. | Ultra I/O Parallel Port Status | 8-16 | | Register Map 8-9. | Ultra I/O Parallel Port Control | 8-17 | viii BajaPPC-750: Contents | Register Map 9-1. | Counter/Timer Status, CTSR | 9-2 | |-------------------|----------------------------|-----| | Register Map 9-2. | Counter/Timer Mode, CTMR | 9-4 | 0002M621-15 ix #### **Tables** | Table 1-1. | Address Summary | |-------------|------------------------------------------------------------| | Table 1-2. | Regulatory Agency Compliance | | Table 1-3. | Technical References | | Table 2-1. | Mechanical Specifications | | Table 2-2. | LED Segment Vector Assignments | | Table 2-3. | Power Requirements | | Table 3-1. | BajaPPC-750 CPU Features | | Table 3-2. | CPU Internal Register Initialization | | Table 3-3. | IEEE Floating-Point Exception Modes | | Table 3-4. | PPC750 Exception Priorities | | Table 3-5. | Interrupt Vector Assignments | | Table 3-6. | JTAG/COP Interface Pin Assignments (HDR1) | | Table 3-7. | Debug Header Pin Assignments (HDR4) | | Table 4-1. | MPC106 Memory Interface Configuration Registers | | Table 4-2. | Memory Configuration Jumpers | | Table 4-3. | Memory Configuration Bit Values | | Table 4-4. | SDRAM Access Time Required for the BajaPPC-750 | | Table 4-5. | Nonvolatile Memory Map | | Table 5-1. | MPC106 PCI Interface Configuration Registers | | Table 5-2. | PCI Device Identification Mapping | | Table 5-3. | J1x PMC Connector Pin Assignments | | Table 5-4. | J2x PMC Connector Pin Assignments | | Table 6-1. | Universe Internal Register Summary6-2 | | Table 6-2. | Recommended Initialization Values for Universe | | Table 6-3. | VMEbus Default Memory Mapping | | Table 6-4. | Universe VMEbus Interrupt Sources | | Table 6-5. | Location Monitor Interrupt Mapping6-24 | | Table 6-6. | P0 Connector Pin Assignments | | Table 6-7. | P1 Connector Pin Assignments (Standard Configuration) 6-30 | | Table 6-8. | P1 Connector Pin Assignments (Optional Configuration) 6-31 | | Table 6-9. | P2 Connector Pin Assignments (Standard Configuration) 6-32 | | Table 6-10. | P2 Connector Pin Assignments (Optional Configuration) 6-33 | | Table 7-1. | 21143 Configuration Register Summary 7-2 | | Table 7-2. | 21143 Command/Status Register Summary 7-3 | x BajaPPC-750: Contents | Table 7-3. | Default Ethernet Boot Device Selection (JP1) | 7-4 | |-------------|---------------------------------------------------------------|-------| | Table 7-4. | Fast Ethernet Pin Assignments (P3, RJ45) | 7-5 | | Table 8-1. | Serial/Parallel Port Connector Summary | 8-1 | | Table 8-2. | W83C553 Internal Register Summary | 8-2 | | Table 8-3. | Ultra I/O Block Addressing | 8-5 | | Table 8-4. | Ultra I/O Configuration Registers | 8-5 | | Table 8-5. | Addresses for Ultra I/O Serial Port Registers | 8-8 | | Table 8-6. | Baud Rate Divisors (1.8462 MHz Crystal) | 8-12 | | Table 8-7. | Serial Port-A Pin Assignments (P4 RJ45 or Console Adapter) | 8-13 | | Table 8-8. | Serial Port-B Pin Assignments (HDR3 Header or Cable Assembly) | 8-14 | | Table 8-9. | EIA-232 Handshaking Configuration Jumper | 8-15 | | Table 8-10. | Addresses for Ultra I/O Parallel Port Registers | 8-16 | | Table 9-1. | Counter/Timer Registers | 9-1 | | Table 10-1. | Power-up Diagnostic PASS/FAIL Flags | 10-8 | | Table 10-2. | Device Download Formats | 10-17 | | Table 10-3. | NVRAM Configuration Groups | 10-26 | | Table 10-4. | Test Command PASS/FAIL Flags | 10-34 | | Table 10-5. | Error and Screen Messages | 10-46 | | Table 10-6. | IsLegal Function Types | 10-57 | | Table 10-7. | <b>NVOp</b> Commands | 10-61 | | Table 10-8. | <b>NVOp</b> Error Codes | 10-62 | 0002M621-15 xi xii BajaPPC-750: Contents ## 7 Overview The BajaPPC-750 is 64-bit single-board computer based on the IBM PowerPC™ PPC750 microprocessor. It can have up to 256 megabytes of synchronous DRAM and incorporate two PMC module sites. The PMC interfaces act as a base for plugover modules that provide additional functions. The BajaPPC-750 serves as a flexible and powerful platform for real-time communications applications, such as Advanced Intelligent Network (AIN) switches, telecommunications switches, and local/wide area network (LAN/WAN) bridges. The BajaPPC-750 has an optional configuration that allows for compatability with the Motorola MVME712M transition module. #### 1.1 Components and Features The following is a brief summary of the BajaPPC-750 components and features: CPU The CPU is an IBM PowerPC<sup>™</sup> microprocessor running internally at 366 MHz or higher. The PPC750 has 32-kilobyte data and instruction caches, three instructions per clock cycle, and a 32/64-bit data bus mode. L2 Cache A 1-megabyte Level 2 cache is provided by two synchronous random access memory (SRAM) devices running at 122 MHz or higher. The cache has zero wait state performance (2-1-1-1 burst) with a two-way set associative cache design. SDRAM The BajaPPC-750 may be populated with 32, 64, 128, or 256 megabytes of 64-bit wide synchronous DRAM. Refresh and other control functions are provided by the Motorola MPC106 "Grackle" memory controller. EPROM The BajaPPC-750 has a 32-pin PLCC socket with a 512-kilobyte EPROM or flash memory capacity. ROM access and control functions are provided by the Motorola MPC106 memory controller. User Flash The BajaPPC-750 allows for 12 megabytes of user flash to support the PowerPC CPU. The MPC106 memory controller has four megabytes of paged flash (512 kilobytes per page) on its 8-bit ROM bus, as well as eight megabytes of flash on its 64-bit ROM bus. Ethernet<sup>TM</sup> The BajaPPC-750 employs the Intel (formerly DEC) 21143 PCI/CardBus 10/100-Mb/s Ethernet LAN Controller, which interfaces directly to the PCI local bus. The 21143 is fully compliant with the IEEE 802.3 100BASE- T draft for Fast Ethernet. **Serial Interface** The BajaPPC-750 provides two 16C550-compatible serial ports by means of the SMC FDC37C935 Ultra I/O chip. This device is a versatile I/O controller that resides on the ISA bus. A Winbond Systems Laboratory $\,$ W83C553F chip bridges the PCI and ISA busses. Parallel Port The SMC FDC37C935 Ultra I/O chip also provides a parallel port for the BajaPPC-750 on row C of connector P2 (optional configuration only). **VMEbus** The PCI to VME interface for the BajaPPC-750 is provided by a Tundra Universe II (CA91C142) chip, which has built-in FIFOs and full VME64 master/slave capability with DMA. The VMEbus has a 32-bit address bus with 16-, 24-, or 32-bit address modes (4-gigabyte range) and a 32-bit data bus with 8-, 16-, 24-, 32-, or 64-bit board compatibility. The board supports all seven VMEbus interrupts. Mailbox Mailbox interrupts allow the BajaPPC-750 to be controlled remotely from specific VMEbus addresses. This feature supports CPU interrupt and VMEbus lock functions. Counters/ The BajaPPC-750 uses a programmable logic device (PLD) to implement Timers/ two general purpose 31-bit counter/timers and an interrupt controller. Interrupts LED The BajaPPC-750 features a 7-segment LED display on the front panel that is oriented so it can be read when the board is vertically mounted. **Reset/Interrupt** The BajaPPC-750 has a two-position momentary toggle switch. In the **Switch** reset position, this switch resets the board (and the VMEbus when the reset position, this switch resets the board (and the VMEbus when the board is the system controller). In the interrupt position, it provides a user-definable debug tool. PMC Modules PCI Mezzanine Card (PMC) interface is a 32-bit interface that allows you to customize the BajaPPC-750 by adding plugover modules. The plugover modules are based on the Peripheral Component Interconnect (PCI) standard. The BajaPPC-750 accepts two single-width or one double- width PMC modules with I/O on the front panel and connector P2. Functional Description 1-3 #### 1.2 Functional Description Figure 1-1. General System Block Diagram #### 1.3 Physical Memory Map The physical memory map of the BajaPPC-750 is depicted in Fig. 1-2. Information on particular portions of the memory map can be found in later sections of this manual. See Table 1-1 for a list of these references. Figure 1-2. Physical Memory Map Table 1-1. Address Summary | Hex Physical<br>Address | Access<br>Mode | Description | See Section | |-------------------------|----------------|------------------------------------------------------------------------------------|--------------| | FFA0,0000 | _ | Reserved | _ | | FF9E,0000 | W | Clear Non-maskable Interrupt Register | 2.2.4, 3.1 | | FF9C,0000 | R/W | Real Time Clock/Nonvolatile RAM | 4.5 | | FF9A,0070 | R | Interrupt Status Register (PLD) | 3.4 | | FF9A,0060 | R | Interrupt Vector Register (PLD) | 3.4 | | FF9A,0050 | R/W | Counter/Timer 2 - Timer Period Reg. (PLD) | 9.2.1 | | FF9A,0040 | R/W | Counter/Timer 2 - Status/Mode Reg. (PLD) | 9.2.3, 9.2.5 | | FF9A,0030 | R/W | Counter/Timer 2 - Count/Int. Ack. Reg. (PLD) | 9.2.2, 9.2.4 | | FF9A,0020 | R/W | Counter/Timer 1 - Timer Period Reg. (PLD) | 9.2.1 | | FF9A,0010 | R/W | Counter/Timer 1 - Status/Mode Reg. (PLD) | 9.2.3, 9.2.5 | | FF9A,0000 | R/W | Counter/Timer 1 - Count/Int. Ack. Reg. (PLD) | 9.2.2, 9.2.4 | | FF98,0030 | R | L2 Cache/PMC Bus Mode Register (PLD) | 3.6.1, 5.2 | | FF98,0020 | R | Board Configuration Register (PLD) | 4.4.1 | | FF98,0010 | R/W | Flash Bank Select Register (PLD) | 4.3 | | FF98,0000 | R/W | LED (PLD) | 2.2.5 | | FF90,0000 | R | Boot EPROM Socket (512K) with JP6 Out<br>Boot User Flash Page 0 (512K) with JP6 In | 4.2 | | FF88,0000 | R/W | User Flash Pages 1–7 (512K) | 4.3 | | FF80,0000 | R-R/W | Flash Page 0 (512K) with JP6 Out<br>EPROM Socket (512K) with JP6 In | 4.2 | | FF00,0000 | R/W | Flash, 64-bit wide (8MB) | 4.3 | | FEF0,0000 | R | PCI Interrupt Acknowledge | 5.4.3 | | FEE0,0000 | R/W | Configuration Data Register (MPC106) | 4.1 | | FEC0,0000 | R/W | Configuration Address Register (MPC106) | 4.1 | | FE80,0000 | R/W | PCI I/O Space (4 MB), 0 Based | 5 | | FE00,0000 | R/W | PCI/ISA I/O Space (64 KB), 0 Based | 5 | | FD00,0000 | R/W | PCI/ISA Memory Space (16 MB), 0 Based | 5, 8 | | 8000,0000 | R/W | PCI Memory Space | 5 | | 4000,0000 | - | Reserved | _ | | 0000,0000 | R/W | SDRAM | 4.4 | #### 1.4 Additional Information This section lists the BajaPPC-750's regulatory certifications and briefly discusses the terminology and notation conventions used in this manual. It also lists general technical references for the BajaPPC-750. #### 1.4.1 Product Certifications The BajaPPC-750 has been tested and certified to comply with various safety, immunity, and emissions requirements as specified by the Federal Communication Commission (FCC), Industry Canada (IC), Underwriters Laboratories (UL), and the European Union Directives (CE mark). The following table summarizes this compliance: **Table 1-2. Regulatory Agency Compliance** | Туре | Specification | |---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | CE mark | EMC Directive 89/336/EEC Emissions: EN55022: 1994-Class A Immunity: EN50082-1: 1997 | | FCC | Title 47, Code of Federal Regulations, Part 15 (Class A) | | IC | Industry Canada Standard ICES-003 (Class A) | | UL/CSA | Safety of Information Technology Equipment, Including Electrical Business Equipment (Bi-National), UL 1950, Third Edition; CSA C22.2 No. 950-95, Third Edition | Artesyn maintains test reports that provide specific information regarding the methods and equipment used in compliance testing. Unshielded external I/O cables, loose screws, or a poorly grounded chassis may adversely affect the BajaPPC-750's ability to comply with any of the stated specifications. Additional Information 1-7 #### 1.4.2 Terminology and Notation **Active low signals** An active low signal is indicated with an asterisk \* after the signal name. Byte, word, Throughout this manual *byte* refers to 8 bits, *word* refers to 16 bits, *long* word refers to 32 bits, and *double long word* refers to 64 bits. **Radix 2 and 16** Hexadecimal numbers either end with a subscript 16 or begin with 0x. Binary numbers are shown with a subscript 2. #### 1.4.3 Technical References Further information on basic operation and programming of the intelligent components on the BajaPPC-750 can be found in the following documents: Table 1-3. Technical References | <b>Device or Interface</b> | Туре | Document <sup>†</sup> | | |---------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------|--| | CPU | PPC750 | PowerPC <sup>™</sup> 750 RISC Microprocessor User's Manual IBM number GK21-0263-00. | | | | | PowerPC <sup>™</sup> Microprocessor Family: The Programming Environments IBM number G522-0290-00. | | | | | http://www.chips.ibm.com | | | Fast Ethernet | 21143 | DIGITAL Semiconductor 21143 PCI/CardBus<br>10/100-Mb/s Ethernet LAN Controller:<br>Hardware Reference Manual<br>(Intel Corporation, 1998) | | | | | http://developer.intel.com/design/network | | | I/O Controller | FDC37C93x | Ultra I/O Advance Information<br>(Standard Microsystems Corporation, 1995) | | | | | http://www.smc.com | | | Memory Controller<br>ISA Bridge | W83C553F | W83C553F System I/O Controller with PCI Arbiter, Data<br>Book, Pub. #2565 (Winbond Systems Laboratory, 1995) | | | Memory Controller<br>PCI Bridge | MPC106 | MPC106 PCI Bridge/Memory Controller User's Manual Motorola order number MPC106UM/AD 1/97. | | | | | http://www.mot.com | | | | | PCI Local Bus Specification (PCI Special Interest Group, Revision 2.1 1995). | | | | | http://www.pcisig.com | | Table 1-3. Technical References — Continued | <b>Device or Interface</b> | Туре | Document <sup>†</sup> | | |----------------------------|---------------------------|--------------------------------------------------------------------------------------------|--| | VMEbus | Universe II<br>(CA91C142) | Universe II Users' Guide<br>(Tundra Semiconductor Corporation, 1997) | | | | | http://www.tundra.com/unidex.html | | | | | VME64 Draft Specification, Rev. 1.10, October 4, 1994<br>(VITA: Scottsdale, AZ) | | | | | VME64 Extensions Draft Standard, Draft 1.6, February 7, 1997 (VITA: Scottsdale, AZ) | | | | | http://www.vita.com | | | Timekeeper SRAM | M48T35 | M48T35 CMOS 32K x 8 Timekeeper SRAM, Preliminary Data (SGS-Thomson Microelectronics, 1995) | | | | | http://www.st.com | | <sup>&</sup>lt;sup>†</sup> Frequently, the most current information regarding addenda/errata for specific documents may be found on the corresponding web site. If you have questions, please call an Artesyn Communication Products Technical Support representative at 1-800-327-1251, visit the web site at http://www.artesyncp.com, or send e-mail to support@artesyncp.com. ### 2 Setup This chapter describes the physical layout of the board, the setup process, and how to check for proper operation once the board has been installed. This chapter also includes troubleshooting, service, and warranty information. #### 2.1 Electrostatic Discharge Before you begin the setup process, please remember that electrostatic discharge (ESD) can easily damage the components on the BajaPPC-750. Electronic devices, especially those with programmable parts, are susceptible to ESD, which can result in operational failure. Unless you ground yourself properly, static charges can accumulate in your body and cause ESD damage when you touch the board. CAUTION. Use proper static protection and handle the BajaPPC-750 board only when absolutely necessary. Always wear a wrist-strap to ground your body before touching the board. Keep your body grounded while handling the board. Hold the board by its edges—do not touch any components or circuits. When the board is not in an enclosure, store it in a static-shielding bag. To ground yourself, wear a grounding wriststrap. Simply placing the board on top of a static-shielding bag does not provide any protection—place it on a grounded dissipative mat. Do not place the board on metal or other conductive surfaces. 2-2 BajaPPC-750: Setup #### 2.2 BajaPPC-750 Circuit Board The BajaPPC-750 is a 14-layer board. Standard board spacing is 0.800 inches. The dimensions of the BajaPPC-750 board are given in Table 2-1. **Table 2-1. Mechanical Specifications** | Width | Depth | Height | |------------|------------|-----------| | 9.187 in. | 6.299 in. | 0.535 in. | | 233.350 mm | 160.000 mm | 13.601 mm | #### 2.2.1 Component Maps and Jumpers The figures on the following pages show the placement for various components on the BajaPPC-750 printed circuit board. Fig. 2-9 shows the jumper and fuse locations. Figure 2-1. Component Map, Top (Board Rev. 23) 2-4 BajaPPC-750: Setup Figure 2-2. Component Map, Bottom (Board Rev. 23) Figure 2-3. Component Map, Top (Board Rev. 22) 2-6 BajaPPC-750: Setup Figure 2-4. Component Map, Bottom (Board Rev. 22) Figure 2-5. Component Map, Top (Board Rev. 21) 2-8 BajaPPC-750: Setup Figure 2-6. Component Map, Bottom (Board Rev. 21) Figure 2-7. Component Map, Top (Board Rev. 1) 2-10 BajaPPC-750: Setup Figure 2-8. Component Map, Bottom (Board Rev. 1) Figure 2-9. Jumper and Fuse Locations 2-12 BajaPPC-750: Setup ### 2.2.2 Serial Numbers | ore you install the BajaPPC-750 in a card cage or system, you should record following information: | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | The board serial number: | | The board serial number appears on a bar code sticker located on the back of the board. | | The monitor version: | | The version number of the monitor is on the monitor start-up display. | | The operating system version and part number: | | This information is labeled on the master media supplied by Artesyn or another vendor. | | The board revision number/date code: 621 | | A sticker on the board contains the board assembly part number (beginning with "621" for BajaPPC-750), ECO level (preceded by an asterisk *), date code, and configuration description. Be sure to include all the information that appears on the sticker. | | Any custom or user ROM installed, including version and serial number: | | - <del></del> • | It is useful to have these numbers available when you contact Artesyn Communication Products. ### 2.2.3 Connectors The BajaPPC-750 has various connectors as follows: | THE Dajar I | C-750 Has various connectors as follows. | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PO | P0 is an optional VME connector that allows for additional I/O and 3.3V power signals. It has six rows of 19 pins for a total of 114 extra signal paths. Pin assignments are shown in Section 6.13. | | P1, P2 | P1 and P2 are the main VME connectors, which are compatible with both three-row and five-row DIN backplanes. P2 handles PMC I/O, AUI Ethernet, and serial I/O. P2 has an optional configuration that includes a Motorola-specific pinout, as well as a parallel port. Pin assignments are shown in Section 6.13. | | Р3 | P3 is an RI45 connector for the front panel Fast Ethernet port | P3 is an RJ45 connector for the front panel Fast Ethernet port. Refer to Section 7.5.1 for the pin assignments. | P4 | P4 is an RJ45 connector for the front panel serial port A (standard configuration only). See Section 8.3.4 for pin assignments. | |----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | J1x, J2x | J1x (J11, J12, J14) and J2x (J21, J22, J24) are the two sets of PMC module connectors. Details and pin assignments are in Chapter 5. | | HDR1 | HDR1 is a 16-pin JTAG\COP header that allows for boundary-scan testing of the PowerPC CPU and the BajaPPC-750. See Section 3.7 for pin assignments. | | HDR2 | HDR2 allows for PLD programming (factory use only). | | HDR3 | HDR3 is a 14-pin header located on the front of the circuit board to accommodate EIA-232 communications from serial port B. See Section 8.3.4 for pin assignments. | | HDR4 | HDR4 is a 16-pin debug header that allows additional access to various PowerPC test signals. See Section 3.8 for pin assignments. | ### 2.2.4 Reset/Interrupt Switch This momentary two-position toggle switch can reset the BajaPPC-750 or provide a level 6 interrupt to the CPU. It is located between serial port connector P4 and the LED on the front panel. The interrupt position on this switch may be used as a user-defined debugging tool. To determine the status of the interrupt switch, read bit zero of the 32-bit interrupt status register at FF9A,0070 $_{16}$ ; a one indicates a switch interrupt. To clear the interrupt, write a one to the 8-bit register at FF9E,0000 $_{16}$ . ### 2.2.5 LED The BajaPPC-750 has a seven-segment LED on the front panel. The control register for this LED is located in a PLD at FF98,0000 $_{16}$ . Each bit of this register controls a particular segment of the seven-segment display. To turn a segment on, write a one to its control bit. At power-up or after a system reset, all segments are off. The segments are connected to data bits DH0-DH7 on the CPU as follows: Table 2-2. LED Segment Vector Assignments | Data Bit | Segment | Data Bit | Segment | |----------|---------|----------|---------------| | DH0 | f | DH4 | С | | DH1 | g | DH5 | b | | DH2 | е | DH6 | a | | DH3 | d | DH7 | decimal point | 2-14 BajaPPC-750: Setup ### 2.2.6 Optional VMEbus Configurations The BajaPPC-750 has an optional configuration that includes a six-row, 114-pin, VMEbus connector at P0 (see page 29 for pin assignments). It also has an optional configuration that includes a three-row, 96-pin, VMEbus connector at P2 (see page 33 for pin assignments). This optional P2 configuration provides compatability with the Motorola MVME712M transition module. Also, the software can read bit 6 of the Board Configuration Register at FF98,0020<sub>16</sub> to determine which P2 configuration is installed on the BajaPPC-750 (see Register Map 2-1). A value of zero in this field indicates the standard configuration, while a one indicates the optional configuration. Register Map 2-1. BajaPPC-750 Board Configuration (P2 Configuration) # 2.3 BajaPPC-750 Setup You need the following items to set up and check the operation of the Artesyn BajaPPC-750. - ☐ Artesyn BajaPPC-750 microcomputer board - ☐ Card cage and power supply - ☐ Serial interface cable (EIA-232) - □ CRT terminal When you unpack the board, save the antistatic bag and box for future shipping or storage. CAUTION. To avoid damaging the board, do not install or remove it while power is applied to the rack. CAUTION. The BajaPPC-750 board requires a relatively high insertion/ extraction force. Be careful not to flex the board while handling it. Use the mounting screws to apply pressure evenly during insertion. BajaPPC-750 Setup 2-15 # 2.3.1 Providing Power Be sure your power supply is sufficient for the board. Without a PMC module, the BajaPPC-750 requires about 30 watts maximum. With two PMC modules, the requirement is approximately 45 watts maximum. Power supply ripple and noise below 10 MHz should be limited to 50 mV peak-to-peak (a requirement of the VMEbus specification). Power requirements for the BajaPPC-750 are shown in Table 2-3. NOTE. VMEbus connectors P1 and P2 must be used to meet BajaPPC-750's power requirements. Fuses select whether the P1 connector or the onboard regulator provides +3.3-volt power signals for the PMC module(s). Both power sources have a current limit of 1 Amp (see also Chapter 5). Table 2-3. Power Requirements | Voltage<br>(volts) | Range<br>(volts) | Maximum<br>Current | Usage | |--------------------|------------------|----------------------------|----------------------| | +3.3 | ±5% | 1 amp <sup>a</sup> | PMC module dependent | | +5 | ±5% | 4 amps <sup>b</sup> | All logic | | +12 | ±5% | 100 milliamps <sup>c</sup> | PMC module dependent | | -12 | ±5% | 100 milliamps <sup>c</sup> | PMC module dependent | a. Many modules do not require the +3.3V supply. ### 2.3.2 Providing Air Flow As with any printed circuit board, be sure that there is sufficient air flow to the board to prevent overheating. The environmental requirements are specified as: **Operating temp.** 0 to +55 degrees Centigrade, ambient (at board) **Relative humidity** 0% to 95% (non-condensing) Storage temperature -40 to +85 degrees Centigrade, ambient CAUTION. High operating temperatures will cause unpredictable operation or permanent failure. Because of the high power requirements of the CPU, fan cooling is required for all configurations, even when boards are placed on extenders. b. Current is measured during an on-card memory test, without a PMC module. c. Estimated 2-16 BajaPPC-750: Setup # 2.4 Operational Checks All products are tested before they are shipped from the factory. When you receive your BajaPPC-750, follow these steps to assure yourself that the system is operational: - 1. Read "Monitor", Chapter 10 and the operating system literature to become familiar with their features and available tools. - 2. Visually inspect the board for components that could have loosened during shipment. Visually inspect the chassis and all cables. - 3. Install the BajaPPC-750 in the VMEbus card cage. Be sure the board is seated firmly. - 4. Connect a CRT terminal to serial port A via connector P4 or the transition module console port. Set the terminal as follows: - □ 9600 baud, full duplex - ☐ Eight data bits (no parity) - ☐ Two stop bits for transmit data - One stop bit for receive data. If your terminal does not have separate controls for transmit and receive stop bits, select one stop bit for both transmit and receive. Also, be sure the serial cable is securely connected. - 5. Turn the system on. If you are using the BajaPPC-750 monitor, VxWorks, or pSOS, a sign-on message and prompt should appear on the screen. If the prompt does not appear, try using the toggle switch to Reset (R), then check your power supply voltages and CRT cabling. 6. Turn off the power before you remove boards from the card cage. ### 2.5 Reset Methods Any of the following actions reset the entire board: - Power-up - Input from the VMEbus SYSRESET\* signal on P1 (row C, pin 12) Troubleshooting 2-17 - Setting the toggle switch to Reset (R) on the BajaPPC-750 front panel - Writing a one to bit 23 (SW\_LRST) of the Universe chip's MISC\_CTL register at offset 404<sub>16</sub> resets the Universe and all devices on the local PCI bus (does not reset other VMEbus devices) # 2.6 Troubleshooting | case of difficulty, use this checklist: | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Be sure the board is seated firmly in the card cage. | | Be sure the system is not overheating. | | Check the power cables and connectors to be certain they are secure. | | If you are using the BajaPPC-750 monitor, run the power-up diagnostics and check the results. "Monitor", Chapter 10 describes the power-up diagnostics. | | Check your power supply for proper DC voltages. If possible, use an oscilloscope to look for excessive power supply ripple or noise (over 50 mV $_{\rm pp}$ below 10 MHz). Note that the use of P2 is required to meet the power specifications | | Check your terminal switches and cables. Be sure the serial cable is secure. | | Check that your terminal is connected to serial port A on the front panel. | | The BajaPPC-750 monitor uses values stored in on-card NVRAM (ROM) to configure and set the baud rates for its console port. The lack of a prompt might be caused by incorrect terminal settings, an incorrect configuration of the NVRAM, or a malfunctioning NVRAM. Try holding down the H character during a reset to abort autoboot using NVRAM parameters. If the prompt comes up, the NVRAM console parameters are probably configured incorrectly. Type <b>nvopen</b> then <b>nvdisplay</b> to check the console configuration. For more information about the way the NVRAM is used to configure the console port baud rates, refer to Chapter 10. | | | 2-18 BajaPPC-750: Setup # 2.6.1 Technical Support After you have checked all of the above items, call 1-800-327-1251 and ask for technical support from our Customer Services Department (or send email to support@artesyncp.com). Please have the following information handy: - the BajaPPC-750 serial number, - the BajaPPC-750 monitor revision level (on the monitor start-up display and in the monitor command prompt in square brackets—see Chapter 10), - version and part number of the operating system, - revision/date code sticker on the front of the board, and - whether your board has been customized for options such as processor speed or configuration for networking and peripherals. ### 2.6.2 Service Information If you plan to return the board to Artesyn Communication Products for service, call 1-800-327-1251 and ask for our Test Services Department (or send e-mail to serviceinfo@artesyncp.com) to obtain a Return Merchandise Authorization (RMA) number. We will ask you to list which items you are returning and the board serial number, plus your purchase order number and billing information if your BajaPPC-750 is out of warranty. Contact our Test Services Department for any warranty questions. If you return the board, be sure to enclose it in an antistatic bag, such as the one in which it was originally shipped. Send it prepaid to: Artesyn Communication Products Test Services Department 8310 Excelsior Drive Madison, WI 53717 | RMA | # | <u> </u> | |-----|---|----------| | | | | Please put the RMA number on the outside of the package so we can handle your problem efficiently. Our service department cannot accept material received without an RMA number. # **Central Processing Unit** This chapter is an overview of the processor logic on the BajaPPC-750. It includes information on the CPU, exception handling, and cache memory. The BajaPPC-750 utilizes the IBM PPC750 PowerPC $^{\text{TM}}$ microprocessor, running at an internal clock speed of 366 MHz or higher. The following table outlines some of the key features for the PPC750 CPU: Table 3-1. BajaPPC-750 CPU Features | Category | PPC750 Key Features | |------------------------|-----------------------------------------------| | Instruction Set | 32-bit | | CPU Speed (internal) | 366 MHz (and faster) | | Data Bus | 32/64-bit modes | | Address Bus | 32-bit | | Instructions per Clock | 3, (2 + Branch) | | Cache(s) | 32K Instruction, 32K Data | | Execution Units | 2 Integer, Float, Branch, Load/Store, System | | Voltages | internal, 1.9 V or 2.5 V; input/output, 3.3 V | Other general features for the PowerPC family of microprocessors include: - Superscalar microprocessor - Independent execution units and multiple register files - Independent, 8-way, set-associative, instruction and data caches - Low power design - JTAG/COP test interface ### 3.1 Processor Reset The BajaPPC-750 has a momentary two-position reset switch on its front panel. Upon assertion of the SWRST\* signal from this switch or the V\_SYSRST\* VME reset signal, the HRESET\* signal is asserted at the CPU and power-on reset circuitry, ensuring the proper initialization value for the DRTRY\* signal. When asserted, this signal prohibits data retrys, allowing operation of the fast L2 cache and data streaming. In addition, the front panel switch can issue a non-maskable interrupt to the interrupt controller programmable logic device (PLD). Software resets are initiated by asserting the SRESET\* signal at the CPU. Bit 7 of the Board Configuration Register (see Register Map 3-1) at FF98,0020<sub>16</sub> indicates whether or not the reset was due to a power-up condition (0=power-up, 1=reset). After power-up, a write to the Clear NMI Register at FF9E,0000<sub>16</sub> sets this bit, which is cleared only at power-up. (After power-up, wait for at least 500 milliseconds before writing to the Clear NMI Register.) Register Map 3-1. BajaPPC-750 Board Configuration (Reset) ### 3.2 Processor Initialization Initially, the BajaPPC-750 powers up with specific values stored in the CPU registers. The initial power-up state of the Hardware Implementation Dependent register (HID0) and the Machine State register (MSR) are given in Table 3-2. Table 3-2. CPU Internal Register Initialization | Register | Default After<br>Initialization (Hex) | Notes | |----------|---------------------------------------|-----------------------------------------------------------------| | HID0 | 8000,802C | Hardware Implementation Dependent register. (See Section 3.2.1) | | MSR | 3032 | Machine State register.<br>(See Section 3.2.2) | Processor Initialization 3-3 ### 3.2.1 Hardware Implementation Dependent Register The Hardware Implementation Dependent Register, HID0, contains bits for CPU-specific features. Most of these bits are cleared on initial power-up of the BajaPPC-750. Please refer to the *PPC750 RISC Microprocessor User's Manual* for more detailed descriptions of the individual bit fields. The following register map summarizes HID0 for the PPC750 CPU: Register Map 3-2. PPC750 Hardware Implementation Dependent, HID0 | <b>EMCP</b> Enable ma | achine check pin. | Initially enabled or | the BajaPPC-750. | |-----------------------|-------------------|----------------------|------------------| |-----------------------|-------------------|----------------------|------------------| **DBP** Enable bus address and data parity generation (in conjunction with EBA/ EBD). **EBA/EBD** Bus address and data parity checking enables. BCLK Select bus clock for test clock pin. **ECLK** Enable external test clock pin. **PAR** Disable precharge of ARTRY\* and shared signals. **DOZE** In doze mode the PLL, time base, and snooping are active. **NAP** In nap mode the PLL and time base are active. **SLEEP** In sleep mode no external clock is required. **DPM** Enable dynamic power management. NHR Not hard reset (software only). 0=hard reset, 1=no hard reset. ICE/DCE Instruction and data cache enables. The instruction cache is enabled on initial power-up. I/DLOCK Instruction and data cache lock bits. **ICFI/DCFI** Instruction and data cache flash invalidate bits. **SPD** Speculative cache access disable. **IFEM** Instruction fetch enable M bit. **SGE** Store gathering enable. DCFA Data cache flush assist. BTIC Disable 64-entry branch instruction cache. ABE Address broadcast enable. Allows broadcast of **dcbf**, **dcbi**, and **dcbst** on the bus. BHT Enable branch history table. **NOOPTI** No-op touch instructions. # 3.2.2 Machine State Register The Machine State Register, MSR, configures the state of the PPC750 CPU. On initial power-up of the BajaPPC-750, most of the MSR bits are cleared. The MSR may be read using the Move to Machine State Register (**mtmsr**) instruction. The **mtmsr**, System Call (**sc**), and Return from Exception (**rfi**) instructions may be used to modify the MSR. Please refer to the *PPC750 RISC Microprocessor User's Manual* for detailed bit descriptions. Register Map 3-3. CPU Machine State, MSR Processor Initialization 3-5 POW Power management enable. Setting this bit enables the programmable power management modes: nap, doze, or sleep. These modes are selected in the HIDO register. This bit has no effect on dynamic power management. - ILE Exception little-endian mode. - EE External interrupt enable. This bit allows the processor to take an external interrupt, system management interrupt, or decrementer interrupt. - **PR** Privilege level. 0= user- and supervisor-level instructions are executed 1= only user-level instructions are executed - **FP** Allows the execution of floating-point instructions. This bit is set on initial power-up. - ME Machine check enable. Machine checking is enabled initially on the BajaPPC-750. - FE0/FE1 These bits define the floating-point exception mode. **Table 3-3. IEEE Floating-Point Exception Modes** | FE0 | FE1 | FP Exception Mode | | |-----|-----|--------------------------|--| | 0 | 0 | Disabled | | | 0 | 1 | Imprecise nonrecoverable | | | 1 | 0 | Imprecise recoverable | | | 1 | 1 | Precise | | - **SE/BE** Single-step and branch trace enables. - IP Exception prefix. Initially, this bit is cleared so that the exception vector table is placed at the base of RAM $(0000,0000_{16})$ . When this bit is set, the vector table is placed at the base of ROM $(FFF0,0000_{16})$ . - IR/DR Instruction and data address translation enables. - RI Recoverable exception enable for system reset and machine check. This feature is enabled on initial power-up. - LE Little-endian mode enable. On the BajaPPC-750, this bit must set to zero so that the processor always runs in big-endian mode. # 3.3 Exception Handling Each CPU exception type transfers control to a different address in the vector table. The vector table normally occupies the first 2000 bytes of RAM (with a base address of $0000,0000_{16}$ ) or ROM (with a base address of FF80,0000<sub>16</sub>). An unassigned vector position may be used to point to an error routine or for code or data storage. Table 3-4 lists the exceptions recognized by the processor from the lowest to highest priority. **Table 3-4. PPC750 Exception Priorities** | Exception | Vector Address<br>Hex Offset | Notes | |--------------------------------|------------------------------|-----------------------------------------------------------------------------------| | Trace | 00D00 | Lowest priority. | | DSI | 00300 | Refer to CPU user's manual for specific causes. | | Alignment | 00600 | Any alignment exception condition. | | DSI | 00300 | Due to eciwx, ecowx. | | Program | 00700 | Due to a floating-point enabled exception. | | Floating-point unavailable | 00800 | Any floating-point unavailable exception. | | System call | 00C00 | System call exception. | | Program | 00700 | Due to an illegal instruction, a privileged instruction, or a trap. | | Instruction address breakpoint | 01300 | IABR | | ISI | 00400 | Instruction fetch exceptions. | | Thermal management | 01700 | Programmer-specified. | | Decrementer interrupt | 00900 | Decrementer passed through zero. | | Performance monitor interrupt | 00F00 | Programmer-specified. | | External interrupt | 00500 | Refer to Section 3.4 for description of interrupt sources and interrupt handling. | | System management interrupt | 01400 | SMI* | | System reset | 00100 | Soft reset. | | Machine check | 00200 | Assertion of TEA*. | | System reset | 00100 | Highest priority, hard reset. | | _ | 00000 | Reserved. | Interrupt Handling 3-7 # 3.4 Interrupt Handling The interrupt controller on the BajaPPC-750 is a programmable logic device (PLD) that handles seven local interrupts and receives external interrupts from the counter/timers and PMC modules. (See Chapters 6 and 9 for additional information.) The interrupt controller drives the 750\_INT\* interrupt input on the CPU. The interrupt controller's registers are accessible through the MPC106 ROM interface. When an interrupt is pending, the CPU may read a unique vector from the controller at location FF9A,0060 $_{16}$ or the current state of the interrupts from the Interrupt Status Register at FF9A,0070 $_{16}$ . These 32-bit registers are connected to the most significant long word on the CPU bus. Table 3-5. Interrupt Vector Assignments | Interrupt Source | Mnemonic | Priority | Hex Vector | |------------------|----------|----------|------------| | Counter/Timer 2 | CT2 | Highest | 0000,00B8 | | Counter/Timer 1 | CT1 | | 0000,00B0 | | Ethernet | ETH | | 0000,00A8 | | PMC Site 2 INTD* | J2x INTD | | 0000,00A0 | | PMC Site 2 INTC* | J2x INTC | | 0000,0098 | | PMC Site 2 INTB* | J2x INTB | | 0000,0090 | | PMC Site 2 INTA* | J2x INTA | | 0000,0088 | | PMC Site 1INTD* | J1x INTD | | 0000,0080 | | PMC Site 1 NTC* | J1x INTC | | 0000,0078 | | PMC Site 1INTB* | J1x INTB | | 0000,0070 | | PMC Site 1INTA* | J1x INTA | | 0000,0068 | | Universe output | LINT7 | | 0000,0060 | | Universe output | LINT6 | | 0000,0058 | | Universe output | LINT5 | | 0000,0050 | | Universe output | LINT4 | | 0000,0048 | | Universe output | LINT3 | | 0000,0040 | | Universe output | LINT2 | | 0000,0038 | | Universe output | LINT1 | | 0000,0030 | | Universe output | LINT0 | | 0000,0028 | | ISA bridge chip | ISA INT | | 0000,0010 | | Reset switch | NMI | | 0000,0008 | | None pending | _ | Lowest | 0000,0000 | Register Map 3-4. BajaPPC-750 Interrupt Status The interrupt handler sends a command for the interrupting device to acknowledge the interrupt and deassert 750\_INT\*. # 3.5 Bus Speed Bit 5 of the Board Configuration Register (see Register Map 3-5) at location FF98,0020 $_{16}$ indicates the local bus speed. A configuration resistor determines the state of this bit (0 = 66 MHz, 1 = 83 MHz). Register Map 3-5. BajaPPC-750 Board Configuration (Bus Speed) # 3.6 Cache Memory The PPC750 processor has separate, on-chip, 32-kilobyte instruction and data caches with eight-way, set-associative translation lookaside buffers (TLBs). The CPU supports the modified/exclusive/invalid (MEI) cache coherency protocol. Each cache has 128 entries and supports demand-paged virtual memory address translation and variable-sized block translation. The PPC750 also employs pseudo-least-recently used (PLRU) replacement algorithms for enhanced performance. Cache Memory 3-9 ### 3.6.1 Integrated Level 2 Cache In addition to the on-chip caches, the PPC750 CPU utilizes a 1-megabyte, integrated secondary cache provided by two synchronous random access memory (SRAM) chips. For the BajaPPC-750, the cache operates in Fast L2 mode and integrates data, tag, host interface, and LRU memory with a cache controller. At 122 MHz and above, it performs with zero wait states (2-1-1-1 burst). The cache design is two-way, set-associative and employs LRU logic. The software can read an 8-bit register at FF98,0030 $_{16}$ to determine the L2 configuration settings (see Register Map 3-6). There are various configuration resistors that set the bit values for this register (0=installed, 1=not installed). Please refer to the IBM documentation for details on the L2 configuration parameters. Register Map 3-6. BajaPPC-750 L2 Cache/PMC Bus Mode - L2 L2 cache enable/disable. 0=enabled, 1=disabled - **DIVISOR** L2 clock divisor. 00=divide by 3, 01=divide by 2.5, 10=divide by 2, 11=divide by 1.5 - HLD L2 hold time. 00=0.5 nanosecond, 01=1 nanosecond, 10=1.2 nanoseconds, 11=1.5 nanoseconds - DLL L2 DLL speed. 0=fast, 1=slow - J2X–J1X PMC bus mode. These bits do not affect the L2 cache. Refer to page 3 for details on the PMC bus mode. # 3.7 JTAG/COP Interface The JTAG/COP interface provides boundary-scan testing of the CPU and the BajaPPC-750. This interface is compliant with IEEE 1149.1 interface standard. JTAG interface signals are routed to header HDR1 (refer to the component map in Fig. 2-5). Table 3-6. JTAG/COP Interface Pin Assignments (HDR1) | Pin | Signal | Pin | Signal | |-----|---------------|-----|----------------------| | 1 | TDO | 2 | no connection | | 3 | TDI | 4 | TRST* | | 5 | no connection | 6 | +3.3V | | 7 | TCK | 8 | no connection | | 9 | TMS | 10 | no connection | | 11 | SRESET* | 12 | GND | | 13 | HRESET* | 14 | used as a keying pin | | 15 | CKSTP_OUT* | 16 | GND | The signals for the JTAG/COP interface are defined as follows: CKSTP\_OUT\* Checkstop Output. When asserted, this output signal indicates that the CPU has detected a checkstop condition and has ceased operation. This signal also drives the HALT LED on the BajaPPC-750 circuit board. HRESET\* Hard Reset. This input signal is used at power-up to reset the processor. SRESET\* Soft Reset. This input signal may initiate a warm reset. **TCK** Test Clock Input. Scan data is latched at the rising edge of this signal. TDI Test Data Input. This signal acts at the input port for scan instructions and data. TDO Test Data Output. This signal acts as the output port for scan instructions and data. **TMS** Test Mode Select. This input signal is the test access port (TAP) controller mode signal. TRST\* Test Reset. This input signal resets the test access port. Debug Header 3-11 # 3.8 Debug Header In addition to the COP/JTAG interface, the BajaPPC-750 has a debug header at HDR4 on the back of the board to provide easy access to the following signals: Table 3-7. Debug Header Pin Assignments (HDR4) | Pin | Signal | Pin | Signal | |-----|--------|-----|--------| | 1 | ARTRY* | 2 | TA* | | 3 | TS* | 4 | TEA* | | 5 | AACK* | 6 | MCP* | | 7 | TT0 | 8 | TSIZ0 | | 9 | TT1 | 10 | TSIZ1 | | 11 | TT2 | 12 | TSIZ2 | | 13 | TT3 | 14 | BG* | | 15 | TT4 | 16 | TBST* | The signals for the debug header are defined as follows: **ARTRY\*** Address Retry. Refer to the processor's user manual for details. TA\* Transfer Acknowledge. This signal acknowledges the successful completion of a data transfer. TS\* Transfer Start. This signal indicates that a bus transaction is starting. TEA\* Transfer Error Acknowledge. This signal terminates a transfer error. AACK\* Address Acknowledge. This signal terminates the address phase of transaction. MCP\* Machine Check Interrupt. Refer to the processor's user manual for details. TT0-TT4 Transfer Type. Refer to the processor's user manual for details. **TSIZ0–TSIZ2** Transfer Size. Refer to the processor's user manual for details. **BG\*** Bus Grant. This is the processor bus grant signal. **TBST\*** Transfer Burst. Refer to the processor's user manual for details. # On-Card Memory Configuration The BajaPPC-750 has a 32-pin, plastic-leaded chip carrier (PLCC) socket to support up to 512 kilobytes of EPROM or flash memory. The BajaPPC-750 also incorporates an 8-bit, 4-megabyte flash device and a 64-bit, 8-megabyte flash bank to provide an additional 12 megabytes of User Flash memory. The board supports on-card synchronous DRAM configurations of up to 256 megabytes. Off-card memory is accessible via the PMC/PCI and VMEbus interfaces. # 4.1 MPC106 Memory Interface The Motorola MPC106 acts as the memory controller for the BajaPPC-750. Table 4-1 lists the control registers associated with the memory interface. Chapter 5 describes the PCI bridge. Please refer to the MPC106 PCI Bridge/Memory Controller User's Manual for complete details on the memory interface registers. Table 4-1. MPC106 Memory Interface Configuration Registers | MPC106<br>Hex Address | Size in<br>Bytes | Access<br>Mode | Register Name | |-----------------------|------------------|----------------|----------------------------------| | 80-87 | 8 | R/W | Memory Starting Address | | 88-8F | 8 | R/W | Extended Memory Starting Address | | 90-97 | 8 | R/W | Memory Ending Address | | 98-9F | 8 | R/W | Extended Memory Ending Address | | A0 | 1 | R/W | Memory Enable | | A3 | 1 | R/W | Page Mode Counter/Tlmer | | F0 | 4 | R/W | Memory Control Configuration 1 | | F4 | 4 | R/W | Memory Control Configuration 2 | | F8 | 4 | R/W | Memory Control Configuration 3 | | FC | 4 | R/W | Memory Control Configuration 4 | The BajaPPC-750 Configuration Address and Data Registers at $FEC0,0000_{16}$ and $FEE0,0000_{16}$ allow access to the MPC106 registers. To initiate an access, write the value 0x8000,00nn (where nn is the MPC106 address of the register you want to access) to the Configuration Address Register at $FEC0,0000_{16}$ . The data for that register then may be read from or written to the Configuration Data Register at $FEE0,0000_{16}$ . # 4.2 Boot Memory Configuration The BajaPPC-750 has a 32-pin PLCC socket for either a byte-wide EPROM (up to 512 kilobytes) or a 512-kilobyte flash memory chip. This socketed memory occupies physical address space FF90,0000-FF97,FFFF<sub>16</sub>. CAUTION. When removing socketed PLCC devices, always use an extraction tool designed specifically for that task. Otherwise, you risk damaging the PLCC device. Jumpers on the BajaPPC-750 circuit board configure the memory as shown in Table 4-2. The on-board monitor (HKMON) is standard in the first 512K of this flash memory space. Table 4-2. Memory Configuration Jumpers | Jumper <sup>a</sup> | Function | Options | Default Configuration | | | |---------------------|------------------------------------------------|--------------------------------------------------------------|-------------------------------|--|--| | JP4 | Selects type of memory in PLCC socket. | JP4 in, Flash.<br>JP4 out, EPROM. | Varies | | | | JP5 | Enables writing to Flash memory in PLCC socket | JP5 in, Enable flash write.<br>JP5 out, Disable flash write. | JP5 in,<br>Enable write | | | | JP6 | Selects boot device | JP6 in, User Flash Bank 0<br>JP6 out, PLCC socket. | JP6 in, User<br>Flash Bank Ot | | | a. Spare jumpers are located at JP2 (board revs. 1 and 21 only). The MPC106 controls the access time for ROM. The default power-up timing allows boards of any speed to work with ROMs of speeds faster than 150 nanoseconds. We strongly suggest that you use the default timing because of the inherent risks of optimizing timing for a specific configuration and because the ROM is cached. User Flash 4-3 # 4.3 User Flash The BajaPPC-750 provides 12 megabytes of User Flash. Four megabytes of 8-bit wide flash is paged 512 kilobytes at a time to the address space at FF88,0000 $_{16}$ . This memory is paged because the address window is limited to 512 kilobytes. If booting from User Flash, Bank 0 is addressed at FF80,0000 $_{16}$ . The byte-wide Flash Bank Select register (R/W) at FF98,0010 $_{16}$ selects one of the eight User Flash pages at a time. All the Flash Bank Select Register bits are set to zeroes at power-up. Register Map 4-1. BajaPPC-750 Flash Bank Select In addition to the four megabytes of paged User Flash, the BajaPPC-750 provides another eight megabytes of 64-bit wide flash, beginning at address $FF00,0000_{16}$ . This memory must be accessed with 64-bit transfers from the PowerPC. ### 4.4 On-Card SDRAM The BajaPPC-750 supports 32-, 64-, 128-, and 256-megabyte configurations of 64-bit wide synchronous DRAM (SDRAM). The memory chips are 4Mx16 or 8Mx16, 3.3-V, SDRAM devices arranged in up to eight banks of four devices. (Currently, no configurations utilize more than four banks. Revision 22 and higher boards do not support more than four banks.) On-card RAM occupies physical addresses from $0000,0000_{16}$ to $0FFF,FFFF_{16}$ . The SDRAM is controlled by the MPC106 DRAM controller, which may be programmed for most memory sizes and speeds, various block sizes, and write protection. In addition to the basic SDRAM control functions the MPC106 chip provides several additional DRAM-related functions and contains the following performance enhancing features: - Programmable delay insertion for controlling RAS precharge time, RAS low time, CAS setup before RAS time, CAS precharge time, CAS pulse width, CAS access time, and address access time. - Logic needed to control parity generation, and checking logic with functions to clear parity errors. # 4.4.1 SDRAM Configuration Bits 0:3 of the Board Configuration Register (see Register Map 4-2) at FF98,0020 $_{16}$ store the SDRAM bank configuration information. Bit 4 indicates whether or not the parity option is installed. Bits 5–7 do not affect the SDRAM configuration. Register Map 4-2. BajaPPC-750 Board Configuration (Memory) A programmable logic device (PLD) maintains these configuration values, which are determined by whether or not specific configuration resistors are physically installed on the BajaPPC-750 circuit board. The following table describes the configuration bit selections: Table 4-3. Memory Configuration Bit Values | Bit Field | Description | Bit Val | ues | | | | |-------------|----------------------------------|---------|-------|-------|-------|------| | bit rieid | Description | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit0 | | mem_size | 64MB per bank | | | | | 0 | | | 32MB per bank | | | | | 1 | | bank_config | Bank 1 installed | | 0 | 0 | 0 | | | | Banks 1–2 installed | | 0 | 0 | 1 | | | | Banks 1–3 installed | | 0 | 1 | 0 | | | | Banks 1–4 installed | | 0 | 1 | 1 | | | | Banks 1–5 installed <sup>a</sup> | | 1 | 0 | 0 | | | | Banks 1–6 installed <sup>a</sup> | | 1 | 0 | 1 | | | | Banks 1–7 installed <sup>a</sup> | | 1 | 1 | 0 | | | | Banks 1–8 installed <sup>a</sup> | | 1 | 1 | 1 | | | parity | Parity not installed | 0 | | | | | | | Parity installed <sup>b</sup> | 1 | | | | | a. Currently, no configurations use more than four banks. Rev. 22 and higher boards do not support more than four banks. ### 4.4.2 SDRAM Timing One of the primary functions of the MPC106 is to allow flexible control of all important DRAM timing parameters. The correct SDRAM timing for any reasonable combination of board speed and SDRAM speed can be programmed. On the BajaPPC-750, the timing values programmed into the Memory Control Configu- <sup>&</sup>lt;sup>b.</sup> Currently, no configurations have parity installed. Rev. 22 and higher boards do not support parity. On-Card SDRAM 4-5 ration register 8 (F0 $_{16}$ ) have been carefully tuned for optimum memory cycle times for 100-MHz SDRAMs (running at 83MHz in the current configuration) under a variety of conditions. The table below describes the wait states for the BajaPPC-750. Table 4-4. SDRAM Access Time Required for the BajaPPC-750 | Cycle | Total Clocks | Wait States | | | | | |-----------------------------|--------------|-------------|--|--|--|--| | Reads | 7 | 6 | | | | | | Writes | 3 | 2 | | | | | | Burst Read<br>(4 accesses) | 7-1-1-1 | 6-0-0-0 | | | | | | Burst Write<br>(4 accesses) | 3-1-1-1 | 2-0-0-0 | | | | | For non-burst cycles, the number in the "Total Clocks" column of Table 4-4 is the total number of CPU clock cycles required to complete the transfer, and the number in the "Wait States" column is the number of wait states per cycle. For burst cycles, the number in the "Total Clocks" column of Table 4-4 is the total number of CPU clocks for the first access of the four 8-word (64-bit) burst, plus the number of clocks for the second, third, and fourth cycles. The number in the "Wait States" column is the number of wait states for each of the four accesses. There are two other sources of wait states that SDRAM architectures can exhibit: - When a refresh must be performed and the SDRAM controller is unable to perform the refresh during non-RAM cycles. This happens so infrequently that any performance degradation is usually unnoticeable. - When the processor is required to perform back-to-back memory cycles with no delays. This is also rare because of the instruction cache. In the event of a back-to-back memory cycle, an additional two-clock-cycle wait is inserted between accesses. While the above information is important in comparing the relative performance of SDRAM designs, the performance of individual SDRAM designs has much less impact on overall system performance than one might expect. The reason for this is that the internal instruction and data cache built into the CPU helps to decouple the processor from slower speed memories such as SDRAMs. To summarize, the higher the cache hit rates, the less impact external memory has on system performance. ### 4.5 Real-Time Clock The real-time clock for the BajaPPC-750 is provided by an M48T35 Timekeeper SRAM device from SGS-Thomson Microelectronics. This is CMOS device with 32K x 8 of non-volatile RAM, integrated real-time clock, power-fail control circuitry, and lithium battery. CAUTION. There is a danger of explosion if the lithium battery is incorrectly replaced. Replace only with the same or equivalent type recommended by the manufacturer. Dispose of used batteries according to the manufacturer's instructions. The BajaPPC-750 utilizes a SNAPHAT<sup>™</sup> housing that allows the quartz crystal and lithium cell to be mounted in a socket on top of the SRAM array and supporting circuitry. The M48T35 is pin- and function-compatible with standard JEDEC 32K x 8 SRAMs. The real-time clock and NVRAM are mapped in the BajaPPC-750 memory space beginning at FF9C,0000 $_{16}$ . CAUTION. Since the RTC registers deal with 100-year values, the software must correctly set starting values to accommodate the year 2000 and beyond. **Address** Function / Range D7 D5 D3 D2 D1 (Hex) D6 D4 D0 (BCD Format) 7FFF 10 Years Year / 00-99 Year 7FFE 0 0 0 10 M. Month Month / 01-12 7FFD 0 0 10 Date Date Date / 01-31 7FFC 0 FT 0 0 0 Day Day / 01-07 7FFB 0 0 10 Hours Hours Hour / 00-23 7FFA 0 10 Minutes Minutes Minutes / 00-59 7FF9 10 Seconds ST Seconds Seconds / 00-59 7FF8 W R S Calibration Control Data Register Map 4-3. BajaPPC-750 Real-Time Clock Real-Time Clock 4-7 The Real-Time Clock Configuration Registers contain all of the clock/calendar data and calibration information. Under normal operating conditions, the M48T35 operates as a conventional byte-wide static RAM. If the supply voltage drops below the $V_{\text{PFD}}$ (min) threshold, the device automatically protects itself by taking all outputs to high impedance and treating all inputs as "don't care." The control circuit switches power to the internal battery to preserve the data. The battery will operate for an accumulated period of at least 7 years. The following descriptions apply to the bits shown in Register Map 4-3: - FT Frequency Test Bit This bit is automatically reset to zero upon power-up and must be zero for normal clock operation. The FT bit is used in calibrating the clock (refer to M48T35 data sheet for calibration methods). - St Stop Bit Writing a one to this bit turns off the oscillator. If the M48T35 will be stored for a significant amount of time, stopping the oscillator minimizes current drain on the battery. - W Write Bit Writing a one to this bit halts the register updating so that the day, date, and time BCD data may be written. When the write bit is set back to zero, the written data is transferred to the counters and the register updating resumes. Note: The FT bit and '0' bits must be written to zero for normal clock and RAM operation. - R Read Bit Writing a one to this bit halts the register updating so that the day, date, and time information may be read. When the read bit is set back to zero, the register updating resumes. - Sign Bit This bit is used in calibrating the clock. A one indicates positive calibration, while a zero indicates negative calibration (see M48T35 data sheet for details). - These bits must be set to zero for proper operation of the real-time clock. # 4.6 Nonvolatile Memory Map A portion of ROM is reserved by Artesyn for data storage. The following memory map convention allows various operating systems to store their boot parameters without affecting each other. Table 4-5. Nonvolatile Memory Map | Hex Address Range | Description | |-------------------|--------------------------------------| | 500-7FF | User nonvolatile data storage | | 400-4FF | Reserved for pSOS | | 300-3FF | Reserved for VxWorks | | 000-2FF | Reserved for the BajaPPC-750 monitor | Please refer to "NVRAM Commands", Section 10.7 for details on programming the nonvolatile memory. # PMC/PCI Interface The PCI Mezzanine Card (PMC) interface supports the addition of modules that can provide other functions, such as SCSI, on the BajaPPC-750. The PMC/PCI interface complies with the Peripheral Component Interconnect (PCI) bus interface standard. ### 5.1 Features The BajaPPC-750 uses the Motorola MPC106 to implement the +3.3/5V PMC/PCI interface, which features: **Expansion Sites** The BajaPPC-750 has two PMC expansion sites to support two single-width PMC modules or one double-width PMC module. Both expansion sites support +3.3-volt or +5-volt PMC modules. NOTE. The BajaPPC-750 circuit board selects +3.3-volt module power from either the VMEbus backplane or the onboard regulator, depending upon which fuse is installed. F4 selects the backplane; F3 selects the onboard regulator. Do not install both fuses at the same time. Power from either source has a 1-Amp current limit. (Spare fuses are located at F1 and F2.) Address and Data Each PMC expansion site uses 32 multiplexed address/data lines to sup- port 8-, 16-, and 32-bit transfers. **Interrupts** Each PMC expansion site supports the four PCI interrupt lines. Initiator/Master The MPC106 can allow the BajaPPC-750 CPU to act as a PCI bus cycle initiator. Target/Slave The MPC106 can act as a PCI bus target for other initiator devices, such as PMC modules, Ethernet devices, or VMEbus controllers. ### 5.2 PMC Module Installation The BajaPPC-750 has two PMC expansion sites—J1x and J2x. A single-width PMC module may be installed at each of these sites, or a double-width module may be installed over both sites. Each site includes a cutout in the front panel for I/O. The possible PMC module configurations are shown in Fig. 5-1 and Fig. 5-2. Figure 5-1. Single-Width PMC Module Configuration Figure 5-2. Double-Width PMC Module Configuration When installing a PMC module, follow these guidelines: - 1. Before adding modules to the BajaPPC-750, be sure that the combined power requirements of the BajaPPC-750 and the PMC modules do not exceed the system's power supply rating. Without a PMC module, the BajaPPC-750 base-board requires a maximum of about 30 W. With two PMC modules, the requirement is approximately 45 W maximum. - 2. To prevent ESD damage to the BajaPPC-750 and the PMC modules, wear a grounding wriststrap and use a grounded work surface while handling the boards. - 3. If the BajaPPC-750 is installed in a system, turn off power to the BajaPPC-750 before removing it from the system. - 4. Set up the PMC module and install it on the BajaPPC-750 as specified in the module's hardware manual. CAUTION. To avoid the risk of damaging boards, do not install or remove boards from a rack while power is applied. To check if a PMC module is installed, read the L2 Cache/PMC Bus Mode Register (Register Map 3-6) at FF98,0030 $_{16}$ . A value of one in Bit 0 indicates that PMC site J1x is occupied, and a one in Bit 1 indicates that site J2x is occupied. # **5.3 PCI Bridge Configuration Registers** The Motorola MPC106 is the PCI bridge for the BajaPPC-750. It interfaces directly with the CPU and supports synchronous DRAM. Table 5-1 summarizes the MPC106 configuration registers associated with the PCI interface. For complete details on these registers and bit definitions, please refer to the MPC106 PCI Bridge/Memory Controller User's Manual. Table 5-1. MPC106 PCI Interface Configuration Registers | MPC106<br>Hex Offset | Size in<br>Bytes | Access<br>Mode | Register Name | Hex<br>Default | |----------------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------|----------------| | 00 | 2 | R | Vendor ID (Motorola) | 1057 | | 02 | 2 | R | Device ID (MPC106) | 0002 | | 04 | 2 | R/W | PCI Command Register. Allow access to both memory and I/O space. Allow the MPC106 to act as PCI bus master. | 0006 | | 06 | 2 | R/Bit-reset | PCI Status Register | 0800 | | 08 | 1 | R | Revision ID | nn | | 09 | 1 | R | Standard Programming Interface | 00 | | 0A | 1 | R | Subclass Code | 00 | | ОВ | 1 | R | Class Code | 06 | | MPC106<br>Hex Offset | Size in<br>Bytes | Access<br>Mode | Register Name | Hex<br>Default | |----------------------|------------------|----------------|-----------------------------------|----------------| | 0C | 1 | R | Cache Line Size | 08 | | 0D | 1 | R | Latency Timer | 00 | | OE | 1 | R | Header type | 00 | | 0F | 1 | R | BIST Control (Built-in self test) | 00 | | 3C | 1 | R | Interrupt Line | 00 | | 3D | 1 | R | Interrupt Pin | 00 | | 3E | 1 | R | MIN_GNT (Burst period length) | 00 | | 3F | 1 | R | MAX_GNT (PCI bus access rate) | 00 | | 40 | 1 | R | MPC106 Bus Number Assignment | 00 | | 41 | 1 | R/W | Subordinate Bus Number | 00 | | 42 | 1 | R | Target Disconnect Timeout Counter | 00 | Table 5-1. MPC106 PCI Interface Configuration Registers — Continued The MPC106 registers are accessed through the BajaPPC-750 Configuration Address and Data registers at $FEC0,0000_{16}$ and $FEE0,0000_{16}$ . To initiate an access, write the value 0x8000,00nn (where nn is the MPC106 address of the register you want to access) to the Configuration Address register at $FEC0,0000_{16}$ . Then the data for that register may be read from or written to the Configuration Data register at $FEE0,0000_{16}$ . # 5.3.1 PCI Command Register The PCI Command Register at hex offset $04_{16}$ controls the MPC106 bridge's ability to generate and respond to PCI cycles. | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|----|----|------|------|----|-----|------|------|-----|------|-----|----|----|----|-----| | Res. | RL | | Rese | rved | | FBB | SERR | Res. | PER | Res. | MWI | SC | ВМ | MS | IOS | Register Map 5-1. MPC106 PCI Command RL PCI force read lock (see MPC106 manual). 0=disable, 1=enable. FBB Fast back-to-back. Hardwired to zero (no fast back-to-back transactions). **SERR**\* driver enable. 0=disable, 1=enable. **PER** Parity error response enable. 0=disable, 1=enable. **MWI** Memory-write-invalidate. Hardwired to zero (no MWI command). - SC Special cycles. Hardwired to zero (ignore SC commands). - BM Bus master. 0=PCI access disable, 1=bus master enable. - MS Memory space access response. 0=disable, 1=enable. - **IOS** I/O space. Hardwired to zero (no response to PCI I/O space accesses). ### 5.3.2 PCI Status Register The MPC106 PCI Status Register at hex offset $06_{16}$ records status information for PCI-related events. (See important note below regarding RMA master abort status bit.) | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|-----|-----|----|-----|-----|------|-----|---|---|----------|---|---| | DPE | SSE | RMA | RTA | STA | DSE | iL | DPD | FBB | Res. | 66M | | F | Reserved | d | | # Register Map 5-2. MPC106 PCI Status - **DPE** Detected parity error. 1=parity error. - **SSE** Signalled system error. 1=SERR\* asserted. - RMA Received master abort. 1=transaction terminated by master abort. - CAUTION. You might need to clear the RMA bit more than once. After a master abort, always read the status of this bit to verify that it cleared successfully. - RTA Received target abort. 1=transaction terminated by target abort. - STA Signalled target abort. 1=target abort issued to a PCI master. - **DSEL** Device select timing. Hardwired to 0B00<sub>16</sub> (fast select). - DPD Data parity detected. 1=parity error (while MPC106 is bus master and PCI Command Register, bit 6, is set). - **FBB** Fast back-to-back capable. Hardwired to one (accept fast back-to-back transactions). - 66M 66-MHz capable. Read only indicator that MPC106 cannot operate the PCI bus at 66 MHz. ### 5.4 PCI Interface The MPC106 must be initialized to enable the functions on the chip and to set up the PCI bridge. The PCI bridge is used to decode portions of the local address bus and the PCI address bus. Fig. 5-3 illustrates how the PCI bridge works. Figure 5-3. PCI Bridge Memory Space ### 5.4.1 Device Mapping Once the PCI bridge is initialized, PCI devices should be mapped so that they can be accessed locally. In addition to the MPC106, there are two PMC expansion slots and three PCI devices on the local PCI bus. Each PCI device requires its own IDSEL address line as indicated in the table below: Table 5-2. PCI Device Identification Mapping | PCI Device | IDSEL Address | |------------|---------------| | PMC Slot 1 | AD11 | | PMC Slot 2 | AD12 | | Ethernet | AD15 | | VME bridge | AD16 | | ISA bridge | AD17 | PCI Interface 5-7 # **5.4.2 Timing** The module interface transfers data between PCI and local memory at burst data rates. When two modules are installed, they both contend for ownership of a common bus, which may reduce the individual performance of each module. Specific transfer rates to the PCI bus are dependent on the module design. **NOTE.** A module may burst up to 32 long words to or from DRAM before a boundary crossing occurs, starting a new cycle. Many PMC modules also incorporate a bridge chip between their PCI and local busses, essentially creating two bridges that must be crossed to complete a cycle. Often, the second bridge is a source of long delays due to the associated bus acquisition latency. Initialization and time-out values should be set up to accommodate any additional latency. # 5.4.3 Interrupts Each module has four interrupt lines which are routed through the interrupt controller programmable logic device (PLD) to the CPU's interrupt input. Refer to Section 3.4 for details. #### 5.4.4 Arbitration PCI arbitration for the BajaPPC-750 is handled by the Winbond Systems Laboratory W83C553 ISA Bridge chip. This is a programmable arbiter that supports eight masters. Upon power-up in the default mode, the arbiter allows all PCI masters equal access to the local bus. However, the relative priority can be adjusted by manipulating the PCI Priority Control Register 1 starting at index $80_{16}$ . See the W83C553 data book for complete details on this register. Register Map 5-3. Winbond PCI Priority Control BNK [3:1] Rotate These bits default to $111_2$ (rotation enabled). Enable BNK4 Fixed These bits select the priority as follows: **Mode Priority** $00_2$ selects IDE $\rightarrow$ bank1 $\rightarrow$ bank2 $\rightarrow$ bank3; $01_2$ selects bank1 $\rightarrow$ bank2 $\rightarrow$ bank3 $\rightarrow$ IDE; $10_2$ selects bank2 $\rightarrow$ bank3 $\rightarrow$ IDE $\rightarrow$ bank1; $11_2$ selects bank3 → IDE → bank1 → bank2 BNK [3:1] Fixed If no upper bits are chosen, IDEIRQ\* priority is always higher than Mode Priority REQ4\* # 5.5 PCI Bus Control Signals The following signals for the PCI interface are available on connectors J1x and J2x. Refer to the PCI specification for detailed usage of these signals. All signals are bi-directional unless otherwise stated. **NOTE.** A sustained three-state line is driven high for one clock cycle before float. ACK64\*, REQ64\* These output signals are used to tell a 64-bit PCI device whether to use the 64-bit or the 32-bit data width. Since the BajaPPC-750 is a 32-bit board, these signals are tied off to indicate the 32-bit data width. AD00-AD31 ADDRESS and DATA bus (bits 0-31). These three-state lines are used for both address and data handling. A bus transaction consists of an address phase followed by one or more data phases. **BUSMODE1\*-4\*** On the BajaPPC-750, BUSMODE2\* is tied high and BUSMODE3\* and BUSMODE4\* are tied low to indicate to the module that the BajaPPC-750 is a PMC baseboard. The module uses BUSMODE1\* to indicate that it is present and compatible with the BajaPPC-750. C/BEO\* -C/BE3\* BUS COMMAND and BYTE ENABLES. These three-state lines have differ- ent functions depending on the phase of a transaction. During the address phase of a transaction these lines define the bus command. Dur- ing a data phase the lines are used as byte enables. CLK Clock. This input signal to PMC modules provides timing for PCI trans- actions. **DEVSEL\*** DEVICE SELECT. This sustained three-state signal indicates when a device on the bus has been selected as the target of the current access. - **FRAME\*** CYCLE FRAME. This sustained three-state line is driven by the current master to indicate the beginning of an access, and continues to be asserted until transaction reaches its final data phase. - GNT\* GRANT. This input signal indicates that access to the bus has been granted to a particular master. Each master has its own GNT\*. - **IDSEL** INITIALIZATION DEVICE SELECT. This input signal acts as a chip select during configuration read and write transactions. - INTA, B, C, D\* PMC INTERRUPTS A, B, C, D. These input lines are used by the PMC module to interrupt the baseboard. The interrupts are routed through the interrupt controller to the CPU on BajaPPC-750. - **IRDY\*** INITIATOR READY. This sustained three-state signal indicates that the bus master is ready to complete the data phase of the transaction. - LOCK\* LOCK. This sustained three-state signal indicates that an atomic operation may require multiple transactions to complete. - PAR PARITY. This is even parity across AD00-AD31 and C/BE0-C/BE3\*. Parity generation is required by all PCI agents. This three-state signal is stable and valid one clock after the address phase, and one clock after the bus master indicates that it is ready to complete the data phase (either IRDY\* or TRDY\* is asserted). Once PAR is asserted, it remains valid until one clock after the completion of the current data phase. - **PERR\*** PARITY ERROR. This sustained three-state line is used to report parity errors during all PCI transactions. - **REQ\*** REQUEST. This output pin indicates to the arbiter that a particular master wants to use the bus. - **RST\*** RESET. The assertion of this input line brings PCI registers, sequencers, and signals to a consistent state. - **SERR\*** SYSTEMS ERROR. This open-collector output signal is used to report any system error with catastrophic results. - STOP\* STOP. A sustained three-state signal used by the current target to request that the bus master stop the current transaction. - TRDY\* TARGET READY. A sustained three-state signal that indicates the target's ability to complete the current data phase of the transaction. # 5.6 PMC Connector Pin Assignments Each PMC expansion site has three 64-pin connectors. Pin assignments are shown in Table 5-3 and Table 5-4. Table 5-3. J1x PMC Connector Pin Assignments | Pin | J11 | J12 | J14 | Pin | J11 | J12 | J14 | |-----|---------------|---------------|--------|-----|---------|---------------|--------| | 1 | TCK | +12V | P2-C1 | 33 | FRAME* | Ground | P2-C17 | | 2 | -12V | TRST* | P2-A1 | 34 | Ground | No Connection | P2-A17 | | 3 | Ground | TMS | P2-C2 | 35 | Ground | TRDY* | P2-C18 | | 4 | INTA* | No Connection | P2-A2 | 36 | IRDY* | +3.3V | P2-A18 | | 5 | INTB* | TDI | P2-C3 | 37 | DEVSEL* | Ground | P2-C19 | | 6 | INTC* | Ground | P2-A3 | 38 | +5V | STOP* | P2-A19 | | 7 | BUSMODE1* | Ground | P2-C4 | 39 | Ground | PERR* | P2-C20 | | 8 | +5V | No Connection | P2-A4 | 40 | LOCK* | Ground | P2-A20 | | 9 | INTD* | No Connection | P2-C5 | 41 | SDONE* | +3.3V | P2-C21 | | 10 | No Connection | No Connection | P2-A5 | 42 | SBO* | SERR* | P2-A21 | | 11 | Ground | BUSMODE2* | P2-C6 | 43 | PAR | C/BE1* | P2-C22 | | 12 | No Connection | +3.3V | P2-A6 | 44 | Ground | Ground | P2-A22 | | 13 | CLK | RST* | P2-C7 | 45 | +5V | AD14 | P2-C23 | | 14 | Ground | BUSMODE3* | P2-A7 | 46 | AD15 | AD13 | P2-A23 | | 15 | Ground | +3.3V | P2-C8 | 47 | AD12 | Ground | P2-C24 | | 16 | GNT* | BUSMODE4* | P2-A8 | 48 | AD11 | AD10 | P2-A24 | | 17 | REQ* | No Connection | P2-C9 | 49 | AD9 | AD8 | P2-C25 | | 18 | +5V | Ground | P2-A9 | 50 | +5V | +3.3V | P2-A25 | | 19 | +5V | AD30 | P2-C10 | 51 | Ground | AD7 | P2-C26 | | 20 | AD31 | AD29 | P2-A10 | 52 | C/BE0* | No Connection | P2-A26 | | 21 | AD28 | Ground | P2-C11 | 53 | AD6 | +3.3V | P2-C27 | | 22 | AD27 | AD26 | P2-A11 | 54 | AD5 | No Connection | P2-A27 | | 23 | AD25 | AD24 | P2-C12 | 55 | AD4 | No Connection | P2-C28 | | 24 | Ground | +3.3V | P2-A12 | 56 | Ground | Ground | P2-A28 | | 25 | Ground | IDSEL | P2-C13 | 57 | +5V | No Connection | P2-C29 | | 26 | C/BE3* | AD23 | P2-A13 | 58 | AD3 | No Connection | P2-A29 | | 27 | AD22 | +3.3V | P2-C14 | 59 | AD2 | Ground | P2-C30 | | 28 | AD21 | AD20 | P2-A14 | 60 | AD1 | No Connection | P2-A30 | | 29 | AD19 | AD18 | P2-C15 | 61 | AD0 | ACK64* | P2-C31 | | 30 | +5V | Ground | P2-A15 | 62 | +5V | +3.3V | P2-A31 | | 31 | +5V | AD16 | P2-C16 | 63 | Ground | Ground | P2-C32 | | 32 | AD17 | C/BE2* | P2-A16 | 64 | REQ64* | No Connection | P2-A32 | NOTE: The shaded table cells represent +3.3V supplied from either the P1 VMEbus connector (if fuse F4 is present) or from the onboard regulator (if fuse F3 is present). These fuses have a 1-Amp current limit. Table 5-4. J2x PMC Connector Pin Assignments | Pin | J21 | J22 | J24 | Pin | J21 | J22 | J24 | |-----|---------------|---------------|--------|-----|---------|---------------|--------| | 1 | TCK | +12V | P0-E4 | 33 | FRAME* | Ground | P0-C13 | | 2 | -12V | TRST* | P0-D4 | 34 | Ground | No Connection | P0-B13 | | 3 | Ground | TMS | P0-C4 | 35 | Ground | TRDY* | P0-A13 | | 4 | INTA* | No Connection | P0-B4 | 36 | IRDY* | +3.3V | P0-E14 | | 5 | INTB* | TDI | P0-A4 | 37 | DEVSEL* | Ground | P0-D14 | | 6 | INTC* | Ground | P0-E5 | 38 | +5V | STOP* | P0-C14 | | 7 | BUSMODE1* | Ground | P0-D5 | 39 | Ground | PERR* | P0-B14 | | 8 | +5V | No Connection | P0-C5 | 40 | LOCK* | Ground | P0-A14 | | 9 | INTD* | No Connection | P0-B5 | 41 | SDONE* | +3.3V | P0-E15 | | 10 | No Connection | No Connection | P0-A5 | 42 | SBO* | SERR* | P0-D15 | | 11 | Ground | BUSMODE2* | P0-E6 | 43 | PAR | C/BE1* | P0-C15 | | 12 | No Connection | +3.3V | P0-D6 | 44 | Ground | Ground | P0-B15 | | 13 | CLK | RST* | P0-C6 | 45 | +5V | AD14 | P0-A15 | | 14 | Ground | BUSMODE3* | P0-B6 | 46 | AD15 | AD13 | P0-E16 | | 15 | Ground | +3.3V | P0-A6 | 47 | AD12 | Ground | P0-D16 | | 16 | GNT* | BUSMODE4* | P0-E7 | 48 | AD11 | AD10 | P0-C16 | | 17 | REQ* | No Connection | P0-D7 | 49 | AD9 | AD8 | P0-B16 | | 18 | +5V | Ground | P0-C7 | 50 | +5V | +3.3V | P0-A16 | | 19 | +5V | AD30 | P0-B7 | 51 | Ground | AD7 | P0-E17 | | 20 | AD31 | AD29 | P0-A7 | 52 | C/BE0* | No Connection | P0-D17 | | 21 | AD28 | Ground | P0-E8 | 53 | AD6 | +3.3V | P0-C17 | | 22 | AD27 | AD26 | P0-D8 | 54 | AD5 | No Connection | P0-B17 | | 23 | AD25 | AD24 | P0-C8 | 55 | AD4 | No Connection | P0-A17 | | 24 | Ground | +3.3V | P0-B8 | 56 | Ground | Ground | P0-E18 | | 25 | Ground | IDSEL | P0-A8 | 57 | +5V | No Connection | P0-D18 | | 26 | C/BE3* | AD23 | P0-E12 | 58 | AD3 | No Connection | P0-C18 | | 27 | AD22 | +3.3V | P0-D12 | 59 | AD2 | Ground | P0-B18 | | 28 | AD21 | AD20 | P0-C12 | 60 | AD1 | No Connection | P0-A18 | | 29 | AD19 | AD18 | P0-B12 | 61 | AD0 | ACK64* | P0-E19 | | 30 | +5V | Ground | P0-A12 | 62 | +5V | +3.3V | P0-D19 | | 31 | +5V | AD16 | P0-E13 | 63 | Ground | Ground | P0-C19 | | 32 | AD17 | C/BE2* | P0-D13 | 64 | REQ64* | No Connection | P0-B19 | | | | | | | | | | NOTE: The shaded table cells represent +3.3V supplied from either the P1 VMEbus connector (if fuse F4 is present) or from the onboard regulator (if fuse F3 is present). These fuses have a 1-Amp current limit. # VMEbus Interface The Tundra Universe II CA91C142 provides a single-chip, 64-bit, VMEbus to PCI interface for the BajaPPC-750. The Universe is optimized to support high-speed processors and allows for numerous bus masters to share the resources on the bus. The VMEbus supports up to 21 boards. Artesyn tests all of its VMEbus boards in a fully-populated backplane. #### 6.1 Features The BajaPPC-750 VMEbus interface has the following features: **Address** The VMEbus interface uses 32 address lines for a total of 4 gigabytes of VMEbus address space. The VMEbus short, standard, and extended address modes are supported, and use 16, 24, and 32 address lines respectively. As VMEbus master, the BajaPPC-750 can access short, standard, and extended space addresses. As a VMEbus slave, the BajaPPC-750 can respond to the full 32-bit range of addresses on the VMEbus. The default master and slave images are programmable via parameters defined in the Artesyn monitor NVRAM configuration groups. Data The VMEbus interface uses 32 data lines and 32 address lines to support 8-, 16-, 24-, 32-, or 64-bit data transfers. Interrupts The Universe handles the seven VMEbus interrupts. Mailboxes / Location Monitor The Universe has four 32-bit mailboxes to facilitate interrupt routines for both the VMEbus and PCI bus. In addition, it supports a VMEbus location monitor to broadcast events across the VME backplane. **System Controller** The BajaPPC-750 may be configured as the VMEbus system controller to perform the necessary system controller functions: driving SYSCLK, BCLR, and SYSRESET, and providing bus watchdog and bus arbitration. Slave Enables Slave enables are provided for each VMEbus space to which the BajaPPC-750 responds—extended, standard, and short space. All three address spaces are initially disabled so that the CPU can control when slave accesses may first occur. The Artesyn monitor NVRAM configuration parameters (see Section 10.7) can program the slave interface to negate SYSFAIL\* when ready. Also, the monitor can enable the slave image independently. ### **6.2 Universe Configuration Registers** The Tundra Universe II CA91C142 provides a single-chip, VMEbus to PCI interface for the BajaPPC-750. Its registers are little-endian and occupy 4 kilobytes of internal memory. These registers are logically divided into three groups as follows: PCI configuration space, Universe device-specific, and VMEbus control and status. The method of access differs according to whether it is from the PCI bus or the VMEbus. From the PCI bus, the registers may be accessed through configuration space or the PCI-defined base address register (PCI\_BS), which resides locally at FE80,000<sub>16</sub>. From the VMEbus, the registers may be accessed through the VMEbus Register Access Image (VRAI), which occupies 4 kilobytes in A16, A24, or A32 space. Alternatively, the registers may be accessed from the VMEbus as CR/CSR space according to the VME64 specification. The following table summarizes the Universe control registers. Please refer to the *Universe User Manual* for detailed descriptions of the control bits. Table 6-1. Universe Internal Register Summary | Hex Offset | Mnemonic | Name | |------------|-----------|-----------------------------------------------------| | 000 | PCI_ID | PCI Configuration Space ID Register | | 004 | PCI_CSR | PCI Configuration Space Control and Status Register | | 008 | PCI_CLASS | PCI Configuration Class Register | | 00C | PCI_MISC0 | PCI Configuration Miscellaneous 0 Register | | 010 | PCI_BS | PCI Configuration Base Address Register | | 014 | PCI_BS1 | PCI Configuration Base Address Register 1 | | 018-024 | | PCI Unimplemented | | 028-2C | | PCI Reserved | | 030 | | PCI Unimplemented | | 034-038 | | PCI Reserved | | 03C | PCI_MISC1 | PCI Configuration Miscellaneous 1 Register | | 040-0FF | | PCI Unimplemented | | 100 | LSI0_CTL | PCI Slave Image 0 Control | | 104 | LSIO_BS | PCI Slave Image 0 Base Address Register | Table 6-1. Universe Internal Register Summary — Continued | Hex Offset | Mnemonic | Name | |------------|-----------|--------------------------------------------| | 108 | LSIO_BD | PCI Slave Image 0 Bound Address Register | | 10C | LSI0_TO | PCI Slave Image 0 Translation Offset | | 110 | | Universe Reserved | | 114 | LSI1_CTL | PCI Slave Image 1 Control | | 118 | LSI1_BS | PCI Slave Image 1 Base Address Register | | 11C | LSI1_BD | PCI Slave Image 1 Bound Address Register | | 120 | LSI1_TO | PCI Slave Image 1 Translation Offset | | 124 | | Universe Reserved | | 128 | LSI2_CTL | PCI Slave Image 2 Control | | 12C | LSI2_BS | PCI Slave Image 2 Base Address Register | | 130 | LSI2_BD | PCI Slave Image 2 Bound Address Register | | 134 | LSI2_TO | PCI Slave Image 2 Translation Offset | | 138 | | Universe Reserved | | 13C | LSI3_CTL | PCI Slave Image 3 Control | | 140 | LSI3_BS | PCI Slave Image 3 Base Address Register | | 144 | LSI3_BD | PCI Slave Image 3 Bound Address Register | | 148 | LSI3_TO | PCI Slave Image 3 Translation Offset | | 14C-16C | | Universe Reserved | | 170 | SCYC_CTL | Special Cycle Control Register | | 174 | SCYC_ADDR | Special Cycle PCI bus Address Register | | 178 | SCYC_EN | Special Cycle Swap/Compare Enable Register | | 17C | SCYC_CMP | Special Cycle Compare Data Register | | 180 | SCYC_SWP | Special Cycle Swap Data Register | | 184 | LMISC | PCI Miscellaneous Register | | 188 | SLSI | Special PCI Slave Image | | 18C | L_CMDERR | PCI Command Error Log Register | | 190 | LAERR | PCI Address Error Log | | 194-19C | | Universe Reserved | | 1A0 | LSI4_CTL | Local Slave Image 4 Control | | 1A4 | LSI4_BS | Local Slave Image 4 Base Address Register | | 1A8 | LSI4_BD | Local Slave Image 4 Bound Address Register | | 1AC | LSI4_TO | Local Slave Image 4 Translation Offset | | 1BD | | Universe Reserved | | 1B4 | LSI5_CTL | Local Slave Image 5 Control | | 1B8 | LSI5_BS | Local Slave Image 5 Base Address Register | | 1BC | LSI5_BD | Local Slave Image 5 Bound Address Register | | 1C0 | LSI5_TO | Local Slave Image 5 Translation Offset | | 1C4 | | Universe Reserved | Table 6-1. Universe Internal Register Summary — Continued | Hex Offset | Mnemonic | Name | |------------|-----------|--------------------------------------------| | 1C8 | LSI6_CTL | Local Slave Image 6 Control | | 1CC | LSI6_BS | Local Slave Image 6 Base Address Register | | 1D0 | LSI6_BD | Local Slave Image 6 Bound Address Register | | 1D4 | LSI6_TO | Local Slave Image 6 Translation Offset | | 1D8 | | Universe Reserved | | 1DC | LSI7_CTL | Local Slave Image 7 Control | | 1E0 | LSI7_BS | Local Slave Image 7 Base Address Register | | 1E4 | LSI7_BD | Local Slave Image 7 Bound Address Register | | 1E8 | LSI7_TO | Local Slave Image 7 Translation Offset | | 1EC-1FC | | Universe Reserved | | 200 | DCTL | DMA Transfer Control Register | | 204 | DTBC | DMA Transfer Byte Count Register | | 208 | DLA | DMA PCI bus Address Register | | 20C | | Universe Reserved | | 210 | DVA | DMA VMEbus Address Register | | 214 | | Universe Reserved | | 218 | DCPP | DMA Command Packet Pointer | | 21C | | Universe Reserved | | 220 | DGCS | DMA General Control and Status Register | | 224 | D_LLUE | DMA Linked List Update Enable Register | | 228-2FC | | Universe Reserved | | 300 | LINT_EN | PCI Interrupt Enable | | 304 | LINT_STAT | PCI Interrupt Status | | 308 | LINT_MAP0 | PCI Interrupt Map 0 | | 30C | LINT_MAP1 | PCI Interrupt Map 1 | | 310 | VINT_EN | VMEbus Interrupt Enable | | 314 | VINT_STAT | VMEbus Interrupt Status | | 318 | VINT_MAP0 | VMEbus Interrupt Map 0 | | 31C | VINT_MAP1 | VMEbus Interrupt Map 1 | | 320 | STATID | Interrupt Status/ID Out | | 324 | V1_STATID | VIRQ1 STATUS/ID | | 328 | V2_STATID | VIRQ2 STATUS/ID | | 32C | V3_STATID | VIRQ3 STATUS/ID | | 330 | V4_STATID | VIRQ4 STATUS/ID | | 334 | V5_STATID | VIRQ5 STATUS/ID | | 338 | V6_STATID | VIRQ6 STATUS/ID | | 33C | V7_STATID | VIRQ7 STATUS/ID | | 340 | LINT_MAP2 | Local Interrupt Map 2 Register | Table 6-1. Universe Internal Register Summary — Continued | Hex Offset | Mnemonic | Name | |------------|-----------|-----------------------------------------------| | 344 | VINT_MAP2 | VME Interrupt Map 2 Register | | 348 | МВОХ0 | Mailbox 0 | | 34C | MBOX1 | Mailbox 1 | | 350 | MBOX2 | Mailbox 2 | | 354 | MBOX3 | Mailbox 3 | | 358 | SEMA0 | Semaphore 0 Register | | 35C | SEMA1 | Semaphore 1 Register | | 360-3FC | | Universe Reserved | | 400 | MAST_CTL | Master Control | | 404 | MISC_CTL | Miscellaneous Control | | 408 | MISC_STAT | Miscellaneous Status | | 40C | USER_AM | User AM Codes Register | | 410-EFC | | Universe Reserved | | F00 | VSI0_CTL | VMEbus Slave Image 0 Control | | F04 | VSIO_BS | VMEbus Slave Image 0 Base Address Register | | F08 | VSI0_BD | VMEbus Slave Image 0 Bound Address Register | | F0C | VSI0_TO | VMEbus Slave Image 0 Translation Offset | | F10 | | Universe Reserved | | F14 | VSI1_CTL | VMEbus Slave Image 1 Control | | F18 | VSI1_BS | VMEbus Slave Image 1 Base Address Register | | F1C | VSI1_BD | VMEbus Slave Image 1 Bound Address Register | | F20 | VSI1_TO | VMEbus Slave Image 1 Translation Offset | | F24 | | Universe Reserved | | F28 | VSI2_CTL | VMEbus Slave Image 2 Control | | F2C | VSI2_BS | VMEbus Slave Image 2 Base Address Register | | F30 | VSI2_BD | VMEbus Slave Image 2 Bound Address Register | | F34 | VSI2_TO | VMEbus Slave Image 2 Translation Offset | | F38 | | Universe Reserved | | F3C | VSI3_CTL | VMEbus Slave Image 3 Control | | F40 | VSI3_BS | VMEbus Slave Image 3 Base Address Register | | F44 | VSI3_BD | VMEbus Slave Image 3 Bound Address Register | | F48 | VSI3_TO | VMEbus Slave Image 3 Translation Offset | | F4C-F60 | | Universe Reserved | | F64 | LM_CTL | Location Monitor Control | | F68 | LM_BS | Location Monitor Base Address Register | | F70 | VRAI_CTL | VMEbus Register Access Image Control Register | | F74 | VRAI_BS | VMEbus Register Access Image Base Address | | F78-F7C | | Universe Reserved | Table 6-1. Universe Internal Register Summary — Continued | Hex Offset | Mnemonic | Name | |------------|----------|---------------------------------------------| | F80 | VCSR_CTL | VMEbus CSR Control Register | | F84 | VCSR_TO | VMEbus CSR Translation Offset | | F88 | V_AMERR | VMEbus AM Code Error Log | | F8C | VAERR | VMEbus Address Error Log | | F90 | VSI4_CTL | VMEbus Slave Image 4 Control | | F94 | VSI4_BS | VMEbus Slave Image 4 Base Address Register | | F98 | VSI4_BD | VMEbus Slave Image 4 Bound Address Register | | F9C | VSI4_TO | VMEbus Slave Image 4 Translation Offset | | FA0 | | Universe Reserved | | FA4 | VSI5_CTL | VMEbus Slave Image 5 Control | | FA8 | VSI5_BS | VMEbus Slave Image 5 Base Address Register | | FAC | VSI5_BD | VMEbus Slave Image 5 Bound Address Register | | FB0 | VSI5_TO | VMEbus Slave Image 5 Translation Offset | | FB4 | | Universe Reserved | | FB8 | VSI6_CTL | VMEbus Slave Image 6 Control | | FBC | VSI6_BS | VMEbus Slave Image 6 Base Address Register | | FC0 | VSI6_BD | VMEbus Slave Image 6 Bound Address Register | | FC4 | VSI6_TO | VMEbus Slave Image 6 Translation Offset | | FC8 | | Universe Reserved | | FCC | VSI7_CTL | VMEbus Slave Image 7 Control | | FD0 | VSI7_BS | VMEbus Slave Image 7 Base Address Register | | FD4 | VSI7_BD | VMEbus Slave Image 7 Bound Address Register | | FD8 | VSI7_TO | VMEbus Slave Image 7 Translation Offset | | FDC-FEC | | Universe Reserved | | FF0 | Reserved | VME CR/CSR | | FF4 | VCSR_CLR | VMEbus CSR Bit Clear Register | | FF8 | VCSR_SET | VMEbus CSR Bit Set Register | | FFC | VCSR_BS | VMEbus CSR Base Address Register | #### 6.2.1 Initialization Values Some of the Universe registers have recommended initialization values, as described in the table below. Please see the *Universe User's Manual* for more information on the available power-up options. Table 6-2. Recommended Initialization Values for Universe | Configure | Register | Hex Default | Notes | |----------------------------------------|----------|--------------|------------------------------------------------------------------------------------------------------------------| | PCI space, control, and status | PCI_BS | 0080,0001 | PCI base address, mapped to I/O space | | | PCI_CSR | 0000,0045 | Parity error response, bus master, and target I/O enabled | | SYSFAIL* assertion | VCSR_CLR | 4000,0000 | De-assert SYSFAIL on VMEbus (typically written at power-up/init.) | | VMEbus transaction characteristics | MAST_CTL | 00D0,0000 | Set maximum number of retries, posted write transfer count, request level and mode, release mode, and burst size | | VMEbus timeout and other misc. params. | MISC_CTL | 3000,0000 | Set VMEbus timeout to 64µs | | Timer values | LMISC | Do not alter | Additional PCI timing params. | | VME Master Image 0 | LSIO_BS | C000,0000 | VME master base address | | (PCI Slave Image 0) | LSI0_BD | F800,0000 | VME master window size | | | LSI0_TO | 0000,0000 | VME master translation offset.<br>(Default to zero—can be any<br>address on 4K boundary) | | | LSIO_CTL | 8082,1000 | Enable image and set A32<br>address space, max. 32-bit<br>data width for VMEbus | | VME Slave Image 0 | VSIO_BS | C000,0000 | VME slave base address | | | VSI0_BD | C800,000 | VME slave window size | | | VSI0_TO | 4000,0000 | VME slave translation offset | | | VSI0_CTL | 8062,0000 | Enable image, set A32 address<br>space, data AM code, and<br>supervisor | | VMEbus Register Access | VRAI_BS | 0000,1000 | Mailbox base address | | Image Control | VRAI_CTL | 8060,0000 | Enable and set for data AM code and supervisor | #### 6.2.2 PCI Base Address Register The Universe PCI Configuration Base Address Register, PCI\_BS, at hex offset $010_{16}$ defines the base address of the Universe register space on PCI and has a resolution of 4 kilobytes. In addition, it determines whether the Universe registers are mapped to memory or I/O space. If mapped to memory space, the registers may be located anywhere in the address space, but they should not be pre-fetched. For added flexibility, a second Universe PCI Configuration Base Address Register, PCI\_BS1, exists at hex offset 014<sub>16</sub> with identical bit assignments. The SPACE bit assignment for this register is the logical inversion of the SPACE bit for PCI\_BS. Register Map 6-1. Universe PCI Base Address, PCI\_BS **BS** Base address. SPACE Local bus address space. (read only) Binary 0=memory, 1=I/O #### 6.2.3 PCI Configuration Space and Status Register The Universe PCI Configuration Space Control and Status Register, PCI\_CSR, at hex offset $004_{16}$ defines the PCI space, parity handling characteristics, and other general parameters. The BM bit allows the Universe to master the PCI bus. The MS and IOS bits map the PCI space to memory or input/output space, respectively. For additional information about PCI, please refer to the *PCI Local Bus Specification*. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 S\_ERR S\_TA **TFBBC** D PE R MA R TA **DEVSEL** DP D Reserved 9 5 15 12 8 7 6 2 1 0 14 13 11 10 4 3 MF-BBC SERR EN WAIT PERESP VGAPS MWI\_EN SC IOS Reserved ВМ MS Register Map 6-2. Universe PCI Configuration Space and Status, PCI\_CSR - D\_PE Detected parity error (write 1 to clear). Binary 0=no parity error, 1=parity error. - S\_ERR Signalled SERR# (write 1 to clear). Binary 0=SERR# not asserted, 1=SERR# asserted. - **R\_MA** Received master abort generated by master (write 1 to clear). Binary 0=no, 1=yes. - **R\_TA** Received target abort and master detected it (write 1 to clear). Binary 0=no, 1=yes. - **S\_TA** Signalled target abort, target terminated transaction (write 1 to clear). Binary 0=no, 1=yes. - **DEVSEL** Device select timing (read only). Binary 01=medium speed device. - DP\_D Data parity detected, master detected/generated data parity error. Binary 0=no, 1=yes. - TFBBC Target fast back-to-back capable (read only). The Universe can not accept back-to-back cycles from a different agent. - **MF-BBC** Master fast back-to-back enable (read only). The Universe never generates fast back-to-back transactions. - SERR\_EN SERR# driver enable, in conjunction with PERESP to report address parity errors with SERR#. Binary 0=disable, 1=enable. - WAIT Wait cycle control (read only). Binary 0=no address/data stepping. - PERESP Parity error response, allow assertion of PERR# to report data parity errors. Binary 0=disable, 1=enable. **VGAPS** VGA palette snoop (read only). Binary 0=disabled. **MWI\_EN** Memory write and invalidate enable (read only). Binary 0=disabled. **SC** Special cycles (read only). Binary 0=disabled. **BM** Master enable. Binary 0=disable, 1=enable. MS Target memory enable. Binary 0=disable, 1=enable. **IOS** Target I/O enable. Binary 0=disable, 1=enable. #### 6.2.4 Master Control Register The Universe Master Control Register, MAST\_CTL, at hex offset $400_{16}$ defines parameters to set up transactions between the VME and PCI interfaces. | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | | 18 | | 17 | 16 | |----|-------|------|----|------|----|----|------|------|----|-----|------|------|-------|------|----|------|------| | | MAX | RTRY | | | PW | ON | | V | RL | VRM | VREL | VOWN | VO | WN_A | ск | Rese | rved | | 15 | 14 | 1 | 13 | 12 | | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reser | ved | | PABS | | | Rese | rved | | | | | BUS_N | 10 | | | | Register Map 6-3. Universe Master Control, MAST\_CTL MAXRTRY Maximum number of retries before the PCI master signals an error condi- tion. Range=binary 0000 to 1111 (0000=retry forever). **PWON** Posted write transfer count. The PCI slave channel posted writes FIFO gives up the VME master interface according to this value. Binary 0000=128 bytes, 0001=256 bytes, 0010=512 bytes, 0011=1024 bytes, 0100=2048 bytes, 0101=4096 bytes, 1111=BBSY\* release after each transaction, and all other values are reserved. VRL VMEbus request level. Binary 00=level 1, 01=level 2, 11=level 3 (reset value). VRM VMEbus request mode. Binary 0=demand, 1=fair. VREL VMEbus release mode. Binary 0=release when done, 1=release upon request. **VOWN** VME ownership bit. (VMEbus masters should not set this bit.) Binary 0=release VMEbus, 1=acquire and hold VMEbus. **VOWN\_ACK** VME ownership bit acknowledge (synchronized to PCI clock). Binary 0=not owned, 1=acquired and held due to VOWN. (Read only.) PABS PCI aligned burst size. This determines the PCI address boundary where the Universe breaks up a PCI transaction. Binary 00=32 bytes, 01=64 bytes, 10=128 bytes, all others=reserved. BUS\_NO PCI bus number. If the bus number of the PCI address equals this value, the configuration cycle is Type 0. Otherwise, it is Type 1. #### **6.2.5** Miscellaneous Control Register The Universe Miscellaneous Control Register, MISC\_CTL, at hex offset $404_{16}$ defines VMEbus arbitration characteristics, software reset options, and other miscellaneous parameters. Reserved Register Map 6-4. Universe Miscellaneous Control, MISC CTL VBTO VMEbus timeout in microseconds. (SYSCON support) Binary 0000=disabled, 0001=16μs, 0010=32μs, 0011=64μs (default), $0100 {=} 128 \mu s,\, 0101 {=} 256 \mu s,\, 0110 {=} 512 \mu s,\, 0111 {=} 1024 \mu s,\,$ all others=reserved. **VARB** VMEbus arbitration mode. (SYSCON support) Binary 0=round robin, 1=priority. **VARBTO** VMEbus arbitration timeout in microseconds. (SYSCON support) Binary 00=disabled, 016µs, 10=256µs, all others=reserved. **SW\_LRST** Software PCI reset characteristic. PCI masters should not write to this bit. Binary 0=no effect, 1=initiate LRST#. (Read always returns 0.) SW\_SRST Software VMEbus SYSRESET characteristic. VMEbus masters should not write to this bit. Binary 0=no effect, 1=initiate SYSRST\*. (Read always returns 0.) BI Mode. (Also, this bit is affected by VIRQ1\*, if enabled.) Binary 0=disabled, 1=enabled. **ENGBI** Enable global BI-mode initiator. Binary 0=VIRQ1 assertion ignored, 1=VIRQ1 assertion activates BI mode. **RESCIND** Rescinding DTACK Enable. This field is no longer used. The Universe always rescinds DTACK. **SYSCON** Allow Universe to function as VMEbus system controller. Binary 0=disabled, 1=enabled. **V64**AUTO Initiate VME64 Auto ID slave participation by Universe. Binary 0=no effect, 1=initiate sequence. # 6.2.6 VMEbus Master Image Registers The Universe allows up to eight VMEbus master (PCI slave) images. Each image has a control register, base address register, bound address register, and a translation offset register. All these registers have 64-kilobytes of resolution, except for the LSIO and LSI4 register sets, which have a 4-kilobyte resolution. Since the bit assignments are similar for all eight VMEbus master (PCI slave) images, only image 0 will be discussed here. Refer to the *Universe User's Manual* for additional details. The PCI Slave Image 0 Base Address Register, LSI0\_BS, at hex offset $104_{16}$ defines the lowest address in the range to be decoded. Bits BS[31:12] hold the base address, and bits [11:0] are reserved. The PCI Slave Image 0 Bound Address Register, LSI0\_BD, at hex offset $108_{16}$ defines the window size for the slave image. Bits BD[31:12] hold the bound address, and bits [11:0] are reserved. NOTE. Since the MPC106 memory controller currently issues a retry upon detecting a memory select error, the maximum slave window size should be limited to the size of the desired memory-mapped region. The slave window can make any portion of the BajaPPC-750 memory map available on the VMEbus. The PCI Slave Image 0 Control Register, LSI0\_CTL, at hex offset $100_{16}$ defines the general VMEbus and PCI bus controls. 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 **PWEN** ΕN Reserved **VDW** Reserved VAS 15 13 9 8 7 6 3 0 14 12 11 10 5 2 1 **PGM** SUPER Reserved VCT Reserved LAS Register Map 6-5. Universe PCI Slave Image 0 Control, LSIO\_CTL EN Enable the image. (power-up option, disable when configuring). Binary 0=disabled, 1=enabled. **PWEN** Posted write enable. Binary 0=disabled, 1=enabled. VDW Maximum data width for VMEbus. Binary 00=8 bits, 01=16 bits, 10=32 bits, 11=64 bits. VAS VMEbus address space. (power-up option) Binary 000=A16, 001=A24, 010=A32, 011=reserved, 100=reserved, 101=CR/CSR, 110=user1, 111=user2. **PGM** Program/data AM code. Binary 00=data, 01=program, all others=reserved. **SUPER** Supervisor/user AM code. Binary 00=non-privileged, 01=supervisor, all others=reserved. VCT VMEbus cycle type. Binary 0= single cycles only, 1=single cycles and block transfers. LAS PCI bus memory space. (power-up option) Binary 0=memory space, 1=I/O space. #### 6.2.7 VMEbus Slave Image Registers The Universe also allows up to eight VMEbus slave images. Each image has a control register, base address register, bound address register, and a translation offset register. All these registers have 64-kilobytes of resolution, except for the VSIO and VSI4 register sets, which have a 4-kilobyte resolution. Since the bit assignments are similar for all eight VMEbus slave images, only image 0 will be discussed here. Refer to the *Universe User's Manual* for additional details. The VMEbus Slave Image 0 Base Address Register, VSIO\_BS, at hex offset F04<sub>16</sub> defines the lowest address in the range to be decoded. Bits BS[31:12] hold the base address, and bits [11:0] are reserved. The VMEbus Slave Image 0 Bound Address Register, VSI0\_BD, at hex offset F08<sub>16</sub> defines the window size for the slave image. Bits BD[31:12] hold the bound address, and bits [11:0] are reserved. NOTE. Since the MPC106 memory controller currently issues a retry upon detecting a memory select error, the maximum slave window size should be limited to the size of the desired memory-mapped region. The slave window can make any portion of the BajaPPC-750 memory map available on the VMEbus. The VMEbus Slave Image 0 Control Register, VSI0\_CTL, at hex offset $F00_{16}$ defines general VMEbus and PCI bus controls for this image. The PCI master interface must be enabled before a VMEbus slave image can respond to an incoming cycle (see BM bit description and Register Map 6-2). | 31 | 30 | 29 | 28 | 3 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 1 | 9 | 18 | 17 | 16 | |----|------|------|--------|------|---------|-----|----|--------|-------|----|------|--------|-------|----|-----|----| | EN | PWEN | PREN | | | Reserve | d | | PGN | Л | S | UPER | Rese | erved | | VAS | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 8 | } | 7 | 6 | | 5 | 4 | 3 | 2 | 1 | 0 | | | | | Reserv | ed | | | ı | LD64EN | LLRM\ | w | | Reserv | ved | | LA | ıs | Register Map 6-6. Universe VME Slave Image 0 Control, VSIO\_CTL EN Enable the image. (Disable when configuring). Binary 0=disabled, 1=enabled. **PWEN** Posted write enable. Binary 0=disabled, 1=enabled. **PREN** Pre-fetch read enable. Binary 0=disabled, 1=enabled. **PGM** Program/data AM code. Binary 00=reserved, 01=data, 10=program, 11=both. VMEbus Master Interface 6-15 **SUPER** Supervisor/user AM code. Binary 00=reserved, 01=non-privileged, 10=supervisor, 11=both. VAS VMEbus address space. Binary 000=A16, 001=A24, 010=A32, 011=reserved, 100=reserved, 101=CR/CSR, 110=user1, 111=user2. **LD64EN** Enable 64-bit PCI transactions. Binary 0=disabled, 1=enabled. LLRMW Allow VMEbus to lock PCI bus during RMW. For improved performance, disable this feature until it is needed. Binary 0=disabled, 1=enabled. LAS PCI bus memory space. (power-up option) Binary 00=memory space, 01=I/O space, 10=PCI configuration space, 11=reserved. #### **6.3** VMEbus Master Interface The architecture of the Universe can be described in terms of three channels: the PCI bus channel, the DMA channel, and the interrupt channel. The Universe functions as the VMEbus master interface upon the request of any of these channels, with the interrupt channel having the highest priority. The VMEbus master supports Read-Modify-Write (RMW) and Address-Only-with-Handshake (ADOH). A PCI master can lock VME resources via the VMEbus Lock command in the ADOH cycle. The Universe does not support RETRY\* as a termination from the VMEbus slave. The VOWN bit in the Universe's MAST\_CLT register sets VMEbus ownership (see Register Map 6-3). The CWT bits in the Universe's LMISC register at hex offset 184<sub>16</sub> affect the performance of the PCI bus and, indirectly, the VMEbus. | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |----|----|----------|----|----|----|-------------|----| | | | Reserved | | | C | CWT (unused | d) | Register Map 6-7. Universe PCI Miscellaneous, LMISC CWT Coupled window timer in PCI clocks. This field no longer controls the Universe coupled window timer. Instead, the Universe waits for $2^{15}$ PCI clocks before giving up the VMEbus. This timer restarts each time a PCI master tries a coupled request. Changing the CWT values during a coupled cycled will produce unpredictable results. The CWT value of 2<sup>15</sup> PCI clock cycles determines how long to hold the VMEbus after a coupled transaction (across the VMEbus) is made. #### 6.3.1 Addressing The Universe can generate A16, A24, A32, and CR/CSR address phases on the VMEbus in accordance with the VME64 specification (see control registers in Section 6.2). Programming of the VME master (PCI slave) image determines the address space, mode, and type. The Universe supports address pipelining, except during MBLT cycles. In addition, the USER\_AM register allows for programming of two user-defined address modifier codes (default=same as VME64 user-defined AM code). The VMEbus decoding is such that the address must be in the window defined by the base and bound addresses. The address modifier has to match one of those specified by the address space, mode, and type fields. The eight VME slave images are bounded by A32 space. VME slave images 0 and 4 have a resolution of 4 kilobytes. The other six VME slave images have a resolution of 64 kilobytes. NOTE. The address space of a VMEbus slave image must not overlap the Universe control and status registers. Also, slave image spaces must not overlap each other, and master image spaces must not overlap each other. By default, the BajaPPC-750 NVRAM configuration parameters (see Chapter 10) map one VMEbus master and two VMEbus slave images as indicated in the table below: | Table 6-3. VMEbus Default Memory Ma | apping | |-------------------------------------|--------| |-------------------------------------|--------| | Type Master Address Range (Hex | | Slave Base Address (Hex) | |--------------------------------|-----------------------|--------------------------| | Extended | C000,0000 – FCFF,FFFF | 80000000 | | Standard | BF00,0000 – BFFF,FFFF | 200000 | | Short | FEBF,0000 – FEBF,FFFF | 1000 | The user can reconfigure this mapping to include up to four VMEbus master and four VMEbus slave images. The mapping must be enabled via the **nvdisplay** and **nvupdate** monitor commands. Short VMEbus master space should be placed in upper PCI I/O space. VMEbus Slave Interface 6-17 #### 6.3.2 Data Transfers The Universe has a software-configurable, high-performance, internal DMA controller to facilitate data transfers between the PCI bus and VMEbus. It uses a single bidirectional FIFO to decouple DMA operations between the busses. The DMA controller supports a linked-list mode, where it can perform multiple block transfers by following pointers in the list. Please refer to Section 2.8 in the *Universe User's Manual* for a thorough explanation of the DMA controller. Generally, if the width of the PCI bus data is less than that of the VMEbus, no packing or unpacking occurs between the two busses. However, for 32-bit PCI multi-data beat transactions to a PCI slave image with a 64-bit VMEbus data width, packing or unpacking does occur to maximize the full bandwidth on both busses. The Universe only generates aligned VMEbus transactions; so if the PCI data beat has non-contiguous byte enables, it is divided into multiple aligned VMEbus transactions. The initiating PCI image or PWON field of the MAST\_CTL register (see Register Map 6-3) determines the length of BLT/MBLT cycles. The Universe will attempt block DMA transfers of up to 256 bytes for BLT and 2 kilobytes for MBLT as limited by the VMEbus specification (and VON counter). CAUTION. Do not perform any byte-, word-, or longword-wide reads/ writes on the VMEbus while a DMA transaction is pending on a BajaPPC-750 that utilizes revision Z1 of the Universe chip. If another VME master attempts a single-beat slave transaction (byte-, word-, or longword-wide read/write) under this condition, the slave transaction following the single-beat slave transaction will occur at a corrupted address. For the latest information regarding Universe errata, please visit the Tundra web site (see Section 1.4.3). #### 6.4 VMEbus Slave Interface When one of the eight programmed slave or register images is accessed by a VME-bus master, the Universe becomes a slave. It handles incoming write transactions from the VMEbus as either coupled-writes or posted-writes, as determined by the VMEbus slave image. (Refer to control registers in Section 6.2.) For posted-writes, a FIFO receives the data an acknowledgment is sent to the VMEbus master. For coupled-writes, the VMEbus master receives and acknowledgment only when the transaction is complete on the PCI bus. Similarly, read transactions may be either pre-fetched or coupled. Although posted transactions do enhance performance, keep in mind that: - VMEbus errors will be reported via interrupt to the PCI master, rather than a target-abort. If the BajaPPC-750 processor is a PCI master (via the MPC106), VMEbus errors translate to an external interrupt (vector 500<sub>16</sub>) instead of the MCP/TEA. - Posted mode has less determinism than coupled mode. For example, a VME-bus error may not be reported as quickly in posted mode because the Universe must re-acquire the PCI channels to report the error. However, the PCI interrupt channel does have priority over the DMA and slave channels. #### 6.4.1 Slave Mapping Example The following code example maps an A32/D32 image to extended space. To compute the bound address (LSIx\_BD) for the PCI slave window, simply add the memory size to the base address (LSIx\_BS). The VME slave window bound address (VSIx\_BD) may be determined in the same manner. (See control registers in Section 6.2.) ``` void universe init() volatile UNIVERSE PORT *universeIO = (UNIVERSE PORT *)UNIVERSE MPC IO BASE; int noError = 0; /*map the Universe - via PCI configuration cycle - to PCI memory space at address UNIVERSE PCI MEM BASE */ /*The CHRP MAP definition has no bearing on the Universe chip - it simply tells the function where configuration space resides*/ noError = pci dev config write((int)IDSEL UNIVERSE, (int) UNIVERSE VENDOR ID, (int) UNIVERSE PCI BS, (int) (UNIVERSE PCI MEM BASE), CHRP MAP); if (noError < 0) { exit(); /*enable the MEM space map, clear any previously asserted status bits*/ noError = pci_dev_config_write((int)IDSEL_UNIVERSE, (int) UNIVERSE VENDOR ID, (int)UNIVERSE PCI CSR, (int)(UNIV_PCI_CSR_D_PE UNIV_PCI_CSR_S_ERR UNIV_PCI_CSR_R_MA UNIV_PCI_CSR_R_TA UNIV_PCI_CSR_S_TA UNIV PCI CSR BM UNIV PCI CSR MS), (int) CHRP MAP); ``` VMEbus Slave Interface 6-19 ``` if (noError < 0){ exit(); /*At this point the Universe should be mapped to its base address in PCI MEM space - i.e. it's now available as a normal memory-mapped PCI device*/ /*Let's first clean up the SYSFAIL line - it's asserted after power up until otherwise noted*/ universeIO->VCSR CLR |= ES((int)UNIV VCSR SYSFAIL); /*Configure the Universe VME arbitration parameters*/ universeIO->MAST CTL = ES((int)(UNIV MAST CTL MAXRTRY FOREVER UNIV_MAST_CTL_PWON_128B UNIV_MAST_CTL_VRL_L3 UNIV MAST CTL VRM DEMAND UNIV_MAST_CTL_VREL_ROR UNIV MAST CTL PABS 32B)); /*We are going to define one massive window which consists purely of A32/D32 space: this is our PPC->PCI->VME path*/ /*First assure that the window is disabled before we make any modifications to its setup. Otherwise erratic behavior could result*/ universeIO->LSIO CTL &= ES((int)(~UNIV LSIX CTL EN)); /*LSI0 BS contains the base address of our window, as seen by the processor*/ universeIO->LSIO_BS = ES((int)CHRP_PCI_MEM_SPACE_START); /*LSIO BD contains the end of our window as seen by the processor*/ universeIO->LSIO BD = ES((int)CHRP PCI MEM SPACE END VME); /*LSIO_TO contains the "translation offset" which is effectively added to the working window address, if necessary*/ universeIO->LSIO_TO = ES((int)CHRP_PCI_VME_LSIO_TO); /*now setup the attributes of this window using LSIO CTL*/ universeIO->LSIO CTL = ES((int)(UNIV LSIX CTL VAS A32 UNIV_LSIX_CTL_PGM_DATA UNIV LSIX CTL SUPER UNIV_LSIX_CTL_VDW_64 UNIV_LSIX_CTL_LAS_MEM)); /*Enable the window*/ universeIO->LSIO_CTL |= ES((int)(UNIV_LSIX_CTL_EN)); /*Map the VME->PCI window - a32, into PCI mem space - note that this is a big uniform window. For now, no other modes are enabled (a24 etc)*/ /*VSIO_BS = base address of the window as seen on the VME bus*/ universeIO->VSIO BS = ES((int)VME SLAVE ADDR START & 0xFFFFF000); /*VSIO BD = end of the VME window. BD-BS = size*/ universeIO->VSIO BD = ES((int)VME SLAVE ADDR END & 0xfffff000); ``` # 6.5 VMEbus Interrupts The Universe interrupt channel allows interrupts to be mapped either to the PCI bus or VMEbus interface. The VMEbus interrupts are generated on pins VIRQ#[7-1]. The following table identifies various interrupt sources and related Universe registers. Table 6-4. Universe VMEbus Interrupt Sources | Interrupt Source | Bit | Enabled in | Mapped in | Status in | |-------------------------|---------|------------------|-----------------|--------------------| | VME software interrupt | SW_INT | | | | | VMEbus error | VERR | | VINT_MAP0 | | | PCI bus error | LERR | VINT_EN register | or<br>VINT_MAP1 | VINT_STAT register | | DMA event | DMA | . regiote. | registers | . eg.ete. | | PCI bus interrupt input | LINT7-0 | | | | The Universe also allows for each of the seven interrupt request levels to be generated simply by writing to the appropriate field in the VME Interrupt Enable Register, VINT\_EN, at hex offset $310_{16}$ . Register Map 6-8. Universe VME Interrupt Enable, VINT\_EN VMEbus Interrupts 6-21 VME\_SW7 - VME software interrupt mask. VME\_SW1 Binary 0=masked, 1=enabled, transition from zero to one generates inter- rupt at the corresponding level. MBOX3 - MBOX0 Mailbox interrupt mask. Binary 0=masked, 1=enabled. VME SW INT VME software interrupt mask. Binary 0=masked, 1=enabled. Transition from zero to one asserts the interrupt (power-up option). VME\_VERR VMEbus error interrupt mask. Binary 0=masked, 1=enabled. **VME\_LERR** PCI bus error interrupt mask. Binary 0=masked, 1=enabled. VME\_DMA VME DMA interrupt mask. Binary 0=masked, 1=enabled. LINT7 - LINT0 LINTx interrupt mask. Binary 0=masked, 1=enabled. For the BajaPPC-750 application, the Universe is configured to send VME interrupts as LINT outputs to the interrupt controller programmable logic device (PLD), which interrupts the CPU via the 750\_INT\* line (see Section 3.4). #### 6.5.1 Interrupter The Universe interrupter provides an 8-bit status/ID to the interrupt handler. The upper seven bits are programmed from the STATID register. The lowest bit is cleared for software interrupts and set for all other interrupt sources. Software interrupts are given the highest priority. #### 6.5.2 Interrupt Handler In the event of a normal VMEbus interrupt, the Universe interrupt handler generates an acknowledge (IACK) cycle and output. Upon completion of the cycle, it releases the VMEbus, allowing the PCI resource to read the interrupt vector and service the output. Software interrupts are release-on-acknowledge (ROAK). Hardware and internal interrupts are release-on-register-access (RORA). ## 6.6 VMEbus System Controller When the BajaPPC-750 circuit board is located in slot 1 of the VME system, the Universe acts as VMEbus system controller. In this capacity, the Universe provides a system clock driver, an arbitration module, an IACK Daisy Chain Driver (DCD), and a bus timer. To determine if the BajaPPC-750 is in slot 1, the Universe samples BG3IN\* immediately after reset. If lines BG[3:0]\* are sampled at logic low, then the Universe becomes the VMEbus system controller. Otherwise, the SYSCON module is disabled. Software can override the automatic first slot detector by manipulating the SYSCON bit in the Universe's MISC\_CTL register (see Register Map 6-4). #### 6.7 SYSFAIL Control The Universe asserts SYSFAIL\* after power-up or reset. It remains asserted until explicitly cleared, typically after self-tests and diagnostics are completed. To deassert the signal, write a one to the SYSFAIL bit at $1E_{16}$ of the VCSR\_CLR register at offset FF4<sub>16</sub>. Refer to the Universe specification for further information. At power-up all boards in the system assert SYSFAIL\* until their diagnostics are complete. Once all boards are initialized, SYSFAIL\* should not be asserted by any board, except to indicate a failure. (SYSFAIL\* may be polled.) #### 6.8 Bus Timer The Universe has a programmable bus timer accessible through the VBTO field of the MISC\_CTL register (see Register Map 6-4). The default time-out period for the VMEbus is 64 $\mu$ s. The bus timer asserts VXBERR# when a VMEbus time-out occurs. #### 6.9 Mailboxes The Universe supports four 32-bit mailbox registers which can generate interrupts on either the VMEbus or PCI bus. The mailbox registers are in the existing register space beginning at hex offset $348_{16}$ . Bits [19:16] of the Local Interrupt Enable Register, LINT\_EN, at hex offset $300_{16}$ allow each mailbox interrupt to be enabled or masked by writing either a 1 or 0, respectively, to the corresponding MBOX field. Mailboxes 6-23 Two interrupt mapping registers, LINT\_MAP2 at offset $340_{16}$ and VINT\_MAP2 at offset $344_{16}$ , define the mailbox interrupt destinations. For example, writing a value of $000_2$ to LINT\_MAP2, bits [2:0], maps the corresponding interrupt source for mailbox 0 to LINT[0]; writing a value of $001_2$ to the same location maps the source to LINT[1]; writing $010_2$ maps to LINT[2], and so on. Similarly, writing a value of $001_2$ to VINT\_MAP2, bits [2:0], maps the corresponding interrupt source for mailbox 0 to VIRQ1; writing a value of $010_2$ to the same location maps the source to VIRQ2; writing $011_2$ maps to VIRQ3, and so on. Two status registers, LINT\_STAT at offset $304_{16}$ and VINT\_STAT at offset $314_{16}$ , may be read to determine if a specific mailbox interrupt is active (1=active, 0=inactive). Writing a one clears the status bit. Two access registers, VRAI\_BS at offset F74<sub>16</sub> and VRAI\_CTL at offset F80<sub>16</sub>, make the mailboxes available on the VMEbus. The VMEbus Register Access Image Base Address Register, VRAI\_BS, specifies the base address in bits BS[31:12]. The VMEbus Register Access Image Control Register, VRAI\_CTL, is described as follows: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----|----------|----|----|----------|----|----|----|----|----|----|-----|------|-------|----|----| | EN | | | F | Reserved | d | | | PC | iΜ | SU | PER | Rese | erved | VA | AS | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | | | | | | | | | | | | | | Register Map 6-9. Universe VMEbus Register Access Image Control, VRAI\_CTL **EN** Enable the image. Binary 0=disabled, 1=enabled. **PGM** Program/data AM code. Binary 00=reserved, 01=data, 10=program, 11=both. **SUPER** Supervisor/user AM code. Binary 00=reserved, 01=non-privileged, 10=supervisor, 11=both. VAS VMEbus address space. Binary 000=A16, 001=A24, 010=A32, all others=reserved. #### 6.10 Location Monitor The Universe location monitor provides a mechanism for broadcasting events across the VME backplane. It is enabled and defined by the Location Monitor Control Register, LM\_CTL, at hex offset F64<sub>16</sub>. The base address is set by the Location Monitor Base Address Register, LM\_BS, in bits BS[31:12] at hex offset F68<sub>16</sub>. Bits [23:20] of the Local Interrupt Enable Register, LINT\_EN, at hex offset 300<sub>16</sub> allow each location monitor interrupt to be enabled or masked by writing either a 1 or 0, respectively, to the corresponding LM field. | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |----|----------|----|----|----------|----|----|----|----|----|----|-----|----|----|-----|----| | EN | | | ſ | Reserved | d | | | PC | iΜ | SU | PER | | | VAS | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Reserved | | | | | | | | | | | | | | | Register Map 6-10. Universe Location Monitor Control, LM\_CTL **EN** Enable the image. Binary 0=disabled, 1=enabled. **PGM** Program/data AM code. Binary 00=reserved, 01=data, 10=program, 11=both. **SUPER** Supervisor/user AM code. Binary 00=reserved, 01=non-privileged, 10=supervisor, 11=both. **VAS** VMEbus address space. Binary 000=A16, 001=A24, 010=A32, 011=reserved, 100=reserved, 101=reserved, 110=user1, 111=user2. The location monitor generates one of four internal interrupts on the PCI bus. The interrupt level may be read on the VMEbus as follows: Table 6-5. Location Monitor Interrupt Mapping | Binary value in VMEbus address lines AD[4:3] | Defining field in LINT_MAP2 register | |----------------------------------------------|--------------------------------------| | 00 | LM0 | | 01 | LM1 | | 10 | LM2 | | 11 | LM3 | Semaphores 6-25 The interrupt mapping register, LINT\_MAP2 at offset $340_{16}$ defines the location monitor interrupt destinations. For example, writing a value of $000_2$ to LINT\_MAP2, bits [18:16], maps the corresponding interrupt source for LM0 to LINT[0]; writing a value of $001_2$ to the same location maps the source to LINT[1]; writing $010_2$ maps to LINT[2], and so on. The status register, LINT\_STAT at offset $304_{16}$ , may be read to determine if a specific location monitor interrupt is active (1=active, 0=inactive). Writing a one clears the status bit. **NOTE.** The Universe chip does not terminate the cycle with DTACK\* unless initiated by another Universe. # 6.11 Semaphores The Universe provides facilities for up to eight semaphores, which allow improved access to system resources. The semaphores each consist of a status bit and seven tag bits. Two semaphore registers, SEMA0 at hex offset $358_{16}$ and SEMA1 at hex offset $35C_{16}$ , each contain status and tag bits for four semaphores. The status bits power-up with a logic 0. A process can write a one to the status bit and a unique pattern to the tag field of a specific semaphore. During subsequent byte-wide reads by the process, it will be granted ownership of the resource if the pattern matches the semaphore tag field. The owning process then can write a zero to the status bit to release the resource. ### 6.12 VMEbus Control Signals VMEbus pins are defined on P1 and P2. Refer to the ANSI/VITA 1-1994 VME64 Standard for detailed usage of these signals. All signals are bidirectional unless otherwise stated. Refer to *Universe User Manual* for a complete listing of the pins. The following signals on connectors P1 and P2 are used for the VMEbus interface. | A01-A15 | ADDRESS bus (bits 1-15). Three-state address lines that are used for short, | |---------|-----------------------------------------------------------------------------| | | standard, and extended addresses, and D64 block transfers. | - A16-A23 ADDRESS bus (bits 16-23). Three-state address lines that are used for standard and extended addresses, and D64 block transfers. - A24-A31 ADDRESS bus (bits 24-31). Three-state address lines that are used for extended addresses and D64 block transfers. - ACFAIL\* AC FAILURE. An open-collector signal which is an input to the BajaPPC-750 and may be used to generate an interrupt to the CPU by programming the Universe accordingly. AM0-AM5 ADDRESS MODIFIER (bits 0-5). Three-state lines that are used to broadcast information such as address size and cycle type. AS\* ADDRESS STROBE. A three-state signal that indicates when a valid address has been placed on the address bus. BBSY\* BUS BUSY. An open-collector signal driven low by the current master to indicate that it is using the bus. When the master releases this line, the resultant rising edge causes the arbiter to sample the bus request lines and grant the bus to the highest priority requester. Early release mode is supported. BCLR\* BUS CLEAR. A totem-pole signal generated by the arbiter to indicate when there is a higher priority request for the bus. This signal requests the current master to release the bus. BERR\* BUS ERROR. An open-collector signal generated by a slave or bus timer. This signal indicates to the master that the data transfer was not completed in the time alloted (64 or 128µs). **BG0IN\*-BG3IN\*** BUS GRANT (0-3) IN. Totem-pole signals generated by the arbiter and requesters. Bus-grant-in and bus-grant-out signals form bus grant daisy chains. An input to the BajaPPC-750, the bus-grant-in signal indicates that it may use the bus if it wants. > BUS GRANT (0-3) OUT. Totem-pole signals generated by requesters. An output from the BajaPPC-750 (driven by boards not requesting the bus, in response to the bus-grant-in signals), the bus-grant-out signal indicates to the next board in the daisy-chain that it may use the bus. BR0\*-BR3\* BUS REQUEST (0-3). Open-collector signals generated by requesters. Assertion of one of these lines indicates that some master needs to use the bus. DATA BUS. Three-state bidirectional data lines used to transfer data D00-D31 between masters and slaves. DS0\*, DS1\* DATA STROBE ZERO, ONE. A three-state signal used in conjunction with LWORD\* and A01 to indicate how many data bytes are being transferred (1, 2, 3, or 4). During a write cycle, the falling edge of the first data strobe indicates that valid data are available on the data bus. DTACK\* DATA TRANSFER ACKNOWLEDGE. Either an open-collector or a threestate signal generated by a slave. The falling edge of this signal indicates that valid data are available on the data bus during a read cycle, or that data have been accepted from the data bus during a write cycle. The rising edge indicates when the slave has released the data bus at the end of a read cycle. **BGOOUT\*-BG3OUT\*** IACK\* INTERRUPT ACKNOWLEDGE. An open-collector or three-state signal used by an interrupt handler acknowledging an interrupt request. It is routed, via a backplane signal trace, to the IACKIN\* pin of slot one, where it forms the beginning of the IACKIN\*-IACKOUT\* daisy-chain. IACKIN\* INTERRUPT ACKNOWLEDGE IN. A totem-pole signal and an input to the BajaPPC-750. The IACKIN\* indicates that the board may respond to the interrupt acknowledge cycle that is in progress. Address lines A3–A1 carry the associated interrupt request level. IACKOUT\* INTERRUPT ACKNOWLEDGE OUT. A totem-pole signal and an output from the BajaPPC-750. The IACKIN\* and IACKOUT\* signals form a daisy-chain. The IACKOUT\* signal indicates to the next board in the daisy-chain that it may respond to the interrupt acknowledge cycle in progress. IRQ1\*-IRQ7\* INTERRUPT REQUEST (1-7). Open-collector signals, generated by an interrupter, which carry interrupt requests. When several lines are monitored by a single interrupt handler, the line with the highest number is given the highest priority. **LWORD\*** LONG WORD. A three-state signal used in conjunction with DS0\*, DS1\*, and A01 to select which byte location(s) within the 4-byte group are accessed during the data transfer. It is also used for D64 transfers. **RETRY\*** RETRY. A line driven by a Slave to indicate to the Master that the cycle cannot be completed and the Master should try again later. This signal is not implemented on the BajaPPC-750. SERCLK SERIAL CLOCK. A totem-pole signal that is used to synchronize the data transmission on the VMEbus. This signal is not implemented on the BajaPPC-750. SERDAT\* SERIAL DATA. An open-collector signal that is used for VMEbus data transmission. This signal is not implemented on the BajaPPC-750. SYSCLK SYSTEM CLOCK. A totem-pole signal that provides a constant 16-MHz clock signal that is independent of any other bus timing. This signal is driven if the BajaPPC-750 is a system controller. SYSFAIL\* SYSTEM FAIL. An open-collector signal that indicates a failure has occurred in the system. It is also used at power-up to indicate that at least one VMEbus board is still in its power-up initialization phase. This signal may be generated by any board on the VMEbus. The Universe drives this signal low at power-up. On the BajaPPC-750, SYSFAIL\* may be driven by the board, and it is possible to read the state of the VMEbus SYSFAIL\* signal. **SYSRESET\*** SYSTEM RESET. An open-collector signal that, when asserted, causes the system to be reset. WRITE\* WRITE. A three-state signal generated by the master to indicate whether the data transfer cycle is a read or a write. A high level indicates a read operation; a low level indicates a write operation. +5V STDBY +5 Vdc STANDBY. This line can act as a backup power source for the real-time clock. # **6.13 VMEbus Connector Pin Assignments** The main VMEbus connectors are P0, P1, and P2. Connector P0 is an optional six-row, 114-pin VME connector. In the standard configuration, connectors P1 and P2 are five-row, 160-pin DIN connectors. P2 has an optional configuration that provides Motorola compatability. In the optional P2 configuration, connectors P1 and P2 are three-row, 96-pin DIN connectors. The tables on the following pages show the pin assignments. NOTE. The P0 connector is optional and requires a mating J0 connector on the backplane. PMC connector J14 connects directly to P2. PMC connector J24 connects directly to P0. Figure 6-1. VMEbus Connectors (P0, P1, P2) Table 6-6. P0 Connector Pin Assignments | Pin | Row F | Row E | Row D | Row C | Row B | Row A | |-----|-------|---------------|---------------|---------------|---------------|---------------| | 1 | GND | Reserved | Reserved | Reserved | Reserved | Reserved | | 2 | GND | Reserved | Reserved | Reserved | Reserved | Reserved | | 3 | GND | +5V | +5V | +3.3V | +3.3V | +3.3V | | 4 | GND | PMC J24-1 | PMC J24-2 | PMC J24-3 | PMC J24-4 | PMC J24-5 | | 5 | GND | PMC J24-6 | PMC J24-7 | PMC J24-8 | PMC J24-9 | PMC J24-10 | | 6 | GND | PMC J24-11 | PMC J24-12 | PMC J24-13 | PMC J24-14 | PMC J24-15 | | 7 | GND | PMC J24-16 | PMC J24-17 | PMC J24-18 | PMC J24-19 | PMC J24-20 | | 8 | GND | PMC J24-21 | PMC J24-22 | PMC J24-23 | PMC J24-24 | PMC J24-25 | | 9 | GND | Reserved | Reserved | Reserved | Reserved | Reserved | | 10 | GND | Reserved | Reserved | Reserved | Reserved | No Connection | | 11 | GND | No Connection | No Connection | No Connection | No Connection | No Connection | | 12 | GND | PMC J24-26 | PMC J24-27 | PMC J24-28 | PMC J24-29 | PMC J24-30 | | 13 | GND | PMC J24-31 | PMC J24-32 | PMC J24-33 | PMC J24-34 | PMC J24-35 | | 14 | GND | PMC J24-36 | PMC J24-37 | PMC J24-38 | PMC J24-39 | PMC J24-40 | | 15 | GND | PMC J24-41 | PMC J24-42 | PMC J24-43 | PMC J24-44 | PMC J24-45 | | 16 | GND | PMC J24-46 | PMC J24-47 | PMC J24-48 | PMC J24-49 | PMC J24-50 | | 17 | GND | PMC J24-51 | PMC J24-52 | PMC J24-53 | PMC J24-54 | PMC J24-55 | | 18 | GND | PMC J24-56 | PMC J24-57 | PMC J24-58 | PMC J24-59 | PMC J24-60 | | 19 | GND | PMC J24-61 | PMC J24-62 | PMC J24-63 | PMC J24-64 | +5V | Table 6-7. P1 Connector Pin Assignments (Standard Configuration) | Pin | Row Z | Row A | Row B | Row C | Row D | |-----|---------------|----------|---------------|-----------|---------------| | 1 | No Connection | D00 | BBSY* | D08 | No Connection | | 2 | GND | D01 | BCLR* | D09 | GND | | 3 | No Connection | D02 | ACFAIL* | D10 | No Connection | | 4 | GND | D03 | BG0IN* | D11 | No Connection | | 5 | No Connection | D04 | BG0OUT* | D12 | No Connection | | 6 | GND | D05 | BG1IN* | D13 | No Connection | | 7 | No Connection | D06 | BG1OUT* | D14 | No Connection | | 8 | GND | D07 | BG2IN* | D15 | No Connection | | 9 | No Connection | GND | BG2OUT* | GND | GAP* | | 10 | GND | SYSCLK | BG3IN* | SYSFAIL* | GA0* | | 11 | No Connection | GND | BG3OUT* | BERR* | GA1* | | 12 | GND | DS1* | BRO* | SYSRESET* | +3.3V to PMC | | 13 | No Connection | DS0* | BR1* | LWORD* | GA2* | | 14 | GND | WRITE* | BR2* | AM5 | +3.3V to PMC | | 15 | No Connection | GND | BR3* | A23 | GA3* | | 16 | GND | DTACK* | AM0* | A22 | +3.3V to PMC | | 17 | No Connection | GND | AM1* | A21 | GA4* | | 18 | GND | AS* | AM2* | A20 | +3.3V to PMC | | 19 | No Connection | GND | AM3* | A19 | No Connection | | 20 | GND | IACK* | GND | A18 | +3.3V to PMC | | 21 | No Connection | IACKIN* | No Connection | A17 | No Connection | | 22 | GND | IACKOUT* | No Connection | A16 | +3.3V to PMC | | 23 | No Connection | AM4 | GND | A15 | No Connection | | 24 | GND | A07 | IRQ7* | A14 | +3.3V to PMC | | 25 | No Connection | A06 | IRQ6* | A13 | No Connection | | 26 | GND | A05 | IRQ5* | A12 | +3.3V to PMC | | 27 | No Connection | A04 | IRQ4* | A11 | No Connection | | 28 | GND | A03 | IRQ3* | A10 | +3.3V to PMC | | 29 | No Connection | A02 | IRQ2* | A9 | No Connection | | 30 | GND | A01 | IRQ1* | A8 | +3.3V to PMC | | 31 | No Connection | -12V | +5V STDBY | +12V | GND | | 32 | GND | +5V | +5V | +5V | No Connection | NOTE: The shaded table cells are No Connection when fuse F3 is present to select the onboard +3.3-volt regulator, which has a 1-Amp current limit. Rows Z and D are not present for the optional P2 configuration. Table 6-8. P1 Connector Pin Assignments (Optional Configuration) | Pin | Row A | Row B | Row C | |------------|-----------------------------|---------------------|-----------| | 1 | D00 | BBSY* | D08 | | 2 | D01 | BCLR* | D09 | | 3 | D02 | ACFAIL* | D10 | | 4 | D03 | BG0IN* | D11 | | 5 | D04 | BG0OUT* | D12 | | 6 | D05 | BG1IN* | D13 | | 7 | D06 | BG1OUT* | D14 | | 8 | D07 | BG2IN* | D15 | | 9 | GND | BG2OUT* | GND | | 10 | SYSCLK | BG3IN* | SYSFAIL* | | 11 | GND | BG3OUT* | BERR* | | 12 | DS1* | BRO* | SYSRESET* | | 13 | DS0* | BR1* | LWORD* | | 14 | WRITE* | BR2* | AM5 | | 15 | GND | BR3* | A23 | | 16 | DTACK* | AM0* | A22 | | 17 | GND | AM1* | A21 | | 18 | AS* | AM2* | A20 | | 19 | GND | AM3* | A19 | | 20 | IACK* | GND | A18 | | 21 | IACKIN* | No Connection | A17 | | 22 | IACKOUT* | No Connection | A16 | | 23 | AM4 | GND | A15 | | 24 | A07 | IRQ7* | A14 | | 25 | A06 | IRQ6* | A13 | | 26 | A05 | IRQ5* | A12 | | 27 | A04 | IRQ4* | A11 | | 28 | A03 | IRQ3* | A10 | | 29 | A02 | IRQ2* | A9 | | 30 | A01 | IRQ1* | A8 | | 31 | -12V | +5V STDBY | +12V | | 32 | +5V | +5V | +5V | | NOTE: Rows | Z and D are not present for | this configuration. | | Table 6-9. P2 Connector Pin Assignments (Standard Configuration) | Pin | Row Z | Row A | Row B | Row C | Row D | |-----|---------------|------------|--------|------------|---------------| | 1 | TXD-B | PMC J14-2 | +5V | PMC J14-1 | RTS-B | | 2 | GND | PMC J14-4 | GND | PMC J14-3 | CTS-B | | 3 | RXD-B | PMC J14-6 | RETRY* | PMC J14-5 | DSR-B | | 4 | GND | PMC J14-8 | A24 | PMC J14-7 | DTR-B | | 5 | DCD-B | PMC J14-10 | A25 | PMC J14-9 | No Connection | | 6 | GND | PMC J14-12 | A26 | PMC J14-11 | No Connection | | 7 | No Connection | PMC J14-14 | A27 | PMC J14-13 | No Connection | | 8 | GND | PMC J14-16 | A28 | PMC J14-15 | No Connection | | 9 | No Connection | PMC J14-18 | A29 | PMC J14-17 | No Connection | | 10 | GND | PMC J14-20 | A30 | PMC J14-19 | No Connection | | 11 | No Connection | PMC J14-22 | A31 | PMC J14-21 | No Connection | | 12 | GND | PMC J14-24 | GND | PMC J14-23 | No Connection | | 13 | ETH_PWR | PMC J14-26 | +5V | PMC J14-25 | No Connection | | 14 | GND | PMC J14-28 | D16 | PMC J14-27 | No Connection | | 15 | No Connection | PMC J14-30 | D17 | PMC J14-29 | No Connection | | 16 | GND | PMC J14-32 | D18 | PMC J14-31 | No Connection | | 17 | ETH_DI* | PMC J14-34 | D19 | PMC J14-33 | No Connection | | 18 | GND | PMC J14-36 | D20 | PMC J14-35 | No Connection | | 19 | No Connection | PMC J14-38 | D21 | PMC J14-37 | No Connection | | 20 | GND | PMC J14-40 | D22 | PMC J14-39 | No Connection | | 21 | No Connection | PMC J14-42 | D23 | PMC J14-41 | No Connection | | 22 | GND | PMC J14-44 | GND | PMC J14-43 | No Connection | | 23 | No Connection | PMC J14-46 | D24 | PMC J14-45 | No Connection | | 24 | GND | PMC J14-48 | D25 | PMC J14-47 | No Connection | | 25 | No Connection | PMC J14-50 | D26 | PMC J14-49 | No Connection | | 26 | GND | PMC J14-52 | D27 | PMC J14-51 | No Connection | | 27 | No Connection | PMC J14-54 | D28 | PMC J14-53 | No Connection | | 28 | GND | PMC J14-56 | D29 | PMC J14-55 | AUI_DO | | 29 | AUI_CI | PMC J14-58 | D30 | PMC J14-57 | AUI_DO* | | 30 | GND | PMC J14-60 | D31 | PMC J14-59 | AUI_DI | | 31 | AUI_CI* | PMC J14-62 | GND | PMC J14-61 | GND | | 32 | GND | PMC J14-64 | +5V | PMC J14-63 | No Connection | Table 6-10. P2 Connector Pin Assignments (Optional Configuration) | Pin | Row A | Row B | Row C | | |------------------------------------------------------------|------------|---------------|---------|--| | 1 | PMC J14-2 | +5V | AUI_CI* | | | 2 | PMC J14-4 | GND | AUI_CI | | | 3 | PMC J14-6 | No Connection | AUI_DO* | | | 4 | PMC J14-8 | A24 | AUI_DO | | | 5 | PMC J14-10 | A25 | AUI_DI* | | | 6 | PMC J14-12 | A26 | AUI_DI | | | 7 | PMC J14-14 | A27 | AUI_PWR | | | 8 | PMC J14-16 | A28 | P_STB* | | | 9 | PMC J14-18 | A29 | P_D0 | | | 10 | PMC J14-20 | A30 | P_D1 | | | 11 | PMC J14-22 | A31 | P_D2 | | | 12 | PMC J14-24 | GND | P_D3 | | | 13 | PMC J14-26 | +5V | P_D4 | | | 14 | PMC J14-28 | D16 | P_D5 | | | 15 | PMC J14-30 | D17 | P_D6 | | | 16 | PMC J14-32 | D18 | P_D7 | | | 17 | PMC J14-34 | D19 | P_ACK* | | | 18 | PMC J14-36 | D20 | P_BSY | | | 19 | PMC J14-38 | D21 | P_PE | | | 20 | PMC J14-40 | D22 | P_SEL | | | 21 | PMC J14-42 | D23 | P_INIT* | | | 22 | PMC J14-44 | GND | P_ERR | | | 23 | PMC J14-46 | D24 | TXD-A | | | 24 | PMC J14-48 | D25 | RXD-A | | | 25 | PMC J14-50 | D26 | RTS-A | | | 26 | PMC J14-52 | D27 | CTS-A | | | 27 | PMC J14-54 | D28 | TXD-B | | | 28 | PMC J14-56 | D29 | RXD-B | | | 29 | PMC J14-58 | D30 | RTS-B | | | 30 | PMC J14-60 | D31 | CTS-B | | | 31 | PMC J14-62 | GND | DTR-B | | | 32 | PMC J14-64 | +5V | DCD-B | | | NOTE: Rows Z and D are not present for this configuration. | | | | | ## **Ethernet Interface** The BajaPPC-750 provides a local area network (LAN) interface using the Intel (formerly DEC) 21143 PCI/CardBus 10/100-Mb/s Ethernet LAN Controller. The 21143 is a single-chip PCI bus master, supporting direct memory access (DMA) and full-duplex operation on either a 10Mb/s AUI port or 10/100Mb/s Fast Ethernet port with transceiver and clock recovery support from an ICS 1890 PHY device. The 21143 controller supports IEEE 802.3, ANSI 8802-3, and Ethernet standards. The 21143 is optimized for PCI-based systems. It includes a number of features which enhance its performance and versatility: - Large, independent receive and transmit FIFOs - Support for either media-independent interface (MII) for Fast Ethernet or serial interface for attachment unit interface (AUI) - On-chip DMA with programmable PCI burst size - Internal and external (PHY) loopback capability on MII or internal loopback on AUI - MicroWire interface for serial ROM ## **7.1 21143 Registers** The Intel 21143 Fast Ethernet controller has a number of configuration and command/status registers (CSRs). The CSRs are mapped in host I/O or memory address space. Please see the 21143 technical documentation (referred to in Section 1.4.3) for complete details on the individual register bit assignments. ## 7.1.1 Configuration The Intel 21143 allows for complete initialization and configuration from software. Write operations to reserved portions of the configuration registers complete normally, discarding any data. Read operations to these areas also complete normally, returning a value of zero. A hardware reset places the default values in the configuration registers, and a software reset (CSR0, bit 0) has no effect. The configuration registers accept byte-, word-, and longword-wide accesses. Table 7-1. 21143 Configuration Register Summary | Hex Offset | Mnemonic | Function | Hex Default | |------------|----------|-------------------------------------|-------------------------| | 00 | CFID | Identification Register | 00191011 | | 04 | CFCS | Command and Status Register | 02800000 | | 08 | CFRV | Revision Register | 02000041 | | 0C | CFLT | Latency Timer Register | 0 | | 10 | CBIO | Base I/O Address Register | undefined | | 14 | СВМА | Base Memory Address Register | undefined | | 18-24 | reserved | | | | 28 | CCIS | Card Information Structure Register | read from<br>serial ROM | | 2C | SSID | Subsystem ID Register | read from<br>serial ROM | | 30 | CBER | Expansion ROM Base Address Register | XXXX0000 | | 38 | reserved | | | | 3C | CFIT | Interrupt | 281401XX | | 40 | CFDD | Device and Driver Area Register | 8000XX00 | | 44 | CWUA0 | Configuration Wake-Up-LAN Address 0 | undefined | | 48 | CWUA0 | Configuration Wake-Up-LAN Address 1 | undefined | | 4C | SOP0 | SecureON Password (D,C,B,A) | undefined | | 50 | SOP1 | SecureON Password (F,E) | undefined | | 54 | CWUC | Configuration Wake-Up Command | undefined | | 58-D8 | reserved | | • | ## 7.1.2 Command/Status The Intel 21143 command/status registers (CSRs) are mapped in host I/O or memory space. The CSRs provide the host with pointers, commands, and status reports. These 32-bit registers are *quadword* aligned and require longword instructions. Also, the reserved bits should be written with zero to preserve compatibility with future releases. Reading the reserved bits will produce unpredictable results. Ethernet Address 7-3 Table 7-2. 21143 Command/Status Register Summary | Hex Offset | Mnemonic | Function | Hex Default | |------------|----------|------------------------------------------------------------------|-------------| | 00 | CSR0 | Bus Mode Register | FE000000 | | 08 | CSR1 | Transmit Poll Demand / Wake-Up Events Setup<br>Register | FFFFFFF | | 10 | CSR2 | Receive Poll Demand / Wake-Up Events Control and Status Register | FFFFFFF | | 18 | CSR3 | Receive List Base Address Register | variable | | 20 | CSR4 | Transmit List Base Address Register | variable | | 28 | CSR5 | Status Register | F0000000 | | 30 | CSR6 | Operation Mode Register | 32000040 | | 38 | CSR7 | Interrupt Enable Register | F3FE0000 | | 40 | CSR8 | Missed Frames and Overflow Counter Register | E0000000 | | 48 | CSR9 | Boot ROM, Serial ROM, and MII Management<br>Register | FFFE83FF | | 50 | CSR10 | Boot ROM Programming Address Register | variable | | 58 | CSR11 | General Purpose Timer Register | FFFE0000 | | 60 | CSR12 | SIA Status Register | 00000C6 | | 68 | CSR13 | SIA Connectivity Register | FFFF0000 | | 70 | CSR14 | SIA Transmit and Receive Register | FFFFFFF | | 78 | CSR15 | SIA and General-Purpose Port Register | 8FFX0000 | ## 7.2 Ethernet Address The Ethernet address for your board is a unique identifier on a network and must not be altered. The address consists of 48 bits divided into two equal parts. The upper 24 bits define a unique identifier that has been assigned to Artesyn Communication Products, Inc. by IEEE. The lower 24 bits are defined by Artesyn for identification of each of our products. The Ethernet address for the BajaPPC-750 is a binary number referenced as 12 hexadecimal digits separated into pairs, with each pair representing eight bits. The address assigned to the BajaPPC-750 has the following form: ## 00 80 F9 51 XX XX **00 80 F9** is Artesyn's identifier. **51** is the identifier for the BajaPPC-750 product group. The last two pairs of hex numbers correspond to the following formula: n-1000, where n is the unique serial number assigned to each board. For example, if the serial number of a BajaPPC-750 is 2867, the calculated value is 1867 (74B<sub>16</sub>). Therefore, the board's Ethernet address is 00:80:F9:51:07:4B. The complete Ethernet address is stored at byte offset $20_{16}$ in serial ROM. #### 7.3 Default Ethernet Boot Device The Intel 21143 supports a variety of Ethernet modes. Since the hardware alone cannot determine the Ethernet configuration, the BajaPPC-750 provides a means for software to detect the mode via the jumper installations at JP1. These jumpers indicate the default Ethernet boot device as follows: Table 7-3. Default Ethernet Boot Device Selection (JP1) | Jumpers <sup>1</sup> installed at JP1 on: | | t JP1 on: | Ethernet mode | CSR9 DATA | | |-------------------------------------------|---------------------|---------------------|---------------------------------------|-----------|--| | pins 1–2<br>(Bit 2) | pins 3-4<br>(Bit 1) | pins 5-6<br>(Bit 0) | selection: | bits: | | | yes | yes | yes | AUI | 11111000 | | | no | yes | yes | MII/SYM with rate detection (default) | 11111100 | | | _ | _ | _ | All other combinations are reserved | _ | | <sup>1.</sup> Spare jumpers are located at JP2 (board revs. 1 and 21 only). In order to determine the Ethernet mode, the software can manipulate the CSR9 command/status register on the Intel 21143. This register is located at hex offset 48<sub>16</sub> in PCI space. Please see the *21143 Hardware Reference Manual* for complete details regarding the CSR9 register.) Register Map 7-1. Intel 21143 General Purpose Command/Status, CSR9 The BR bit selects the boot ROM port on the 21143 device. The jumpers at JP1 are tied to the first three boot ROM address/data lines on the 21143. When BR is set and the software sets the ROM read (RD) bit, the jumper status appears in bits 2:0 of the DATA field. If a jumper is present, it pulls the corresponding data line low. Bit 2 corresponds to the status of JP1 pins 1–2; bit 1 corresponds to pins 3–4, and bit 0 corresponds to pins 5–6. The remaining DATA bits are pulled high (reserved). #### 7.4 21143 Errata The Intel 21143 chip "Extraneous Word During Transmit" problem can cause trouble for low-level software, such as test routines. The 21143 can intermittently insert two extra bytes into the transmitted packet, causing the receiving station to calculate a CRC error. For additional information regarding this and other 21143 errata, please refer to the *Errata Revision 4.0 (May 22, 1998)* document, which is available from Intel technical support. (See Section 1.4.3.) Ethernet Ports 7-5 ## 7.5 Ethernet Ports The BajaPPC-750 has a versatile Ethernet interface. It supports full-duplex operation on either a 10/100Mb/s Fast Ethernet port or a 10Mb/s AUI port. The following sections describe these ports. ### 7.5.1 Fast Ethernet The Intel 21143 media-independent interface (MII) and ICS 1890 PHY device support 10/100Mb/s communications for the Fast Ethernet port, which is available at the P3 connector on the front panel. The pin assignments for P3 are given below: Table 7-4. Fast Ethernet Pin Assignments (P3, RJ45) | Pin | Signal | Pin | Signal | |-----|---------------|-----|---------------| | 1 | Tx+ | 5 | No Connection | | 2 | Tx- | 6 | Rx- | | 3 | Rx+ | 7 | No Connection | | 4 | No Connection | 8 | No Connection | Figure 7-1. Fast Ethernet Connector (P3, RJ45) #### 7.5.2 AUI Ethernet The BajaPPC-750 provides for an additional Ethernet interface at VMEbus connector P2 (see Tables 6-9 and 6-10 for pinouts). This interface conforms to the IEEE 802.3 specification for an Attachment Unit Interface (AUI) and supplies all the required Ethernet signals. A standard 1-Amp fuse (Artesyn #2959001) guards the AUI supply voltage. This fuse (F5) is located near connector P2 on the BajaPPC-750 circuit board. Spare fuses are located at F1 and F2. ## 7.6 Cabling Considerations The BajaPPC-750 Ethernet interface complies with the IEEE P802.3u/D3 and ANSI TP-PMD v2.0 UTP CAT 5 standards for Fast Ethernet. Since the 21143 LAN controller can operate at up to 100 Mb/s, UTP CAT 5 (unshielded twisted pair, category 5) cabling is highly recommended. ## Serial and Parallel I/O The BajaPPC-750 has two 16C550-compatible serial ports and an optional parallel port. The following table summarizes the differences between the standard and optional configurations: Table 8-1. Serial/Parallel Port Connector Summary | Port | Standard | Optional | |----------|-----------------------------------------------|------------------------------------------| | Serial A | P4, front panel RJ45 | P2, VMEbus row C | | Serial B | P2, VMEbus rows Z & D;<br>HDR3, 14-pin header | P2, VMEbus row C;<br>HDR3, 14-pin header | | Parallel | none | P2, VMEbus row C | The serial and parallel interfaces are driven by an Ultra I/O controller chip that resides on an Industry Standard Architecture (ISA) bus. A Windbond PCI to ISA bridge chip links these interfaces with the rest of the system. ## 8.1 PCI to ISA Bridge The PCI to ISA bus interface for the BajaPPC-750 is provided by a Winbond Systems Laboratory W83C553 integrated circuit. The W83C553 ISA bridge features: - Compliance with revision 2.1 PCI specifications - PCI clock frequencies up to 33 MHz at 5 volts - Subtractive decoding for ISA bridge - 32-bit ISA direct memory access addressing - 4-byte line buffer - Fully-implemented standard ISA bus - Synchronous PCI-to-ISA interface ## 8.1.1 Basic Operation The W83C553 is an integrated device that bridges the PCI and ISA busses and performs PCI arbitration. In addition, it has other features (such as common ISA I/O functions) which are unimplemented for the BajaPPC-750. In its basic operation, the W83C553 translates cycles from the PCI bus onto the ISA bus, performing as a standard ISA bus controller with data buffering logic. The W83C553 generates ISA commands, controls I/O recovery, inserts wait-states, and supports up to five ISA slots without external buffering circuitry. An arbiter resolves any conflicts between PCI, refresh, and DMA cycles. The W83C553 handles both PCI master and slave bus bridging. ## 8.1.2 Registers The following table briefly summarizes the ISA bridge registers. Please refer to the Winbond Systems *W83C553F System I/O Controller with PCI Arbiter Data Book* for the bit assignments and other important details. Table 8-2. W83C553 Internal Register Summary | Hex Offset | Туре | Name | Hex<br>Default | |-----------------------|------------|----------------------------------------|----------------| | Header Registers | | | | | 01-00 | _ | Vendor ID | 10AD | | 03-02 | _ | Device ID | 0565 | | 05-04 | R/W | Command | 0007 | | 07-06 | R/W | Status | 0200 | | 08 | _ | Revision ID | 00 | | 0B-09 | _ | Class Code | 060100 | | 0E | _ | Header Type | 80 | | Control Registers (Fu | unction 0) | | ' | | 40 | R/W | PCI Control | 20 | | 41 | R/W | Scatter/Gather Relocation Base Address | 04 | | 42 | R/W | Line Buffer Control | 00 | | 43 | R/W | IDE Interrupt Routing Control | EF | | 45-44 | R/W | PCI Interrupt Routing Control | 0000 | | 47-46 | R/W | BIOS Timer Base Address | 0078 | | 48 | R/W | ISA-to-PCI Address Decoder Control | 01 | | 49 | R/W | ISA ROM Address Decode | 00 | | 4A | R/W | ISA-to-PCI Memory Hole Start Address | 00 | | 4B | R/W | ISA-to-PCI Memory Hole Size | 00 | | 4C | R/W | Clock Divisor | 00 | | 4D | R/W | Chip Select Control | 33 | Table 8-2. W83C553 Internal Register Summary — Continued | Hex Offset | Туре | Name | Hex<br>Default | |-----------------------------------------------------------------------------|-----------|------------------------------------------------------|----------------| | 4E | R/W | AT System Control | 04 | | 4F | R/W | AT Bus Control | 00 | | 80 | R/W | PCI Arbiter Priority Control | E0 | | 81 | R/W | PCI Arbiter Priority Extension Control | 01 | | 82 | R/W | PCI Arbiter Priority Enhanced Control | 00 | | 83 | R/W | PCI Arbiter Control | 80 | | DMA Controller I/O Registe | ers | | | | 00; 02; 04; 06; C0; C4;<br>C8; CC | R/W | Base and Current Address <sup>1</sup> | | | 01; 03; 05; 07; C2; C6;<br>CA; CE | R/W | Base and Current Word Count <sup>1</sup> | _ | | 08; D0 | R | DMA Command <sup>2</sup> | 00 | | 08 | R | DMA Controller 1 Status | 00 | | D0 | R | DMA Controller 2 Status | _ | | 09; D2 | W | DMA Controller Request <sup>2</sup> | _ | | 0A; D4 | W | DMA Controller Mask <sup>2</sup> | _ | | 0B; D6 | W | DMA Controller Mode <sup>2</sup> | _ | | 0C; D8 | W | Clear Byte Pointer <sup>2</sup> | _ | | 0D; DA | W | Master Clear <sup>2</sup> | _ | | 0E; DC | W | Clear Mask <sup>2</sup> | _ | | OF; DE | W | Write All Mask <sup>2</sup> | _ | | 87; 83; 81; n.a.; 82; 8B;<br>89; 8A | R/W | Memory Page <sup>3</sup> | 00 | | 40B - DMAC1<br>4D6 - DMAC2 | W | Extended Mode Register | 0x | | 40A | R | Scatter/Gather Interrupt Status | 00 | | 417-415;<br>413-410 | W | Scatter/Gather Command | 000000 | | 418; 419; 41A; n.a.; 41B;<br>41D; 41E; 41F | R | Scatter/Gather Status <sup>1</sup> | _ | | 420-423; 424-427; 428-<br>42B; 42C-42F; n.a.; 434-<br>437; 438-43B; 43C-43F | W | Scatter/Gather Descriptor Table Pointer <sup>1</sup> | _ | | 487; 483; 481; 482; n.a.;<br>48B; 489; 48A | R/W | DMA Page | _ | | Programmable Interrupt Co | ontroller | (PIC) Registers | | | 20 - PIC1; A0 - PIC2 | W | Initialization Command Word 1 | 19 | | 20 - PIC1; A0 - PIC2 | W | Operational Control Word 2 | _ | | 20 - PIC1; A0 - PIC2 | R/W | Operational Control Word 3 | _ | | 21 - PIC1; A1 - PIC2 | W | Initialization Command Word 2 | _ | Hex **Hex Offset** Type Name **Default** 21 W Initialization Command Word 3 - Master 04 Α1 W Initialization Command Word 3 - Slave 21 - PIC1; A1 - PIC2 Initialization Command Word 4 W 21 - PIC1; A1 - PIC2 R/W Operational Control Word 1 4D0 - PIC1; 4D1 - PIC2 R/W Interrupt Edge/Level Control 00 Counter/Timer I/O Registers 40; 41; 42 R/W Counter<sup>4</sup> 40; 41; 42 R Counter Status<sup>4</sup> Timer Control 43 W **BIOS Timer** 7B-78 000000 Miscellaneous I/O Control Registers R/W NMI Status and Control (Port B) 00 61 70 NMI Enable and RTC Address 0xxx,xxxx92 Port 92 R/W 24 F0 W Co-processor Error 810 RTC CMOS RAM Protect 1 W 812 W RCT CMOS RAM Protect 2 Table 8-2. W83C553 Internal Register Summary — Continued ## 8.2 I/O Controller The SMC FDC37C935 Ultra I/O controller is a versatile single-chip device that provides support for keyboard, mouse, hard disk, floppy disk, parallel port, and serial port input/output. NOTE. Only the parallel port and high-speed serial channels are utilized in the BajaPPC-750 implementation of this chip. <sup>1.</sup> Hex offset values are for Channels 0 through 7, respectively. <sup>2.</sup> Hex offset values are for Controller 1 and Controller 2, respectively. <sup>3.</sup> Hex offset values are for Pages 0 through 7, respectively. <sup>4.</sup> Hex offset values are for Counter/Timer 0 through 2, respectively. I/O Controller 8-5 ## 8.2.1 Block Addressing The CPU accesses the Ultra I/O controller through a series of read/write registers, which have configurable base addresses. All of the I/O registers are 8 bits wide with the exception of a 16-bit IDE data register at port 1F0<sub>16</sub>. The following table summarizes the I/O port addressing scheme: Table 8-3. Ultra I/O Block Addressing | Hex Base | Address | I/O Block | Logical Device | |-----------|----------------------------------------------------------------------------------------|---------------------------------------|----------------| | | Base + (0-5) and + (7) | Floppy Disk | 0 | | FE00,0100 | Base + (0-7) | Serial Port Com 1 | 4 | | FE00,0108 | Base + (0-7) | Serial Port Com 2 | 5 | | FE00,0110 | Base + (0-3)<br>Base + (0-7)<br>Base + (0-3), + (400-402)<br>Base + (0-7), + (400-402) | Parallel Port SPP EPP ECP ECP+EPP+SPP | 3 | | | Base1 + (0-7), Base2 + (0) | IDE1 | 1 | | | Base1 + (0-7), Base2 + (0) | IDE2 | 2 | ## 8.2.2 Configuration Upon reset or power-up, the BIOS uses two configuration ports, INDEX and DATA, to initialize the logical devices at POST. These ports are only valid when the Ultra I/O controller is in Configuration mode, as set by the SYSOPT hardware pin. To enter the configuration state, write $55,55_{16}$ to the CONFIG PORT at $0370_{16}$ . To exit the configuration state, write $AA_{16}$ to the same location. Table 8-4 summarizes the Ultra I/O configuration registers. For a complete description of all the control bits, please refer to the SMC Ultra FDC37C93x user's documentation. Table 8-4. Ultra I/O Configuration Registers | Hex Index | Access | Hard Reset | Soft Reset | Register Name | | | |--------------------------------|--------|------------|------------|------------------------|--|--| | Global Configuration Registers | | | | | | | | 02 | W | 00 | 00 | Config. Control | | | | 03 | R/W | 03 | n/a | Index Address | | | | 07 | R/W | 00 | 00 | Logical Device Number | | | | 20 | R | 02 | 02 | Device ID - hard wired | | | | 21 | R | 01 | 01 | Device Rev hard wired | | | | 22 | R/W | 00 | 00 | Power Control | | | | 23 | R/W | 00 | n/a | Power Management | | | | 24 | R/W | 04 | n/a | OSC | | | | 2D | R/W | n/a | n/a | TEST 1 | | | | 2E | R/W | n/a | n/a | TEST 2 | | | Table 8-4. Ultra I/O Configuration Registers — Continued | Hex Index | Access | Hard Reset | Soft Reset | Register Name | | | | |------------------------------------------------|-----------|------------------|----------------|-----------------------------|--|--|--| | 2F | R/W | 00 | n/a | TEST 3 | | | | | Logical Device 0 Configuration Registers (FDD) | | | | | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 03, F0 | 03, F0 | Primary Base I/O Address | | | | | 70 | R/W | 06 | 06 | Primary Interrupt Select | | | | | 74 | R/W | 02 | 02 | DMA Channel Select | | | | | F0 | R/W | 0E | n/a | FDD Mode Register | | | | | F1 | R/W | 00 | n/a | FDD Option Register | | | | | F2 | R/W | FF | n/a | FDD Type Register | | | | | F4 | R/W | 00 | n/a | FDD0 | | | | | F5 | R/W | 00 | n/a | FDD1 | | | | | | Logi | cal Device 1 Con | figuration Reg | jisters (IDE1) | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 01, F0 | 01, F0 | Primary Base I/O Address | | | | | 70 | R/W | 03, F6 | 03, F6 | Primary Interrupt Select | | | | | | Logic | cal Device 2 Con | figuration Reg | jisters (IDE2) | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 00, 00 | 00, 00 | Primary Base I/O Address | | | | | 62, 63 | R/W | 00, 00 | 00, 00 | Second Base I/O Address | | | | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | | | | F0 | R/W | 00 | n/a | IDE2 Mode Register | | | | | | Logical [ | Device 3 Configu | ration Registe | rs (Parallel Port) | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 00, 00 | 00,00 | Primary Base I/O Address | | | | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | | | | 74 | R/W | 04 | 04 | DMA Channel Select | | | | | F0 | R/W | 3C | n/a | Parallel Port Mode Register | | | | | | Logical [ | Device 4 Configu | ration Registe | rs (Serial Port 1) | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 00, 00 | 00, 00 | Primary Base I/O Address | | | | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | | | | F0 | R/W | 00 | n/a | Serial Port 1 Mode Register | | | | | | Logical [ | Device 5 Configu | ration Registe | rs (Serial Port 2) | | | | | 30 | R/W | 00 | 00 | Activate | | | | | 60, 61 | R/W | 00, 00 | 00, 00 | Primary Base I/O Address | | | | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | | | | F0 | R/W | 00 | n/a | Serial Port 2 Mode Register | | | | I/O Controller 8-7 Table 8-4. Ultra I/O Configuration Registers — Continued | Hex Index | Access | Hard Reset | Soft Reset | Register Name | |-----------|---------------------------|-----------------|-----------------|-------------------------------| | F1 | R/W | 00 | n/a | IR Options Register | | | Logica | l Device 6 Con | figuration Regi | sters (RTC) | | 30 | R/W | 00 | 00 | Activate | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | F0 | R/W | 00 | n/a | Real Time Clock Mode Register | | F1 | R/W | 00 | n/a | Serial EEPROM Mode Register | | F2 | R/W | 00 | 00 | Serial EEPROM Pointer | | F3 | W | n/a | n/a | Write EEPROM Data | | F4 | bits [6:0] R<br>bit [7] W | 03 | 03 | Write Status | | F5 | R | n/a | n/a | Read EEPROM Data | | F6 | R | n/a | n/a | Read Status | | | Logical D | evice 7 Configu | uration Registe | ers (Keyboard) | | 30 | R/W | 00 | 00 | Activate | | 70 | R/W | 00 | 00 | Primary Interrupt Select | | 72 | R/W | 00 | 00 | Second Interrupt Select | | | Logical [ | Device 8 Config | uration Regist | ers (AUX I/O) | | 30 | R/W | 00 | 00 | Activate | | 60, 61 | R/W | 00, 00 | 00, 00 | Primary Base I/O Address | | 62, 63 | R/W | 00, 00 | 00, 00 | Second Base I/O Address | | E0-E7 | R/W | 01 | n/a | GP10-GP17 | | E8-ED | R/W | 01 | n/a | GP20-GP25 | | F0 | R/W | 00 | n/a | GP_INT | | F1 | R/W | 00 | n/a | GPR_GPW_EN | | F2 | R/W | 00 | n/a | WDT_VAL | | F3 | R/W | 00 | n/a | WDT_CFG | | F4 | R/W <sup>1</sup> | 00 | n/a | WDT_CTRL | <sup>1.</sup> Register contains some read or read-only bits. ### 8.3 Serial Ports The Ultra I/O controller provides two high-speed Universal Asynchronous Receiver/Transmitter (UART) devices. Each UART channel is programmable for baud rate, start/stop bits, parity, and prioritized interrupts. Please refer to the *Ultra I/O Controller User's Manual* for complete information on the serial ports. ## 8.3.1 Serial Port Addressing Each of the two serial ports has a register set located at sequentially increasing addresses above the base address. The configuration registers (see Table 8-4) determine the base address. DLAB<sup>1</sup> A2 Α1 Α0 Access Register Description 0 0 0 0 Read **RBR** Receive Buffer 0 0 0 0 Write THR Transmit Buffer 0 0 0 1 Read/Write **IER** Interrupt Enable Χ 0 1 0 **Read Only** IIR Interrupt Identification Χ 0 1 0 Write Only **FCR** FIFO Control Χ 0 1 1 Read/Write **LCR** Line Control 1 0 Read/Write MCR Modem Control Χ 0 Χ 1 0 1 Read/Write LSR Line Status Χ 1 1 0 Read/Write MSR Modem Status 1 Χ 1 1 Read/Write **SCR** Scratch Pad 0 0 0 Read/Write DLL Divisor Latch (least significant) 1 Read/Write DLM 0 0 Divisor Latch (most significant) Table 8-5. Addresses for Ultra I/O Serial Port Registers ## 8.3.2 Serial Port Registers Refer to Table 8-5 for a summary of the serial port registers. The Interrupt Enable Register, IER, enables specific interrupt sources for the serial ports. It is possible to disable all of the Ultra I/O serial port interrupts using this register. | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |-------|--------|------|------|---|---|---|---| | ERDAI | ETHREI | ELSI | EMSI | 0 | 0 | 0 | 0 | Register Map 8-1. Ultra I/O Serial Port Interrupt Enable, IER <sup>1.</sup> DLAB = Bit 7 of LCR Serial Ports 8-9 **ERDAI** Enable received data available interrupt. 1 = enable **ETHREI** Enable transmitter holding register empty interrupt. 1 = enable ELSI Enable receiver line status interrupt. Error sources are Overrun, Parity, Framing, and Break. 1 = enable EmsI Enable modem status interrupt. This bit is set when MSR bits change state. 1 = enable The Interrupt Identification Register, IIR, allows the host CPU to determine the priority and source of an interrupt on a serial port: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |------|---|--------|---|---|---|------|------| | PEND | | INT_ID | | 0 | 0 | FIFC | D_EN | Register Map 8-2. Ultra I/O Serial Port Interrupt Identification, IIR **PEND** Interrupt pending. 1 = none pending, 0 = pending **INT\_ID[1:3]** Interrupt priority identification. Bit 3 is always zero in non-FIFO mode. 1 1 0 = receiver line status (highest priority) 0.10 = received data ready 100 = transmitter holding register empty $0\ 0\ 0 = modem \ status \ (lowest priority)$ FIFO\_EN[6:7] Bits are set when FIFO control register bit 0 = 1. Bits 6 and 7 are always zero in non-FIFO mode (see *Ultra I/O Controller User's Manual*). The Line Control Register, LCR, controls the format of the serial line: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | |----|----|-----|-----|-----|-------|-------|------|--| | WI | LS | STB | PEN | EPS | STICK | BREAK | DLAB | | Register Map 8-3. Ultra I/O Serial Port Line Control, LCR WLS[0:1] Word length select bits. 00 = 5 bits, 10 = 6 bits, 01 = 7 bits, 11 = 8 bits STB Stop bits. 0 = 1 stop bit, 1 = 1.5 stop bits for 5-bit words or 2 stop bits for 6-,7-, and 8-bit words **PEN** Parity enable. 1 = enable **EPS** Even parity select. With PEN enabled, 0 = odd parity and 1 = even parity STICK Stick parity bit. With PEN enabled, 1 = parity bit transmitted and detected by receiver in opposite state from EPS bit **BREAK** Set break control bit. 1 = force TXD to spacing or logic "0" until reset **DLAB** Divisor latch access bit. 0 = allow access to RBR, THR, and IER; 1 = allow access to baud rate generator divisor latch The Modem Control Register, MCR, controls the interface with a serial port device: Register Map 8-4. Ultra I/O Serial Port Modem Control, MCR DTR Data terminal ready. 0 = nDTR output forced to logic "1", 1 = nDTR output forced to logic "0" RTS Request to send. 0 = nRTS output forced to logic "1", 1 = nRTS output forced to logic "0" OUT1 Output 1. Accessed only by the CPU, this bit has no corresponding pin. OUT2 Output 2. 0 = disable UART interrupts, 1 = enable UART interrupts **LOOP** Loopback. 1 = enable loopback diagnostic testing. The Line Status Register, LSR, tracks the status of the serial line: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | |----|----|----|----|----|------|------|---------| | DR | OE | PE | FE | ВІ | THRE | TEMT | FIFO_ER | Register Map 8-5. Ultra I/O Serial Port Line Status, LSR DR Data ready. 0 = all data has been read in RBR or FIFO, 1 = an incoming character has been received and transferred into the RBR or FIFO OE Overrun error. 1 = data in RBR was not read before being overwritten Serial Ports 8-11 - **PE** Parity error. 1 = parity error detected. This bit is reset when read. - FE Framing error. 1 = framing error detected (no stop bit). This bit is reset when read. - BI Break interrupt. 1 = received data was held at logic "0" for longer than a full word transmission time. This bit is reset when the CPU reads the LSR. - THRE Transmitter holding register empty. 0 = serial port not ready, 1 = serial port ready for transmission - TEMT Transmitter empty. 0 = THR or TSR contains a data character, 1 = THR and TSR are empty - FIFO\_ER FIFO error. This bit is always zero, except in FIFO mode, where 1 = FIFO error The Modem Status Register, MSR, tracks the status of the serial port device. These bits all are reset to zero whenever the MSR is read. | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | |------|------|------|------|-----|-----|----|-----|--| | DCTS | DDSR | TERI | DDCD | CTS | DSR | RI | DCD | | Register Map 8-6. Ultra I/O Serial Port Modem Status, MSR - **DCTS** Delta clear to send. 1 = nCTS changed state - **DDSR** Delta data set ready. 1 = nDSR changed state - **TERI** Trailing edge of ring indicator. 1 = nRI changed state to logic "1" - **DDCD** Delta data carrier detect. 1 = nDCD changed state - CTS Complement of clear to send (nCTS) input. - **DSR** Complement of data set ready (nDSR) input. - RI Complement of ring indicator (nRI) input. - DCD Complement of data carrier detect (nDCD) input. ## 8.3.3 Programmable Baud Rate The Ultra I/O controller has a programmable baud rate generator that works in conjunction with the two 8-bit Divisor Latch registers, DLL and DLM. The baud rate generator can divide the clock input by a number from 1 to 65535, which is stored as a 16-bit binary value in the DLL and DLM registers. The resulting clock output frequency is 16 times the baud rate. Upon initialization of the DLL and DLM registers, the value of the divisor determines the clock as follows: - 0 =clock divided by 3 - 1 = inverse of input oscillator - 2 =clock divided by 2, 50% duty cycle - 3 or greater = low for 2 bits, high for count remainder Table 8-6. Baud Rate Divisors (1.8462 MHz Crystal) | Desired<br>Baud Rate | Divisor for<br>16x Clock | Clock Input<br>(MHz) | Percentage of<br>Error | | |----------------------|--------------------------|----------------------|------------------------|--| | 50 | 2304 | 1.8462 | .001 | | | 75 | 1536 | 1.8462 | .2 | | | 110 | 1047 | 1.8462 | .2 | | | 134.5 | 857 | 1.8462 | .004 | | | 150 | 768 | 1.8462 | .2 | | | 300 | 384 | | .2 | | | 600 | 600 192 | | .2 | | | 1200 96 | | 1.8462 | .2 | | | 1800 | 800 64 | | .2 | | | 2000 | 58 | 1.8462 | .005 | | | 2400 | 48 | 1.8462 | .2 | | | 3600 | 32 | 1.8462 | .2 | | | 4800 | 24 | 1.8462 | .2 | | | 7200 | 16 | 1.8462 | .2 | | | 9600 | 12 | 1.8462 | .2 | | | 19200 | 6 | 1.8462 | .2 | | | 38400 | 3 | 1.8462 | .030 | | | 57600 | 2 | 1.8462 | .16 | | | 115200 | 1 | 1.8432 | .16 | | | 230400 | 32770 | 3.6864 | .16 | | | 460800 | 32769 | 7.3728 | .16 | | Serial Ports 8-13 NOTE. The EIA-232C specification defines a maximum rate of 20,000 bits per second over a typical 50-foot cable (2,500 picofarads maximum load capacitance). Higher baud rates are possible, but depend specifically upon the application, cable length, and overall signal quality. ## 8.3.4 Connectors and Cabling The Ultra I/O Controller provides two standard EIA-232 serial I/O ports. Serial Port A is available at the BajaPPC-750 front panel P4 connector (standard configuration only) and at the VMEbus P2 connector (optional configuration). Table 8-7 lists the pinouts for the front panel connector. A console adapter (Fig. 8-2) also is available for this connector, providing connectivity with a standard DB25 connector. Table 6-10 lists the pinouts for the VMEbus connector. Please refer to Table 8-1 for a summary of the port connector configurations. Table 8-7. Serial Port-A Pin Assignments (P4 RJ45 or Console Adapter) | RJ45 Pin#<br>(P4) | DB25 Pin#<br>(Adapter) | Signal | RJ45 Pin#<br>(P4) | DB25 Pin#<br>(Adapter) | Signal | |-------------------|------------------------|---------------|-------------------|------------------------|--------| | 1 | 8 | no connection | 5 | 7 | GND | | 2 | 3 | TXD_A* | 6 | 6 | RTS_A | | 3 | 2 | RXD_A* | 7 | 4 | DCD_A | | 4 | 20 | CTS_A | 8 | 5 | DTR_A | **NOTE.** This connector (P4) is not installed for the optional (Motorola-compatible) P2 configuration. Figure 8-1. Serial Port-A Connector (P4, RJ45) Figure 8-2. Console Adapter #308A006-48 for Serial Port A Serial Port B is available at header HDR3 (see Table 8-8 for pinouts) on the BajaPPC-750 circuit board and also at the VMEbus P2 connector (see Table 6-10 for pinouts). Fig. 8-3 shows the cable assembly for header HDR3. Table 8-8. Serial Port-B Pin Assignments (HDR3 Header or Cable Assembly) | HDR3 Pin #<br>(Header) | DB25 Pin#<br>(Cable) | Signal | HDR3 Pin #<br>(Header) | DB25 Pin#<br>(Cable) | Signal | |------------------------|----------------------|---------------|------------------------|----------------------|---------------| | 1 | 1 | No Connection | 8 | 17 | No Connection | | 2 | 14 | No Connection | 9 | 5 | DTR_B | | 3 | 2 | RXD_B* | 10 | 18 | No Connection | | 4 | 15 | No Connection | 11 | 6 | RTS_B | | 5 | 3 | TXD_B* | 12 | 19 | No Connection | | 6 | 16 | No Connection | 13 | 7 | GND | | 7 | 4 DCD_B | | 14 | 20 | CTS_B | | | | | | 8-13, 21-25 | No Connection | Please refer to the SMC Ultra FDC37C93x user's documentation for a complete description of the serial port signals and associated control registers Figure 8-3. Cable Assembly #314A002-12 for Serial Port B ## 8.3.5 Handshaking Jumper A jumper on the BajaPPC-750 circuit board determines whether or not EIA-232 handshaking is enabled as follows: Table 8-9. EIA-232 Handshaking Configuration Jumper | Jumper <sup>1</sup> | Function | Options | Default Configuration | | | |---------------------|-----------------------------------------------|-------------------------------------------------|-------------------------|--|--| | JP3 | Selects whether EIA-232 handshaking is active | JP3:1–2, False (–12V).<br>JP3:2–3, True (+12V). | JP3:2–3,<br>True (+12V) | | | <sup>1.</sup> Spare jumpers are located at JP2 (board revs. 1 and 21 only). ## 8.4 Parallel Port (Optional) The Ultra I/O controller provides a standard parallel port, which is controlled by software. The parallel port signals are available at VMEbus connector P2, row C (see Table 6-10 for pinouts). NOTE. The standard BajaPPC-750 configuration does not provide parallel port signals. These signals are available only with the optional (Motorola-compatible) pinout configuration on P2. The following sections briefly describe eight addressable registers that determine the parallel port functions. Please refer to the *Ultra I/O Controller User's Manual* for complete information on the parallel port features. ## 8.4.1 Parallel Port Addressing The base address for the BajaPPC-750 parallel port is FE00, 0110<sub>16</sub>. The CPU can read/write the control and data registers. In Enhanced Parallel Port (EPP) mode, the status register also is read/write. (The EPP registers are available only in EPP mode. See the *Ultra I/O Controller User's Manual* for details on the EPP registers.) Table 8-10. Addresses for Ultra I/O Parallel Port Registers | Register Hex Address | | Register | Hex Address | | |----------------------|----------|------------|-------------|--| | Data | Base + 0 | EPP Data 0 | Base + 4 | | | Status | Base + 1 | EPP Data 1 | Base + 5 | | | Control | Base + 2 | EPP Data 2 | Base + 6 | | | EPP Address | Base + 3 | EPP Data 3 | Base + 7 | | ## 8.4.2 Parallel Port Registers The Data Register latches the contents of the data bus upon a write operation and outputs the results to the PD0–PD7 bits. A reset clears the Data Register. | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 | Register Map 8-7. Ultra I/O Parallel Port Data The Status Register latches during the read cycle and contains the following information: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|------|----|------|------|---|---|-------| | nBUSY | nACK | PE | SLCT | nERR | 0 | 0 | TMOUT | Register Map 8-8. Ultra I/O Parallel Port Status **nBUSY** Busy. Read by CPU as bit 7 of Printer Status Register. 0 = printer is busy, 1 = ready to accept next character nACK Acknowledge. Read by CPU as bit 6 of Printer Status Register. 0 = character acknowledged, 1 = still processing or character not received - PE Paper End. Read by CPU as bit 5 of Printer Status Register. 0 = paper is loaded, 1 = paper end detected - SLCT Printer Selected Status. Read by CPU as bit 4 of Printer Status Register. 0 = not selected, 1 = selected - **nERR** Error. Read by CPU as bit 3 of Printer Status Register. 0 = error detected, 1 = no error detected - TMOUT Time Out. Valid only in EPP mode. 0 = no time-out error, 1 = time-out error detected The parallel port Control Register bits are defined as follows: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|-----|------|--------|-------|--------|--------| | 0 | 0 | PCD | IRQE | SLCTIN | nINIT | AUTOFD | STROBE | #### Register Map 8-9. Ultra I/O Parallel Port Control - PCD Parallel Control Direction. Only valid in EPP or ECP mode. 0 = output mode (write), 1 = input mode (read) - IRQE Interrupt Request Enable. 0 = enabled, 1 = disabled - SLCTIN Printer Select Input. Inverted and output onto the nSLCTIN output. 0 = printer not selected, 1 = printer selected - **nINIT** Initiate Output. Output onto the nINIT output (not inverted). - AUTOFD Autofeed. Inverted and output onto the nAUTOFD output. 0 = no autofeed, 1 = generate automatic line feed after printing a line - **STROBE** Strobe. Inverted and output onto the nSTROBE output. | BajaPPC-750: Serial and Parallel I/O | |--------------------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## Counter/Timers The interrupt control and counter/timer functions for the BajaPPC-750 are handled by a programmable logic device (PLD). Interrupts from the processor, reset facilities, Ethernet, VMEbus, PMC, and ISA subsystems are routed by this PLD. It is addressed by four lines from the boot ROM and has 32 DRAM data lines. **NOTE.** Please refer to Section 4.5 for information about the BajaPPC-750 real-time clock. ## 9.1 Counter/Timers The BajaPPC-750 has two programmable 32-bit counter/timers that provide both continuous and one-shot interrupts. Continuous interrupts may be generated with a period of 960 nanoseconds to approximately 4.3 minutes. Counter/timer interrupts are managed by the interrupt controller, which drives the interrupt input to the CPU. For details, see Section 3.4 on interrupt handling. ## 9.2 Counter/Timer Registers Each timer is programmed through three read registers and three write registers. These registers sit on data bus bits DH(0:7) and should be accessed as bytes. The registers are listed in the table below, followed by sections briefly describing each one. Table 9-1. Counter/Timer Registers | Hex Address | Read Function | Write Function | | | | | |-------------|--------------------------------|--------------------------------------|--|--|--|--| | FF9A,0050 | Timer 2 Period Register (CTPR) | Timer 2 Period Register (CTPR) | | | | | | FF9A,0040 | Timer 2 Status Register (CTSR) | Timer 2 Mode Register (CTMR) | | | | | | FF9A,0030 | Timer 2 Count Register (CTCR) | Timer 2 Interrupt Acknowledge (CTIA) | | | | | | FF9A,0020 | Timer 1 Period Register (CTPR) | Timer 1 Period Register (CTPR) | | | | | | FF9A,0010 | Timer 1 Status Register (CTSR) | Timer 1 Mode Register (CTMR) | | | | | | FF9A,0000 | Timer 1 Count Register (CTCR) | Timer 1 Interrupt Acknowledge (CTIA) | | | | | ## 9.2.1 Period Register The Period Register, CTPR, specifies the period to be used by the counter/timer. The value written indicates the number of 14.31818 MHz clocks between interrupts. This register can specify periods from 120 nanoseconds to 4.29 minutes. The formula for determining the correct value is: Value = ((desired period in nanoseconds)/69.8) - 1 or Value = (14,318,180/frequency in Hz) - 1 This register can be read at anytime, but it can only be written when the timer is disabled. At reset the period register is initialized to generate 10.00002-millisecond interrupts. ## 9.2.2 Count Register The Count Register, CTCR, returns the current contents of the counter. When the counter is activated, it is loaded with the contents of the period register and counts down from this value until zero is reached. Reading this register provides the time remaining until the timer generates an interrupt. ### 9.2.3 Status Register The Status Register, CTSR, is a read-only register that returns both the configuration, as specified by the mode register CTMR, and the status information for the timer. The format of this register is described in the following table. | DH0 | DH1 | DH2 | DH3 | DH4 | DH5 | DH6 | DH7 | |--------|--------|--------|--------|--------|--------|--------|--------| | CInPrg | Ovflow | InPend | StrStp | IntrEn | OvFlEn | CTMode | Enable | Register Map 9-1. Counter/Timer Status, CTSR The bits (0:7) return the current state of the timer. These status bits are modified by the timer and can change at any time. The interrupt pending, overflow, and count-in-progress status bits are directly controlled by the state of the timer, and are used to determine the state of the timer. CInPrg The count-in-progress bit indicates that the timer has not reached a terminal count of zero. In timer mode this bit is set when the count is stopped. In counter mode this bit may only be cleared momentarily. Ovflow The overflow bit is set if the counter has reached a terminal count of zero and an interrupt is still present. This bit is also unaffected by the state of CTMR's overflow enable bit. InPend The interrupt pending bit is set if the counter reaches a terminal count of zero, and is unaffected by the interrupt enable bit of CTMR. StrStp The start/stop timer bit is initially set and cleared through CTMR, but under several conditions can be cleared by the counter. These conditions occur when the timer is configured as a timer and has reached the terminal count, and when the timer is configured to stop on overflow and an overflow has occurred. The lowest four bits of this register return the contents of CTMR. These bits are static in that they are only affected by reset and writing to CTMR, and are unaffected by the current state of the counter/timer. **IntrEn** Interrupt enable. OvFlEn Overflow enable. CTMode Counter/timer mode. **Enable** Enable. ### 9.2.4 Interrupt Acknowledge Register The Interrupt Acknowledge Register, CTIA, clears the interrupt and overflow bits of CTSR. The interrupt pending and overflow status bits described above can be cleared either by clearing the enable bit in CTMR that resets the timer, or by writing to the register that clears the status bits without affecting the timer. ## 9.2.5 Mode Register The timer Mode Register, CTMR, is used to initialize and start the timer. The format of this register is described in the following table. | DH3 | DH4 | DH5 | DH6 | DH7 | |--------|--------|--------|--------|--------| | StrStp | IntrEn | OvFlEn | CTMode | Enable | Register Map 9-2. Counter/Timer Mode, CTMR StrStp The start/stop timer bit starts the timer when set and stops the timer when cleared. Use this feature when trying to read the current count from the CTCR. The start/stop timer bit is initially set and cleared through this register, however it may also be cleared by the counter. This is possible when the timer is configured as a timer and has reached terminal count, or when the timer is configured to stop on overflow and overflow has occurred. **IntrEn** When the interrupt enable bit is set, it allows the interrupt pending status to generate interrupt requests. OvFIEn When the overflow enable bit is set, the counter stops if a terminal count is reached and the previous interrupt has not been serviced. If this bit is cleared the counter continues regardless of the error condition. CTMode The counter/timer mode bit determines which of the modes the timer operates in. When cleared the counter/timer operates in timer mode, which counts down to zero once and then stops. When set the counter/timer operates in counter mode, which continually counts down to zero and reloads. Enable The enable bit acts as a general purpose reset for the counter/timer. When set the timer can operate normally. When cleared the timer is stopped and reloaded, and the status is cleared. ## May 2002 # 10 Monitor The BajaPPC-750 monitor consists of about 150 C language functions. The monitor commands are a subset of these functions that provide easy-to-use tools for configuring the BajaPPC-750 at power-up or reset, as well as for communications, downloads, and other common tasks. This chapter describes the monitor's features, basic operation, and configuration sequences. This chapter also serves as a reference for the monitor commands and functions. #### 10.1 Monitor Features The BajaPPC-750 monitor has a command-line editor and can recall previous command lines. This section describes these features, as well as the start-up display. ## 10.1.1 Start-Up Display At power-up or after a reset, the monitor runs diagnostics and reports the results in the start-up display. NOTE. The results of the power-up diagnostic tests are displayed at power-up or after a reset. A failed memory test could indicate a hardware malfunction that should be reported to our Test Services department at 1-800-327-1251 or serviceinfo@artesyncp.com. At power-up and reset, the monitor configures the board according to the contents of nonvolatile configuration memory. If the configuration indicates that an autoboot device has been selected, the monitor attempts to load an application program from the specified device. You can prevent the board from booting the OS if any of the power-up tests fail by setting the NVRAM configuration parameter HaltOnFailure (see Table 10-3 and Section 10.7). ``` Baja750 Monitor, Ver 1.0 Enabling the L1 instruction cache... Print Hex Test, should = 89abcdef ? 0x89abcdef Memory Size is 0x08000000 Timebase Register Test PASSED Memory Test at 0x40000 PASSED Address Boundary Rotating Bit Test Monitor memory rotating bit test Monitor memory init PASSED PASSED Clearing BSS... Initializing ISA Bridge... Enabling external interrupts... Initializing PCI Device Base Addresses. Configuring the data and instruction MMU... Configuring the L2 cache timing... Enabling the L2 cache... Enabling the data cache... PASSED Testing memory addressing MPC750 L2 Cache Test ITC Counter/Timer Test DEC 21143A Test on Port A DAGGED PASSED PASSED Serial Port 1 Test Serial Port 2 Test PASSED PASSED Clearing memory on powerup... Copyright Artesyn Technologies, 1999 Created: Mon Jun 7 11:51:11 1999 Baja750(TM) Debug Monitor _____ Artesyn Technologies. === === Ver 1.0 Ver 1.0 ===== ( +m) ======= ======= ========= ======= ===----- === === === === === === === ======= ======= === === Baja750[Ver 1.0] ``` Figure 10-1. Monitor Start-up Display You can cancel the autoboot sequence by pressing the H key on the console key-board before the countdown ends. The monitor is then in a "manual" mode from which you can execute commands and call functions. The monitor also enters manual mode if the autoboot fails. Instructions for downloading and executing remote programs are given in the command reference and function reference. The monitor provides a command-line interface that includes a command history and a *vi*-like line editor. The command-line interface has two modes: insert text mode and command mode. In insert text mode you can type text on the command line. In command mode you can move the cursor along the command line and modify commands. Each new line is brought up in insert text mode. Monitor Features 10-3 ## **10.1.2** Command-Line History The monitor maintains a history of up to 50 command lines for reuse. Press the <ESC> key from the command line to access the history. **k or -** Move backward in the command history to access a previous command. j or + Move forward in the command history to access a subsequent command. #### 10.1.3 Command-Line Editor The command-line editor uses typical UNIX® *vi* editing commands. help editor To access an on-line description of the editor, type help editor or h editor. <ESC> To exit Entry mode and start the editor, press <ESC>. You can use most common vi commands, such as x, i, a, A, \$, w, cw, dw, r, and e. <cr> To execute the current command and exit the editor, press Enter or Return. <DEL> To discard an entire line and create a new command line, press <DEL> at any time. a or A Append text on the command line. i or I Insert text on the command line. x or X Delete a single character. **r** Replace a single character. w Move the cursor to the next word. c Change. Use additional commands with **c** to change words or groups of words, as shown below. **cw or cW** Change a word after the cursor (capital W ignores punctuation). **ce or cE** Change text to the end of a word (capital E ignores punctuation). **cb or cB** Change the word before the cursor (capital B ignores punctuation). **c\$** Change text from the cursor to the end of the line. **d** Delete. Use additional commands with **d** to delete words or groups of words, as shown below. **dw or dW** Delete a word after the cursor (capital W ignores punctuation). **de or dE** Delete to the end of a word (capital E ignores punctuation). **db or dB** Delete the word before the cursor (capital B ignores punctuation). **d\$** Delete text from the cursor to the end of the line. ## 10.1.4 PowerPC Debugger The PowerPC debugger allows the operator to probe memory-mapped devices. It features simple commands that execute without requiring a stack or memory. The debugger starts automatically if the internal diagnostics discover an error. Also, the operator may force the debugger to start by pressing the 'd' key before resetting the board. The debugger may be called from the monitor command line by using the **Debugger** command (although the **q** command is not functional in this case). The following commands are available in the debugger: ? Display a list of available commands. **r** [b 1] address Read a byte [b] or 32-bit long word [l] from an address. **w** [b l] address data Write a byte [b] or 32-bit long word [l] to an address. d address Display a 256-byte block of data beginning at address. After this command, additional blocks may be displayed by press- ing return. f data address size Fill a block of size bytes with the byte data starting at address. t start end Perform a memory test from the start address to the end address. This is a rotating bit test on the block of memory. It writes 0x00000001 to the first 32-bit data value, 0x00000002 to the second, 0x00000004 to the third, and so on, until all addresses are written. It then reads the block of memory to verify that the data was written correctly. Next, it writes a sec- ond pattern starting with data values 0x00000002, 0x00000004, etc. and verifies the data in the same way. In all, the test writes 32 patterns to the block of memory. If errors are detected, only the first 18 are displayed. The pattern test repeats with a rotating zero this time, rather than a one. And Basic Operation 10-5 finally, the test writes a unique address value to every 32-bit long word to check for address mirrors. i [0 1] Enable [1] or disable [0] the L1 instruction cache. m Attempt to initialize the stack and monitor data, and start the monitor without executing the powerup/reset diagnostics. ## 10.2 Basic Operation The BajaPPC-750 monitor performs various configuration tasks upon power-up or reset. This section describes the monitor operation as it relates to these specific tasks and the memory initialization. The flowcharts beginning on page 9 illustrate the power-up/reset sequence (bold texts in flowcharts indicate NVRAM parameters). ## 10.2.1 Power-Up/Reset Sequence At power-up or board reset, the monitor performs hardware initialization, diagnostics, autoboot procedures, free memory initialization, and if necessary, invokes the command-line editor. #### Power-up sequence: If an unexpected interrupt occurs before the console port is ready, the LED flashes "E", followed by the exception number. If the exception number is "2", then the LED displays: "A" for machine check detected, "B" for transfer error acknowledge detected, "C" for data parity error, or "D" for address parity error. - 1. Initialize the MPC106 and turn off the LED display. - 2. Read the Board Configuration Register to determine power-up or reset. - 3. Write a "1" to the LED display. Check the decrementer function. The counter/timer test flag (Table 10-1) reports failures. If this first step fails, the LED display flashes "1" continuously. - 4. Write a "2" to the LED display. Test the PCI to ISA bridge connection with a rotating bit test of the DMA scatter/gather register at address $FE00,0420_{16}$ . If an error is detected, the LED display will flash "A" (address), "B" (data read), and "C" (data written). - 5. Write a "3" to the LED display. Activiate serial port 1 on the Ultra I/O controller. - 6. Write a "4" to the LED display. Perform a rotating bit test on the scratch register of the UART. If an error is detected, the LED display will flash "A" (address), "B" (data read), and "C" (data written). - 7. Write a "5" to the LED display. Initialize the serial port for 9600 baud and check for a pressed key. If a "d" key is pressed, start the debugger. If an "s" key is pressed, skip the diagnostics, **nvopen**, and **configboard**, and use the default NVRAM parameters. If no key is pressed, or if any other key is pressed, then read NVRAM parameters to determine if diagnostics should be executed and if parity should be enabled. - 8. Turn off the LED display and print the monitor version number. If memory parity was requested, set memory to read-modify-write mode. - 9. Enable the L1 instruction cache. - 10. Print a test hexadecimal number. Print the memory size (read from the Board Configuration Register). - 11. Write a "7" to the LED display. Check timebase timer function. Counter/timer test flag (Table 10-1) reports failures. If an error occurs, the debugger starts. - 12. Write an "8" to the LED display. Write and read locations 0x40000 and 0x4000004 with the data pattern 0x05050a0a and its complement. DRAM data test flag (Table 10-1) reports failures. If a failure occurs, the monitor displays the failed address, followed by the incorrect data and the expected data; then the debugger starts. - 13. Write a "9" to the LED display. Perform a rotating bit test on all address boundaries with parity disabled. Then initialize the address boundaries by writing each long word with its own address. DRAM data test flag (table) reports failures. If a failure occurs, the monitor displays the failed address, followed by the incorrect data and the expected data, and the debugger starts. - 14. Write an "A" to the LED display. If the parity SDRAMs are installed and memory parity is requested, test the ability to detect bad parity. Write a value with even parity to address 0x4000. Then with parity generation turned off, change the data to odd parity. Reading the value at the address should cause a parity error. If an error occurs, the debugger starts. - 15. Write a "B" to the LED display. If the parity SDRAMs are installed and memory parity is requested, enable parity checking; then write and read offset 0x40000 and 0x40004 in each memory bank with data patterns that have opposite byte parity (i.e., 0x01030103 and 0x03010301). The DRAM data and - DRAM parity test flags (Table 10-1) report failures. If an error occurs, the test attempts to determine which byte lanes failed the parity test. Afterwards, the diagnostics continue with parity disabled. - 16. Write a "C" to the LED display. Perform a rotating bit test on the first 0x40000 of memory required by the monitor. If a data error occurs, the debugger starts. If a parity error occurs, the test displays the error and continues the test with parity disabled. - 17. If the parity SDRAMs are installed and memory parity is requested, enable parity checking; then initialize the lower 0x40000 of memory by writing each long word with its own address. Verify the data written. The DRAM data test flag (Table 10-1) reports failures. If a data error occurs, the monitor displays the failed address, followed by the incorrect data and the expected data, and the debugger starts. If a parity error occurs, the test displays the error and continues the test with parity disabled. Note: this test is performed if memory parity is enabled in the NVRAM parameters, even if the diagnostics are disabled. To avoid erasing memory, disable both diagnostics and parity in the NVRAM parameters. - 18. Initialize at system level to set up for running compiled C code. Enable machine checks in the MPC106 and initialize BSS. Relocate the dynamic data section from ROM to its linked address space starting at 0x2000. Initialize the stack pointer to 0x1FFF8. - 19. If an "s" key was not pressed on the serial port, load NVRAM data into memory and configure board according to the parameters in NVRAM. If NVRAM is invalid or the monitor detected a pressed key, load the default parameters into memory. (See Table 10-3 for default NVRAM parameters.) In either case, the actual NVRAM contents are left unchanged and may be edited with **nvdisplay**, followed by **nvupdate**. - Finally, configure the serial port with the parameters that were loaded into memory. - 20. Initialize the RAM-based interrupt vector table. Change the interrupt prefix to point to the RAM-based interrupt table at 0x00000000. Initialize the MPC106 error registers, interrupt handler table, and timebase register. - 21. Store the results of the power-up diagnostics at an offset of 0x60 in NVRAM. To read the PASS/FAIL flags, do four byte reads from the NVRAM at 0x60, 0x61, 0x62, and 0x63. The byte at 0x60 should contain the magic number 0xa5 indicating that the device is functional and that PASS/FAIL reporting is supported. The values for the long word when a failure occurs are listed in Table 10-1. Device Value Read on Failure **Monitor Test Command** Console Serial Port 0xa5000001 serialtest Counter/Timer 0xa5000002 itc\_test Real Time Clock 0xa5000004 FPU 0xa5000008 Cache 0xa5000010 cachetest NVRAM 0xa5000020 nvramtest Flash 0xa5000040 flashtest **Ethernet Port** 0xa5000080 ethertest Download Serial Port 0xa5000100 serialtest Table 10-1. Power-up Diagnostic PASS/FAIL Flags 22. Initialize the free memory pool. **DRAM Parity** **DRAM Data** 23. Execute the **configboard** function if the "s" key was not pressed. If DoPCIConfig is set in NVRAM, **configboard** maps the base addresses of PCI devices. It then configures the MMU and caches. If diagnostics are enabled in NVRAM, **configboard** performs an address mirror test on system memory above address 0x40000. This test also executes (even when diagnostics are not enabled) if the board contains SDRAM parity and it is enabled with the MemParity NVRAM parameter. 0xa5000200 0xa5000400 - 24. If PowerUpDiags or ResetDiags is set in NVRAM, execute and display the results of the following power-up diagnostics on the console: cache, counter/timer, Ethernet controller, and serial port tests. Display errors on the console. The NVRAM flag (Table 10-1) reports any failures. - 25. Branch execution to StartMonitor, which checks the boot device. If a boot device (BootDev) is specified, begin the countdown to autoboot. After the countdown, boot from the selected device. If boot device is "none", the user interrupts the countdown by pressing "H", or any powerup tests fail and HaltOnFailure NVRAM boot parameter is set, skip the autoboot and start the line editor. Basic Operation 10-9 Figure 10-2. Monitor Startup Flowchart (1 of 4) Figure 10-3. Monitor Startup Flowchart (2 of 4) Basic Operation 10-11 Figure 10-4. Monitor Startup Flowchart (3 of 4) Figure 10-5. Monitor Startup Flowchart (4 of 4) # 10.2.2 Initializing Memory The monitor uses the area between $0000,0000_{16}$ and $0003,0000_{16}$ for stack and uninitialized-data space. *CAUTION.* Any writes to that area can cause unpredictable operation of the monitor. The monitor initializes the on-board memory by writing each long word with its own address to prevent subsequent parity errors. If either of the NVRAM parameters "PowerUpMemClr" or "ClrMemOnReset" are set, the monitor will then clear the memory pool, depending upon the state of the board (powerup or reset). It is left up to the programmer to initialize any other accessible memory areas, such as off-card or module memory. ## 10.3 Monitor Command Reference This section describes the syntax and typographic conventions for the BajaPPC-750 monitor commands. Subsequent sections in this chapter describe the individual commands, which fall into the following categories: boot, memory, flash, NVRAM, test, remote host, arithmetic, and other commands. **NOTE.** The BajaPPC-750 monitor performs argument checking for commands, but not for functions. (Please see Section 10.13 for function reference.) ## 10.3.1 Command Syntax Each command may be typed with the shortest number of characters that uniquely identify the command. For example, you can type **nvd** instead of **nvdisplay**. (There is no distinction between uppercase and lowercase.) Note, however, that abbreviated command names cannot be used with on-line help; you must type **help** and the full command name. Press Enter or Return (carriage return <cr>) to execute a command. - The command line accepts three argument formats: string, numeric, and symbolic. Arguments to commands must be separated by spaces. - Monitor commands that expect numeric arguments assume a default base for each argument. However, the base can be altered or specified by entering a colon (:) followed by the base. Several examples are provided below. 1234ABCD:16 hexadecimal 123456789:10 decimal 1234567:8 octal 101010:2 binary - The default numeric base for functions is hexadecimal. Some commands use a different default base. - String arguments must start and end with double quotation marks ("). For example, typing the argument "Foo" would result in a string argument with the value Foo, which is passed to the command. - A character argument is a single character that begins and ends with a single quotation mark ('). The argument 'A' would result in the character A being passed to the command. - A flag argument is a single character that begins with a hyphen (-). For example, the flag arguments -b, -w, or -l could be used for a byte, word, or long flag. There is a symbol entry for every function and command defined in the monitor. Each command must begin with a symbol. Commands are type-checked and argument-validated, but functions are not checked in any way. Commands that are not symbolic are assumed to be numeric, and the hexadecimal, decimal, octal, and binary value of the number is printed. # 10.3.2 Typographic Conventions In the following command descriptions, *italic* type indicates that you must substitute your own selection for the italicized text. Square brackets [] enclose selections from which you must choose one item. ## 10.4 Boot Commands The boot commands provide facilities for booting application programs from various devices. They disable the data cache before calling the application. ### 10.4.1 bootbus bootbus is an autoboot device that allows you to boot an application program over a bus interface. This command is used for fast downloads to reduce development time. ## **DEFINITION** void BootBus(void) Boot Commands 10-15 **bootbus** uses the "LoadAddress" field from the nonvolatile memory definitions group 'BootParams' (see Table 10-3) as the base address of a shared memory communications structure, described below: ``` struct BusComStruct { unsigned long MagicLoc; unsigned long CallAddress; }; ``` The structure consists of two unsigned long locations. The first is used for synchronization, and the second is the entry address of the application. The sequence of events used for loading an application is described below: - 1. The host board waits for the target (this board) to write the value 0x496d4f6b (character string "ImOk") to "MagicLoc" to show that the target is initialized and waiting for a download. - 2. The host board downloads the application to the target board, writes the start address to "CallAddress," and then writes 0x596f4f6b (character string "YoOk") to "MagicLoc" to show that the application is ready for the target. - 3. Target writes value 0x42796521 (character string "Bye!") to "MagicLoc" to show that the application was found. The target then calls the application at "CallAddress." When the application is called, four parameters are passed to the application from the nonvolatile memory boot configuration section. The parameters are seen by the application as shown below: ``` Application(unsigned char Device, unsigned char Number, unsigned long RomSize, unsigned long RomBase) ``` These parameters allow multiple boards using the same facility to receive configuration information from the monitor. Also refer to the function **BootUp** in Section 10.15.2. ## 10.4.2 booteprom booteprom is an autoboot device that allows you to boot an application program from EPROM. It starts execution of the application at "RomBase," read from the non-volatile memory group 'BootParams.' ``` void BootEPROM(void) ``` In order for the monitor to jump to the start of the program, the first long word of the EPROM image must contain a branch link ( $\bf bl$ ) instruction of the form 0100,10xx,xxxx,xxxx,xxxx,xxxx,xxxx,xxx1<sub>2</sub>. You can avoid jumping to an EPROM, even if a valid one is present, by changing the nonvolatile configuration parameter "BootDev" to something other than EPROM. Also refer to the function **BootUp** in Section 10.15.2. ## 10.4.3 **bootrom** bootrom is an autoboot device that allows you to boot an application program from ROM. It copies code from ROM into RAM and then jumps to the RAM address. The ROM source address "RomBase," the RAM destination address "LoadAddress," and the number of bytes to copy "RomSize" are read from the nonvolatile memory group 'BootParams.' #### **DEFINITION** ``` void BootROM(void) ``` When the application is called, two parameters are passed to the application from the nonvolatile memory group 'BootParams.' The parameters are seen by the application as shown below: ``` Application (unsigned char Device, unsigned char Number) ``` There are no arguments for this command. The nonvolatile configuration is modified with the NVRAM commands **nvdisplay** and **nvupdate**. Also refer to the function **BootUp** in Section 10.15.2. ## 10.4.4 bootflash bootflash is an autoboot device that allows you to boot an application program from any 512k flash page. The "BankSelect" parameter in the nonvolatile memory group 'BootParams' sets the Flash Bank Select Register to open the specified flash bank, which will be visible in the 512k window at address FF88,0000 $_{16}$ . If the "CopyToLoadAdr" parameter is true, the "RomSize" (number of bytes to copy) of the application code is copied from the "RomBase" (ROM source address) to the "LoadAddress" (RAM destination address). The application is called at "LoadAddress." If the "CopyToLoadAdr" parameter is false, then the application code is called at "RomBase." Boot Commands 10-17 #### **DEFINITION** ``` void BootFlash(void) ``` When the application is called, two parameters are passed to the application from the nonvolatile memory group 'BootParams.' The parameters are seen by the application as shown below: ``` Application(unsigned char Device, unsigned char Number) ``` There are no arguments for this command. The nonvolatile configuration is modified with the NVRAM commands **nvdisplay** and **nvupdate**. Also refer to the function **BootUp** in Section 10.15.2. ## 10.4.5 bootserial bootserial is an autoboot device that allows you to boot an application program from a serial port. ### **DEFINITION** ``` void BootSerial(void) ``` It determines the format of the download and the entry execution address of the downloaded application from the "LoadAddress" and "DevType" fields in the nonvolatile memory group 'BootParams.' The "DevType" field selects one of the download formats specified below: Table 10-2. Device Download Formats | Device Type | Download Format | | |---------------|-----------------------------------------------|--| | INT_MCS86 0 | Intel MCS-86 Hexadecimal Format | | | MOT_EXORMAT 1 | Motorola Exormax Format (S0-S3,S7-S9 Records) | | | HK_BINARY 2 | Artesyn Binary Format | | The nonvolatile configuration is modified with the NVRAM commands **nvdisplay** and **nvupdate**. When the application is called, three parameters are passed to the application from the nonvolatile memory boot configuration section. The parameters are seen by the application as shown below: ``` Application(unsigned char Number, unsigned long RomSize, unsigned long RomBase) ``` These parameters allow multiple boards using the same facility to receive different configuration information from the monitor. Also refer to the function **BootUp** in Section 10.15.2. # 10.5 Memory Commands The memory commands provide facilities for manipulating specific regions of the memory. For some memory commands, the data size is determined by the following flags: **-b** for data in 8-bit bytes -w for data in 16-bit words -I for data in 32-bit long words ### 10.5.1 checksummem checksummem *source bytecount* reads *bytecount* bytes starting at address *source* and computes the checksum for that region of memory. The checksum is the 16-bit sum of the bytes in the memory block. ### **DEFINITION** ## 10.5.2 clearmem clearmem destination bytecount clears bytecount bytes starting at address destination. ### **DEFINITION** # 10.5.3 cmpmem cmpmem *source destination bytecount* compares *bytecount* bytes at the *source* address with those at the *destination* address. Any differences are displayed. Memory Commands 10-19 # 10.5.4 copymem copymem *source destination bytecount* copies *bytecount* bytes from the *source* address to the *destination* address. ### **DEFINITION** # 10.5.5 displaymem displaymem startaddr lines displays memory in 16-byte lines starting at address startaddr. The number of lines displayed is determined by lines. If the lines argument is not specified, sixteen lines of memory are shown. The data is displayed as hex character values on the left and printable ASCII equivalents on the right. Nonprintable ASCII characters are printed as a dot. Press any key to interrupt the display. If the previous command was **dis-playmem**, pressing <cr>> displays the next block of memory. ### **DEFINITION** ### 10.5.6 fillmem fillmem - [b, w, 1] *value startaddr endaddr* fills memory with *value* starting at address *startaddr* to address *endaddr*. For example, to fill the second megabyte of memory with the data 0x12345678 type: ``` fill -1 12345678 100000 200000 ``` ### 10.5.7 findmem findmem - [b,w,1] searchval startaddr endaddr searches memory for a value from address startaddr to address endaddr for memory locations specified by the data searchval. ### **DEFINITION** ## 10.5.8 findnotmem findnotmem - [b, w, 1] searchval startaddr endaddr searches from address startaddr to address endaddr for memory locations that are different from the data specified by searchval. ### **DEFINITION** ## 10.5.9 findstr findstr searchstr startaddr endaddr searches from address startaddr to address endaddr for a string matching the data string searchstr. ### **DEFINITION** ## 10.5.10 readmem readmem - [b,w,1] *address* reads a memory location specified by *address*. This command displays the data in hexadecimal, decimal, octal, and binary format. Memory Commands 10-21 ### 10.5.11 setmem setmem - [b, w, 1] *address* allows memory locations to be modified starting at *address*. **setmem** first displays the value that was read. Then you can type new data for the value or leave the data unchanged by entering an empty line. If you press <cr>> after the data, the address counts up. If you press <ESC> after the data, the address counts down. To quit this command type any illegal hex character. ### **DEFINITION** # 10.5.12 swapmem swapmem *source destination bytecount* swaps *bytecount* bytes at the *source* address with those at the *destination* address. #### **DEFINITION** ### 10.5.13 testmem testmem *startaddr endaddr* performs a nondestructive memory test from *startaddr* to *endaddr*. If *endaddr* is zero, the address range is obtained from the functions *MemBase* and *MemTop*. The memory test can be interrupted by pressing any character. This command can be used to verify memory (DRAM). It prints the progress of the test and summarizes the number of passes and failures. Also refer to the functions *MemBase* and *MemTop* in Section 10.15.15. ### 10.5.14 um um - [b, w, 1] base\_addr top\_addr performs a destructive memory test from base\_addr to top\_addr. This is done by first clearing all memory in the range specified, doing a rotating bit test at each location, and finally filling each data location with its own address. If top\_addr is zero, the address range is obtained from the functions **MemBase** and **MemTop**. This command prints the progress of the test and summarizes the number of passes and failures. The memory test can be interrupted at the start of the next pass by pressing any character. Also refer to the functions *MemBase* and *MemTop* in Section 10.15.15. ### **DEFINITION** ``` int UM(char flag, unsigned long l_limit, unsigned long u limit) ``` ### 10.5.15 writemem writemem - [b, w, 1] *address value* writes *value* to a memory location specified by *address*. ### **DEFINITION** ### 10.5.16 writestr writestr "string" address writes the ASCII string specified by string to a memory location specified by address. The string must be enclosed in double quotes (" "). Flash Commands 10-23 ## 10.6 Flash Commands The flash commands affect the User Flash devices on the BajaPPC-750 circuit board. They return zero upon successful completion of the operation, or –1 upon failure. The flash commands protect the monitor code after it is copied into the flash memory. If jumper J6 is installed, attempts to write to the 512-kilobyte range above $FF90,0000_{16}$ return an error. (The monitor boots from this address.) Similarly, writes to $FF88,0000_{16}$ are prohibited when Bank 0 is set by the Flash Bank Select register (refer to Register Map 4-1). If jumper J6 is not installed, the monitor code still can be installed in flash Bank 0 and addressed at $FF80,0000_{16}$ . The commands described in sections 10.6.5 through 10.6.7 only affect the 32-megabyte flash devices. ## 10.6.1 flashblkwr flashblkwr source destination bytecount writes bytecount from the source address to the destination address (flash memory). **flashblkwr** calls **flasheraseblk** to erase the block(s) it will write to. In the event of a write or erase error, it calls **flashclrstat**. ### **DEFINITION** ## 10.6.2 flashbytewrite flashbytewrite *destination value* writes *value* to the byte at the *destination* address. ### **DEFINITION** ### 10.6.3 flashclrstat flashclrstat *destination* resets the status register of the flash memory that contains the *destination* address. ``` void FlashClrStat(unsigned char *FlashAddr) ``` ### 10.6.4 flasheraseblk flasheraseblk *destination* erases a 64-kilobyte block of flash memory that contains the *destination* address. ### **DEFINITION** int FlashEraseBlk(unsigned char \*FlashAddr) ### 10.6.5 wideflashblkwr wideflashblkwr source destination bytecount writes bytecount from the source address to the destination address (64-bit wide flash memory). All accesses must be 64-bits wide, so bytecount must be a multiple of 8 bytes. wideflashblkwr calls wideflasheraseblk to erase the block(s) it will write to. In the event of a write or erase error, it calls wideflashclrstat. ### **DEFINITION** ### 10.6.6 wideflashclrstat wideflashclrstat *destination* resets the status registers of the 64-bit wide flash memory that contains the *destination* address. ### **DEFINITION** void WideFlashClrStat(void \*FlashAddr) # 10.6.7 wideflasheraseblk wideflasheraseblk *destination* erases a 512-kilobyte block of wide flash memory that contains the *destination* address. ### **DEFINITION** int WideFlashEraseBlk(void \*FlashAddr) NVRAM Commands 10-25 ## 10.6.8 rewritemonitor rewritemonitor overwrites the monitor software in the onboard soldered flash device with a new monitor image. It asks you for a source address and the size of the new monitor image. Once invoked, the function gives you two opportunities to exit without modifying the onboard flash. CAUTION. This function cannot recover from a failed write to the flash device. If a failure does occur, it cannot print an error and the monitor may no longer be able to boot the board. To recover, you would have to rewrite the monitor from a socketed flash device using the flashblkwr function. ### **DEFINITION** int ReWriteMonitor(void) ## 10.7 NVRAM Commands The monitor uses on-board NVRAM for nonvolatile memory. A memory map is given in Table 4-5, earlier in this manual. Portions of this nonvolatile memory are reserved for factory configuration and identification information and the monitor. The nonvolatile memory support commands deal only with the monitor- and Artesyn-defined sections of the nonvolatile memory. The monitor-defined sections are readable and writeable and can be modified by the monitor. # 10.7.1 nvdisplay nvdisplay is used to display the Artesyn-defined and monitor-defined nonvolatile sections. The nonvolatile memory configuration information is used to completely configure the BajaPPC-750 at reset. The utility command **configboard** can also be used to reconfigure the board after modifications to the nonvolatile memory. ## **DEFINITION** void NVDisplay(void) The configuration values are displayed in groups. Each group has a number of fields. Each field is displayed as a hexadecimal or decimal number, or as a list of legal values. To display the next group, press <space> or <cr>. To edit fields within the displayed group, press E. To quit the display, press <ESC> or Q. To save the changes, type the command **nvupdate**. To quit without saving the changes, type the command **nvopen**. Table 10-3 shows all the groups and fields you can edit with the **nvdisplay** command. **Table 10-3. NVRAM Configuration Groups** | Group | Fields | Purpose | Artesyn<br>Default | Optional Values | | |---------|----------------|--------------------------------------------------------------------------------|--------------------|-----------------------------------------------------------------|--| | Console | Console | | | | | | | Port | Select communications port | A (Console) | (A, B) | | | | Baud | Select baud rate | 9600 | (1200, 2400, 4800,<br>9600, 19200, 38400,<br>56000, 128000 bps) | | | | Parity | Select parity type | None | (Even, Odd, None,<br>Force) | | | | Data | Select the number of data bits for transfer | 8-Bits | (5-Bits, 6-Bits, 7-Bits, 8-Bits) | | | | StopBits | Select the number of stop bits for transfer | 1-Bit | (1-Bit, 2-Bits) | | | | ChBaudOnBreak | Break character causes baud rate change | False | (True, False) | | | | RstOnBreak | Break character causes reset | False | (True, False) | | | Downloa | ad | | | | | | | Port | Select communications port | B (Down-<br>load) | (A, B) | | | | Baud | Select baud rate | 9600 | (1200, 2400, 4800,<br>9600, 19200, 38400,<br>56000, 128000 bps) | | | | Parity | Select parity type | None | (Even, Odd, None,<br>Force) | | | | Data | Select the number of data bits for transfer | 8-Bits | (5-Bits, 6-Bits, 7-Bits, 8-Bits) | | | | StopBits | Select the number of stop bits for transfer | 1-Bit | (1-Bit, 2-Bits) | | | | ChBaudOnBreak | Break character causes baud rate change | False | (True, False) | | | | RstOnBreak | Break character causes reset | False | (True, False) | | | VMEBus | | | | | | | | ExtSlaveMap | Provide VME extended base address for slave access | 0x80000000 | (See Universe Manual) | | | | ExtSlaveOffset | Allow access to any region in the board's memory map (address = zero + offset) | 0x0 | (memory range) | | NVRAM Commands 10-27 Table 10-3. NVRAM Configuration Groups — Continued | Group | Fields | Purpose | Artesyn<br>Default | Optional Values | |---------|----------------|---------------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------| | | ExtMastOffset | Set offset for extended space master access (address = base + offset) | 0x0 | (memory range) | | | ExtEnabled | Enable extended slave map on the VMEbus | False | (True, False) | | | StdSlaveMap | Define A24 slave base address | 0x200000 | See Universe Manual | | | StdSlaveOffset | Allow access to any region in the board's memory map (address = zero + offset) | 0x0 | (memory range) | | | StdMastOffset | Set offset for standard<br>space master access<br>(address = base + offset) | 0x0 | (memory range) | | | StdEnabled | Enable standard slave map on the VMEbus | False | (True, False) | | | BusReqLev | Define VMEbus request level (BR3 = lowest priority) | BR3 | (BRO, BR1, BR2, BR3) | | | MastRelModes | Define how the board terminates its bus tenure | OnRequest | (WhenDone,<br>OnRequest, Never) | | | VmeBusTimer | Internal timer. DTACK must be received before this timer expires | 64µs | (4µs, 16µs, 32µs, 64µs,<br>128µs, 256µs, 512µs,<br>Off) | | | ArbiterMode | Select the arbiter mode | RoundRobin | (RoundRobin, Priority) | | | SlaveWrPost | Enhance performance of<br>PCI transfers to/from VME-<br>bus (delayed error reporting<br>when turned on) | Off | (Off, On) | | | MasterWrPost | Enhance performance of<br>PCI transfers to/from VME-<br>bus (delayed error reporting<br>when turned on) | Off | (Off, On) | | | Sysfail | Allow SYSFAIL negation after power-up | Off | (Off, On) | | | IndivRMC | Allow all VME slave transactions to assert LOCK# on the PCI bus | Off | (Off, On) | | MailBox | | | • | | | | VRAIShtMap | Define A16 VME slave address | 0xf000 | See Universe Manual | | | VRAIEnabled | Enable mailbox / register image | False | (True, False) | Table 10-3. NVRAM Configuration Groups — Continued | Group | Fields | Purpose | Artesyn<br>Default | Optional Values | |---------|---------------------|--------------------------------------------------------------------|--------------------|---------------------------------------------------| | Cache | | I | | | | | InstrCache | Turn instruction cache on or off | On | (On, Off) | | | DataCache | Turn data cache on or off | On | (On, Off) | | | CacheMode | Select the cache mode | Copyback | (Writethru, Copyback) | | | L2State | Enable or disable L2 Cache | On | (On, Off) | | | SkipMMUConfig | Enable or disable MMU configuration | False | (True, False) | | Misc | | | | | | | PowerUpMemClr | Clear memory on power-up | False | (True, False) | | | ClrMemOnReset | Clear memory on reset | False | (True, False) | | | PowerUpDiags | Run diagnostics on power-<br>up | On | (On, Off) | | | ResetDiags | Run diagnostics on reset | Off | (On, Off) | | | MemParity | Request memory parity (no effect if parity is not installed) | On | (On, Off) | | | ThermProtect | Put CPU in sleep mode when its temperature exceeds 100° C. | Off | (On, Off) | | | CountValue | Choose shortest (0) to longest (7) duration for autoboot countdown | 1 | (0, 1, 2, 3, 4, 5, 6, 7) | | | DoPCIConfig | Configure module | True | (True, False) | | Networl | k (future use only) | | <u> </u> | <u></u> | | | BoardIPAddr | IP address of board | 0.0.0.0 | <i>x.x.x.x</i> ; where $0 \le x \le 255$ | | | HostIPAddr | IP address of host | 0.0.0.0 | <i>x.x.x.x</i> ; where $0 \le x \le 255$ | | | GatewaylPAddr | IP address of gateway | 0.0.0.0 | <i>x.x.x.x</i> ; where $0 \le x \le 255$ | | | GatewayMask | Gateway mask | 0.0.0.0 | <i>x.x.x.x</i> ; where $0 \le x \le 255$ | | | DoEtherInit | Initialize network interface upon boot | False | (True, False) | | BootPar | ams | | 1 | | | | BootDev | Select boot device | EPROM | (None, Serial, ROM, Bus, Stos, EPROM) | | | LoadAddress | Define load address | 0x40000 | See <i>User Manual</i> | | | RomBase | Define ROM base | 0xff800000 | Used only when BootDev is defined as ROM or EPROM | | | RomSize | Define ROM size | 0x80000 | Used only when BootDev is defined as ROM | | | DevType | Define device type | 0 | Depends on the application | NVRAM Commands 10-29 Artesyn Group **Fields Purpose Optional Values** Default DevNumber Define device number 0 Depends on the application ClrMemOnBoot Clear memory on boot False (True, False) HaltOnFailure True Halt if a failure occurs (True, False) CopyToLoadAddr Copies from RomBase to False (True, False) LoadAddr (BootFlash only) BankSelect Selects user flash bank con-1 (0, 1, 2, 3, 4, 5, 6, 7) taining the application (BootFlash only) HardwareConfig, Manufacturing, Service Reserved for use by Artesyn Communicaton Products manufacturing. Table 10-3. NVRAM Configuration Groups — Continued ### **EXAMPLE** 1. At the monitor prompt, type: nvdisplay 2. Press <cr> until the group you want to modify is displayed. An example for the group "Console" is shown below. ``` Group 'Console' Port Baud 9600 Parity None (Even, Odd, None, Force) 8-bits (5-Bits, 6-Bits, 7-Bits, 8-Bits) Data StopBits 2-bits (1-Bit, 2-Bits) ChBaudOnBreak False (False, True) RstOnBreak False (False, True) [SP, CR to continue] or [E, e to Edit] ``` - 3. Press E to edit the group. - 4. Press <cr> until the field you want to change is displayed. - 5. Type a new value. For most fields, legal options are displayed in parentheses. - 6. Press <ESC> or **Q** to quit the display. - 7. Type **nvupdate** to save the new value or **nvopen** to cancel the change by reading the old value. ### 10.7.2 nvinit nvinit *sernum "revlev" ecolev writes* is used to initialize the nonvolatile memory to the default state defined by the monitor. First **nvinit** clears the memory and then writes the Artesyn and monitor data back to memory. It also saves the changes in NVRAM. CAUTION. **nvinit** clears any values you have changed from the default. Use **nvinit** only if the nonvolatile configuration data structures might be in an unknown state and you must return them to a known state. sernum serial number revlev revision level ecolev standard ECO level writes the number of writes to nonvolatile memory ### **DEFINITION** ## 10.7.3 nvopen nvopen reads and checks the monitor and Artesyn-defined sections. If the non-volatile sections are not valid, an error message is displayed. ## **DEFINITION** ``` int NVOpen(void) ``` ### 10.7.4 nvset nvset *group field value* is used to modify the Artesyn-defined and monitor-defined nonvolatile sections. To modify the list with the **nvset** command, you must specify the group and field to be modified and the new value. The group, field, and value can be abbreviated, as in the following examples: ``` nvset console port A nvset con dat 6 ``` **NOTE.** The nonvolatile memory support commands provide the interface to the nonvolatile memory. The nonvolatile commands deal only with the monitor- and Artesyn-defined sections of the nonvolatile memory. NVRAM Commands 10-31 The monitor-defined sections of nonvolatile memory are readable and writeable and can be modified by the monitor. The Artesyn-defined section of nonvolatile memory is also readable and writeable, but should not be modified. ### **DEFINITION** # 10.7.5 nvupdate nvupdate attempts to write the Artesyn- and monitor-defined nonvolatile sections back to the NVRAM device. First the data is verified, and then it is written to the device. The write is verified and all errors are reported. ### **DEFINITION** void NVUpdate(void) # 10.7.6 Default Boot Device Configuration Example The default boot device is defined in the nonvolatile memory group 'Boot-Params,' in the field "BootDev." When the BajaPPC-750 is reset or powered up, the monitor checks this field and attempts to boot from the specified device. Currently, the monitor supports Serial, ROM, Bus, EPROM, Flash, and Stos as standard. If you edit the "BootDev" field and define a device that is unsupported on your board, the monitor will display the message: ``` Unknown boot device ``` Defining "BootDev" as: "Serial" calls **bootserial**, "ROM" calls **bootrom**, "Bus" calls **bootbus**, "EPROM" calls **booteprom**, "Flash" calls **bootflash**, and "Stos" calls **stos\_boot**. See the "Boot Commands", Section 10.4 for details on these commands. ### **EXAMPLE** In this example, **nvdisplay** and **nvupdate** are used to change the default boot device from the bus to the ROM. The changes are made to the 'BootParams' group. NOTE. The fields in the 'BootParams' group have different meanings for each device. For example, "DevType" values are not used for Bus devices, but are used by Serial devices to select the format for downloading. 1. At the monitor prompt, type: ``` nvdisplay ``` 2. Press <cr> until the 'BootParams' group is displayed. ``` Group 'BootParams' BootDev Bus (None, Serial, ROM, Bus, EPROM, Stos) LoadAddress 0x40000 ROMBase 0xfff30000 ROMSize 0x40000 DevType 1 DevNumber 0 ClrMemOnBoot False(False, True) [SP, CR to continue] or [E, e to Edit] ``` - 3. Press E to edit the group. - 4. Press <cr> until the "BootDev" field is displayed. - 5. Type the new value "ROM." - 6. Press <cr> to display the "LoadAddress" field. - 7. Type the address where execution begins. - 8. Press <cr> to display the "ROMBase" field. - 9. Type the ROM base address. - 10. Press <cr>> to display the "ROMSize" field. - 11. Type the ROM size. - 12. Press <ESC> or **Q** to quit the display. - 13. Type **nvupdate** to save the new values. ## **EXAMPLE** In this example, **nvdisplay** and **nvupdate** are used to change the default boot device from the bus to the serial port. The changes are made to the 'BootParams' group. 1. At the monitor prompt, type: ``` nvdisplay ``` 2. Press <cr> until the 'BootParams' group is displayed. NVRAM Commands 10-33 - 3. Press E to edit the group. - 4. Press <cr> until the "BootDev" field is displayed. - 5. Type the new value "Serial." - 6. Press <cr> until the "DevType" field is displayed. - 7. Type the new value for "DevType"; for example, 2 selects downloads in Artesyn binary format. - 8. Edit any other fields you want to modify. Whether you use the "DevType" and "DevNumber" fields depends on the application. - 9. Press <ESC> or **Q** to quit the display. - 10. Type **nvupdate** to save the new values. # 10.7.7 Download Port Configuration Example In this example, the NVRAM command **nvdisplay** changes fields in the 'Download' group, which contains fields for port selection, baud rate, parity, number of data bits, and number of stop bits: 1. At the monitor prompt, type: nvdisplay - 2. Press <cr> until the 'Download' group is displayed. - 3. Press E to edit the group. - 4. Press <cr> until the "Baud" field is displayed. - 5. Type a new value. - 6. Change other fields in the same way. - 7. <cr> over all fields whether you edit them or not, until the monitor prompt reappears. - 8. Type **nvupdate** to save the new value. - **NOTE.** A cable reverser might be necessary for the connection. ## 10.8 Test Commands The following on-card functional tests are available to be run any time you desire. The nonvolatile configuration memory can be used to enable or disable the execution of these tests on power-up and reset (see the **nvdisplay** monitor command's Misc group in Table 10-3). The results of the tests are stored at an offset of 0x60 in NVRAM. To read the PASS/FAIL flags, do four byte reads from the ROM at 0x60, 0x61, 0x62, and 0x63. The byte at 0x60 should contain the magic number 0xa5 indicating that the device is functional and that PASS/FAIL reporting is supported. The values for the long word when a failure occurs are listed in Table 10-4. Table 10-4. Test Command PASS/FAIL Flags | Test | Value Read on Failure | Monitor Command | |----------------------|-----------------------|-----------------| | Console Serial Port | 0xa5000001 | serialtest | | Counter/Timer | 0xa5000002 | itctest | | Cache | 0xa5000010 | cachetest | | NVRAM | 0xa5000020 | nvramtest | | Ethernet Port | 0xa5000080 | ethertest | | Download Serial Port | 0xa5000100 | serialtest | ## 10.8.1 itctest itctest tests the operation and accuracy of each of the two counter/timers in both modes. In timer mode, it sets the timer for 100 milliseconds and verifies that a single interrupt occurs 100 milliseconds later. In counter mode, the test counts 100 interrupts at 1-millisecond intervals. ### **DEFINITION** int ITCtest(void) ### 10.8.2 ethertest ethertest checks all the logic necessary to interface the Ethernet controller to the PCI bus in the following manner: - Assures that the Ethernet controller self test can be run without error. - Performs a data line test to ensure that all data line connectivity is intact. - Verifies that data can be transferred successfully with the 82C501 in loopback mode. Test Commands 10-35 - Verifies that Ethernet controller interrupts can be generated, that the CPU responds to the interrupts, and that the interrupt condition can be cleared. - Assures that an Ethernet controller access to a non-responding local bus space results in an ABORT interrupt and that writing to the ABORT-clear address clears the interrupt. Performs a continuous loopback test which causes the Ethernet controller to transmit a frame of data and then generate an interrupt. The interrupt handler verifies the transmitted data and kicks off another transmit command. The test stops after a number of data frames have been transmitted and verified. #### **DEFINITION** void ethertest(void) ## 10.8.3 serialtest serialtest verifies that data can be transmitted and received by the console and download ports. This test operates in internal loopback mode and simultaneously tests serial interrupts. ### **DEFINITION** void serialtest(void) ## 10.8.4 nvramtest nvramtest performs a non-destructive write test at offset 7FF<sub>16</sub> in NVRAM. The NVRAM test command pass/fail flag (Table 10-4) reports any errors. #### **DEFINITION** void nvramtest(void) ## 10.8.5 cachetest cachetest verifies the connectivity of address and data lines to the CPU's backside L2 cache. During the test, modified blocks are not cast out to system memory and instructions are not cached. The test fills the L2 cache with a one-megabyte block of addresses, then performs a rotating bit and address mirror test on all addresses in the test block. After invalidating the contents of the cache, it tests the L2 address tags stored on the PPC750 processor. For unique tag entries, it writes and verifies a series of rotating- one addresses, rotating-zero addresses, and alternating one and zero addresses. The L2 synchronous RAM parity is disabled during the test, and the test restores the L2 cache to the original state when it is finished. ### **DEFINITION** ``` int cachetest (void) ``` ## 10.9 Remote Host Commands The monitor commands **download** and **call** are used for downloading applications and data in hex-Intel format, S-record format, or binary format. Hex-Intel and S-record are common formats for representing binary object code as ASCII for reliable and manageable file downloads. Both formats send data in blocks called records, which are ASCII strings. Records may be separated by any ASCII characters except for the start-of-record characters—"S" for S-records and ":" for hex-Intel records. In practice, records are usually separated by a convenient number of carriage returns, linefeeds, or nulls to separate the records in a file and make them easily distinguishable by humans. All records contain fields for the length of the record, the data in the record, and some kind of checksum. Some records also contain an address field. Most software requires the hexadecimal characters that make up a record to be in uppercase only. ### 10.9.1 call call address arg0 arg1 arg2 arg3 arg4 arg5 arg6 arg7 allows execution of a program after a download from one of the board's interfaces. This command allows up to eight arguments to be passed to the called address from the command line. Arguments can be symbolic, numeric, characters, flags, or strings. The default numeric base is hexadecimal. The function disables and flushes the data cache before branching to the application. If the application wants to return to the monitor, it should save and restore the processor registers. Also, it is important that special-purpose registers remain unchanged. NOTE. The code at vector table locations $300_{16}$ , $1100_{16}$ , and $1200_{16}$ must remain intact, unless you wish to disable or reconfigure the data MMU for other user-defined purposes. ``` int Call(int (*Funct) (), unsigned long Arg0, unsigned long Arg1...) ``` Remote Host Commands 10-37 ### 10.9.2 download download -[b,h,m] address provides a serial download from a host computer to the board. **download** uses binary, hex-Intel, or Motorola S-record format, as specified by the following flags: **-b** binary (address not used) -h hex-Intel (load address in memory = *address* + record address) -m Motorola S-record (load address in memory = *address* + record address) If no flag is specified, the default format is hex-Intel. Refer to Section 10.7.7 for an example of how to configure the download port using NVRAM commands. Sections 10.9.3, 10.9.4, and 10.9.5 describe the download formats in detail. ### **DEFINITION** # 10.9.3 Binary Download Format The binary download format consists of two parts: - Magic number (which is 0x12345670) + number of sections - Information for each section including: the load address (unsigned long), the section size (unsigned long), a checksum (unsigned long) that is the longword sum of the memory bytes of the data section. NOTE. If you download from a UNIX host in binary format, be sure to disable the host from mapping carriage return <cr> to carriage return line feed <cr-lf>. The download port is specified in the nonvolatile memory configuration. ## 10.9.4 Hex-Intel Download Format Hex-Intel format supports addresses up to 20 bits (one megabyte). This format sends a 20-bit absolute address as two (possibly overlapping) 16-bit values. The least significant 16 bits of the address constitute the offset, and the most significant 16 bits constitute the segment. Segments can only indicate a paragraph, which is a 16-byte boundary. Stated in C, for example: ``` address = (segment << 4) + offset;</pre> ``` ``` or segment (ssss) + offset (oooo) = address (aaaaa) ``` For addresses with fewer than 16 bits, the segment portion of the address is unnecessary. The hex-Intel checksum is a two's complement checksum of all data in the record except for the initial colon (:). In other words, if you add all the data bytes in the record, including the checksum itself, the lower eight bits of the result will be zero if the record was received correctly. Four types of records are used for hex-Intel format: extended address record, data record, optional start address record, and end-of-file record. A file composed of hex-Intel records must end with a single end-of-file record. ### **Extended Address Record** ``` :02000002sssscs : is the record start character. 02 is the record length. 0000 is the load address field, always 0000. 02 is the record type. ssss is the segment address field. cs is the checksum. ``` The extended address record is the upper sixteen bits of the 20-bit address. The segment value is assumed to be zero unless one of these records sets it to something else. When such a record is encountered, the value it holds is added to the subsequent offsets until the next extended address record. Here, the first 02 is the byte count (only the data in the *ssss* field are counted). 0000 is the address field; in this record the address field is meaningless, so it is always 0000. The second 02 is the record type; in this case, an extended address record. *cs* is the checksum of all the fields except the initial colon. ### **EXAMPLE** ``` :020000020020DC ``` In this example, the segment address is $0020_{16}$ . This means that all subsequent data record addresses should have $200_{16}$ added to their addresses to determine the absolute load address. # **Data Record** Remote Host Commands 10-39 ``` cs is the checksum. ``` ### **EXAMPLE** ``` :0400100050D55ADF8E ``` In this example, there are four data bytes in the record. They are loaded to address $10_{16}$ ; if any segment value was previously specified, it is added to the address. $50_{16}$ is loaded to address $10_{16}$ , $D5_{16}$ to address $11_{16}$ , $5A_{16}$ to address $12_{16}$ , and $DF_{16}$ to address $13_{16}$ . The checksum is $8E_{16}$ . ### **Start Address Record** ``` :04000003ssssooocs : is the record start character. 04 is the record length. 0000 is the load address field, always 0000. 03 is the record type. ssss is the start address segment. 0000 is the start address offset. cs is the checksum. ``` ## **EXAMPLE** ``` :04000035162000541 ``` In this example, the start address segment is $5162_{16}$ , and the start address offset is $0005_{16}$ , so the absolute start address is $51625_{16}$ . ### **End-of-File Record** ``` : is the record start character. 00 is the record length. 0000 is the load address field, always 0000. 01 is the record type. FF is the checksum. ``` This is the end-of-file record, which must be the last record in the file. It is the same for all output files. ### **EXAMPLE:** Complete Hex-Intel File ``` :080000002082E446A80A6CCE40 :020000020001FB :08000000D0ED0A2744617EFFE8 :040000300010002F6 :04003000902BB4FD60 :00000001FF ``` Here is a line-by-line explanation of the example file: ``` :080000002082E446A80A6CCE40 ``` ``` loads byte 20_{16} to address 00_{16} loads byte 82_{16} to address 02_{16} loads byte E4_{16} to address 02_{16} loads byte 46_{16} to address 03_{16} loads byte A8_{16} to address 04_{16} loads byte 0A_{16} to address 05_{16} loads byte 6C_{16} to address 06_{16} loads byte CE_{16} to address 07_{16} ``` : 020000020001FB sets the segment value to one, so $10_{16}$ must be added to all subsequent load addresses. ### :0800000D0ED0A2744617EFFE8 ``` loads byte \mathrm{DO}_{16} to address \mathrm{10}_{16} loads byte \mathrm{ED}_{16} to address \mathrm{12}_{16} loads byte \mathrm{0A}_{16} to address \mathrm{12}_{16} loads byte \mathrm{27}_{16} to address \mathrm{13}_{16} loads byte \mathrm{44}_{16} to address \mathrm{14}_{16} loads byte \mathrm{61}_{16} to address \mathrm{15}_{16} loads byte \mathrm{7E}_{16} to address \mathrm{16}_{16} loads byte \mathrm{FF}_{16} to address \mathrm{17}_{16} ``` :0400000300010002F6 indicates that the start address segment value is one, and the start address offset value is 2, so the absolute start address is $12_{16}$ . #### :04003000902BB4FD60 ``` loads byte 90_{16} to address 40_{16} loads byte 2B_{16} to address 41_{16} loads byte B4_{16} to address 42_{16} loads byte FD_{16} to address 43_{16}:00000001FF terminates the file. ``` ## 10.9.5 Motorola S-Record Download Format S-records are named for the ASCII character "S," which is used for the first character in each record. After the "S" character is another character that indicates the record type. Valid types are 0, 1, 2, 3, 5, 7, 8, and 9. After the type character is a sequence of characters that represent the length of the record, and possibly the address. The rest of the record is filled out with data and a checksum. The checksum is the one's complement of the 8-bit sum of the binary representation of all elements of the record except the S and the record type character. In other words, if you sum all the bytes of a record except for the S and the character immediately following it with the checksum itself, you should get $FF_{16}$ for a proper record. ### User-Defined (S0) ``` S0 indicates the record type. ``` Remote Host Commands 10-41 ``` nn is the count of data and checksum bytes. d1...dn are the data bytes. cs is the checksum. ``` S0 records are optional, and can contain any user-defined data. ### **EXAMPLE** ``` S008763330627567736D ``` In this example, the length of the field is 8, and the data characters are the ASCII representation of "v30bugs." The checksum is $6D_{16}$ . ## Data Records (S1, S2, S3) ``` S1nnaaaad1d2d3...dncs S2nnaaaaaad1d2d3...dncs S3nnaaaaaaad1d2d3...dncs S1 indicates the record type. nn is the count of address, data, and checksum bytes. a...a is a 4-, 6-, or 8-digit address field. d1...dn are the data bytes. cs is the checksum. ``` These are data records. They differ only in that S1-records have 16-bit addresses, S2-records have 24-bit addresses, and S3-records have 32-bit addresses. ### **EXAMPLES** ``` S10801A00030FFDC95B6 ``` In this example, the bytes $00_{16}$ , $30_{16}$ , $FF_{16}$ , $DC_{16}$ , and $95_{16}$ are loaded into memory starting at address $01A0_{16}$ . ``` S30B30000000FFFF5555AAAAD3 ``` In this example, the bytes $FF_{16}$ , $FF_{16}$ , $55_{16}$ , $55_{16}$ , $AA_{16}$ , and $AA_{16}$ are loaded into memory starting at address $3000,0000_{16}$ . Note that this address requires an S3-record because the address is too big to fit into the address range of an S1-record or S2-record. ### Data Count Records (S5) ``` S5nnd1d2d3...dncs S5 indicates the record type. nn is the count of data and checksum bytes. d1...dn are the data bytes. cs is the checksum. ``` S5-records are optional. When they are used, there can be only one per file. If an S5-record is included, it is a count of the S1-, S2-, and S3-records in the file. Other types of records are not counted in the S5-record. ### **EXAMPLE** ``` S5030343B6 ``` In this example, the number of bytes is 3, the checksum is $B6_{16}$ , and the count of the S1-records, S2-records, and S3-records in the file is $343_{16}$ . ## Termination and Start Address Records (S7, S8, S9) ``` S705aaaaaaaacs S804aaaaaacs S903aaacs S7, S8, or S9 indicates the record type. 05, 04, 03 count of address digits and the cs field. a...a is a 4-, 6-, or 8-digit address field. cs is the checksum. ``` These are trailing records. There can be only one trailing record per file, and it must be the last record in the output file. Included in the data for this record is the initial start address for the downloaded code. ### **EXAMPLES** ``` S903003CC0 ``` In this example, the start address is $3C_{16}$ . ``` S8048000007B ``` In this example, the start address is $800000_{16}$ . ## **EXAMPLE:** Complete S-record File ``` S0097A65726F6A756D707A S10F000000001000000000084EFAFFFE93 S5030001FB S9030008F4 ``` Here is a line-by-line explanation of the example file: S0097A65726F6A756D707A contains the ASCII representation of the string "zerojump." S10F0000000100000000084EFAFFFE93 loads the following data to the following addresses: ``` byte 00_{16} to address 00_{16} byte 00_{16} to address 01_{16} byte 10_{16} to address 02_{16} byte 00_{16} to address 03_{16} byte 00_{16} to address 04_{16} byte 00_{16} to address 05_{16} byte 00_{16} to address 06_{16} byte 00_{16} to address 06_{16} byte 08_{16} to address 07_{16} ``` Arithmetic Commands 10-43 ``` byte 4E_{16} to address 08_{16} byte FA_{16} to address 09_{16} byte FF_{16} to address 0A_{16} byte FE_{16} to address 0B_{16} ``` S5030001FB indicates that only one S1-record, S2-record, or S3-record was sent. \$9030008F4 indicates that the start address is $00000008_{16}$ . # 10.10 Arithmetic Commands The commands in this group allow for basic arithmetic functions to be performed at the command line. ## 10.10.1 add add *number1 number2* adds two integers in hexadecimal, binary, octal, or decimal (default). The default numeric base is decimal. Specify hexadecimal by typing ":16" at the end of the value, octal by typing ":8" or binary by typing ":2." The result of the operation is displayed in hex, decimal, octal, and binary. ## **DEFINITION** # 10.10.2 div div *number1 number2* divides two integers in hexadecimal, binary, octal, or decimal (default). *number1* is divided by *number2*. The command also checks the operation to avoid dividing by zero. The default numeric base is decimal. Specify hex by typing ":16" at the end of the value, octal by typing ":8" or binary by typing ":2." The result of the operation is displayed in hex, decimal, octal, and binary. #### **DEFINITION** ## 10.10.3 mul mul *number1 number2* multiplies two integers in hexadecimal, binary, octal, or decimal (default) from the monitor. The default numeric base is decimal. Specify hex by typing ":16" at the end of the value, octal by typing ":8" or binary by typing ":2." The result of the operation is displayed in hex, decimal, octal, and binary. #### **DEFINITION** ## 10.10.4 rand rand is a linear congruent random number generator that uses a function **Seed** and a variable *Value*. The random number returned is an unsigned long. #### **DEFINITION** ``` unsigned long Rand(void) ``` ## 10.10.5 sub sub *number1 number2* subtracts two integers in hexadecimal, binary, octal, or decimal (default). *number2* is subtracted from *number1*. The default numeric base is decimal. Specify hexadecimal by typing ":16" at the end of the value, octal by typing ":8" or binary by typing ":2." The result of the operation is displayed in hex, decimal, octal, and binary. ## **DEFINITION** # 10.11 Other Commands These commands provide basic configuration and help facilities. ## 10.11.1 configboard configboard configures the board to the state specified by the nonvolatile memory configuration. This includes the serial port, processor caches, VME interface, and the PMC modules, if necessary. Other Commands 10-45 **configboard** can be used to reconfigure the board's various interfaces after modification of the nonvolatile memory configuration (using **nvdisplay** or **nvset**). This command accepts no parameters. ## **DEFINITION** void ConfigBoard() # 10.11.2 config\_PCI config\_PCI determines if any PMC modules or PCI devices are present and, if so, uses software polling to determine their type. The memory and I/O spaces of any installed modules are mapped to default locations—only the base addresses of the PCI devices are initialized. Subsequently, you can use the **PCIshow** command to display the PCI devices and their base addresses on the screen. ## **DEFINITION** void config\_PCI(void) ## 10.11.3 ethernetaddr ethernetaddr returns the Ethernet address of the board in hexadecimal. For a description of the Ethernet address, please refer to Section 7.2. ## **DEFINITION** void EthernetAddr(void) # 10.11.4 getboardconfig getboardconfig displays the contents of the two board configuration registers that specifyy the memory and L2 configurations. #### **DEFINITION** void GetBoardConfig(void) # 10.11.5 help help *name* allows you to view the description of the monitor command specified by *name*. The full name of the command must be given. For instructions on editing command lines, type help editor. For a list of command-line functions, type help functions. For a detailed memory map, type help memmap. ## **DEFINITION** int Help(char \*Name) # 10.12 Command Errors and Screen Messages Most commands return an explanatory message for misspelled or mistyped commands, missing arguments, or invalid values. Table 10-5 lists errors that can be attributed to other causes, especially errors that indicate a problem in the nonvolatile memory configuration. Table 10-5. Error and Screen Messages | Message | Source and Suggested Solution | | |--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Error while clearing NV memory. Error while reading NV memory. | NV memory has become corrupted. Use the <b>nvinit</b> command to restore defaults. If the problem persists, contact Customer Services <sup>1</sup> . | | | Error while storing NV memory. | | | | Hit 'H' to skip auto-boot | Consult the introduction to this chapter for information about power-up conditions. | | | No help for | The topic for help was misspelled or is not available. Check the spelling. If the topic was a command name, use the <b>help</b> command to check the spelling of the command. You must use the full command name, not an abbreviation. | | | Power-up Test FAILED. | A failed test could mean a hardware malfunction.<br>Report the error to Test Services <sup>1</sup> . | | | Unknown boot device. | The boot device is invalid. Use <b>nvdisplay</b> to check and edit the 'BootParams' group, "BootDev" field. Save a new value with <b>nvupdate</b> . | | | Warning – ISA bridge not initialized,<br>PCI master abort detected | The ISA bridge did not receive one or more initialization commands. Interrupts will be unstable. Report the error to Customer Services <sup>1</sup> . | | | Unexpected Exception at | There are many possible sources for this error. | | | | If the error is displayed during boot, it could mean that autoboot is enabled and invalid parameters are being used. | | | | If the error is displayed at reset or power-up and auto-<br>boot is <i>not</i> enabled, report the error to Customer<br>Services <sup>1</sup> . | | | | If the error is displayed after a command has been executed, an attempt to perform an operation that causes an exception has probably been made. | | | Warning NV memory is invalid - using defaults. | Consult the introduction to this chapter for information about reset conditions. | | <sup>1.</sup> Artesyn Communications Products, 1-800-327-1251. Customer Services email support@artesyncp.com, Test Services email serviceinfo@artesyncp.com. ## 10.13 Monitor Function Reference The BajaPPC-750 monitor functions fall into two groups: BajaPPC-750-specific and standard Artesyn monitor functions. For convenience, related functions are combined in groups under a single name. If you can not find a particular function, please refer to the index for the appropriate page number. **NOTE.** Unlike the monitor commands, no argument checking takes place for functions that are called directly from the command line. The functions require spaces between the function name and its arguments. No parentheses or other punctuation is necessary. #### **EXAMPLES** AtomicAccess a0000000 ConnectHandler f8 1000 # 10.14 BajaPPC-750-Specific Functions This section describes functions which are specific to the BajaPPC monitor implementation. ## 10.14.1 Grackle Read/Write ## **SYNOPSIS** #### **DESCRIPTION** **ReadGrackleCfgb** and **WriteGrackleCfgb** read and write a byte (8 bits) from the MPC106 register specified by *Offset*. **ReadGrackleCfghw** and **WriteGrackleCfghw** read and write a half word (16 bits) from the specified MPC106 register. **ReadGrackleCfgw** and **WriteGrackleCfgw** read and write a long word (32 bits) from the specified MPC106 register. Refer to Table 4-1 and Table 5-1 for lists of the MPC106 registers and their address offsets. ## 10.14.2 Hardware Implementation Dependent Register #### **SYNOPSIS** ``` unsigned long getHID0(void) void setHID0(unsigned long 32-bit) void clrHID0(unsigned long 32-bit) ``` #### **DESCRIPTION** **GetHID0** returns the value of the CPU's Hardware Implementation Dependent register (HID0). Functions **SetHID0** and **CIrHID0** set and clear the bits in HID0. HID0 is described in Section 3.2.1. #### 10.14.3 Miscellaneous ## **SYNOPSIS** ``` unsigned long getMSR(void) void setMSR(unsigned long 32-bit) void clrMSR(unsigned long 32-bit) unsigned long getTBU(void) unsigned long getTBL(void) unsigned long getDEC(void) void setDEC(unsigned long 32-bit) unsigned long getSRRO(void) unsigned long getPVR(void) unsigned long get_dbatu_entry(int batnum) unsigned long get_dbatl_entry(int batnum) ``` #### **DESCRIPTION** The functions **getMSR**, **setMSR**, and **clrMSR** return the value of the Machine State register (MSR). **setMSR** and **clrMSR** either set or clear the bits in the MSR. **getTBU** and **getTBL** return the upper and lower 32-bit Time Base register values, respectively. Functions **getDEC** and **getSRRO** return the value for the appropriate register. **setDEC** writes a value to the decrementer. **getPVR** gets the processor version number. **get\_dbatu\_entry** and **get\_dbatl\_entry** return the upper and lower MMU data block address translation register values, as indexed by 0, 1, 2, and 3. # 10.14.4 Read/Write Configuration #### **SYNOPSIS** #### **DESCRIPTION** The MPC106 defines the address range $FF80,0000_{16}$ to $FFFF,FFFF_{16}$ as 8-bit system ROM space. The monitor's memory commands may not be used to write 32-bit values to the registers in this space because 8-bit access is required. Instead, the function **writew\_bus8** provides the necessary 8-bit access to the space. Functionality is undefined if *Address* is not long-word aligned. NOTE. The MPC106 supports 8-, 16-, and 32-bit reads in the ROM, so *readw\_bus8* is not necessary. However, it is included for compatibility with other Artesyn products. ## 10.14.5 Display Processor Temperature #### **SYNOPSIS** void DisplayTemp(void) #### **DESCRIPTION** **DisplayTemp** successively approximates the processor junction temperature from the Thermal Management Unit. It displays in real time the temperature in degrees Celsius. The resolution of the thermal sensor is 4° C. If the "ThermProtect" NVRAM parameter is enabled and MSR[EE] is not disabled, the monitor puts the processor into permanent sleep mode when the junction temperature exceeds $100^{\circ}$ C. The application can change this behavior at $100^{\circ}$ C by connecting a new interrupt handler to vector $1700_{16}$ . "ThermProtect" is disabled by default. # 10.15 Standard Artesyn Functions This section describes functions which are part of the standard Artesyn monitor implementation. ## 10.15.1 Conversions #### **SYNOPSIS** ``` unsigned long atoh(char *p) unsigned long atod(char *p) unsigned long atoo(char *p) unsigned long atob(char *p) unsigned long atob(char *p, int Base) void BitToHex(unsigned long Val) void HexToBin(unsigned long Val) void FindBitSet(unsigned long Number) ``` #### **DESCRIPTION** These functions are a collection of numeric conversion programs used to convert character strings to numeric values, convert hexadecimal to BCD, BCD to hexadecimal, and to search for bit values. The **atoh** function converts an ASCII string to a hex number. The **atod** function converts an ASCII string to a decimal number. The **atoo** function converts an ASCII string to an octal number. The **atob** function converts an ASCII string to a binary number. The function atoX accepts both the character string p and the numeric base Base to be used in converting the string. This can be used for numeric bases other than the standard bases 16, 10, 8, and 2. The **BinToHex** function converts a binary value to packed nibbles (BCD). The **HexToBin** function converts packed nibbles (BCD) to binary. This function accepts the parameter *Val*, which is assumed to contain a single hex number of value 0-99. The *FindBitSet* function searches the *Number* for the first non-zero bit. The bit position of the least significant non-zero bit is returned. ## 10.15.2 **Booting** #### **SYNOPSIS** BootUp(int PowerUp) #### **DESCRIPTION** The **BootUp** function is called after the nonvolatile memory device has been opened and the board has been configured according to the nonvolatile configuration. This function also determines if memory is to be cleared according to the nonvolatile configuration and the flag *PowerUp*. The monitor provides an autoboot feature that allows an application to be loaded from a variety of devices and executed. This function uses the nonvolatile configuration to determine which device to boot from and calls the appropriate bootstrap program. The monitor supports the ROM, BUS, and SERIAL autoboot devices, which are not hardware-specific. The remainder of the devices may or may not be supported by board-specific functions described elsewhere. Currently, the board-specific devices are SCSI (floppy, disk, and tape) Ethernet, and Stos. #### **ARGUMENTS** The flag *PowerUp* indicates if this function is being called for the first time. If so, memory must be cleared. The BajaPPC-750 clears memory on reset, so *PowerUp* is always true. #### **SEE ALSO** StartMon.c, NvMonDefs.h, NVTable.c, "Boot Commands", Section 10.4. ## 10.15.3 Cache Control ## **SYNOPSIS** ``` void enable_icache(void) void disable_icache(void) void invalidate_icache(void) void enable_dcache(void) void disable_dcache(void) void flush_dcache(void) void invalidate_dcache(void) void flush_L2(void) void L2 on(void) ``` ``` void L2 off(void) ``` #### **DESCRIPTION** As the names indicate, these functions enable, disable, invalidate, and flush the instruction and data caches. The **disable\_dcache** function calls **flush\_dcache** before disabling the data cache. **L2\_off** should not be called until **disable\_dcache** and **flush\_L2** have been executed. ## 10.15.4 MMU Control ## **SYNOPSIS** ``` void mmu_inst_enable(void) void mmu_inst_disable(void) void mmu_data_enable(void) void mmu_data_disable(void) ``` ## **DESCRIPTION** The MMU functions enable or disable instruction and data address translation in the MSR register. # 10.15.5 Baud Rate # **SYNOPSIS** ``` void baud_c(unsigned long baud) void baud_d(unsigned long baud) void ConfigSerDevs(void) ``` ## **DESCRIPTION** The **baud\_c** and **baud\_d** functions set the baud rates for the console and download ports, respectively. The valid baud rate values are 1200, 2400,4800, 9600, 19200, 38400, 56000, and 128000 bps. The **ConfigSerDevs** function uses the current definitions in the nonvolatile memory configuration to configure the serial ports. It is important that the configuration be valid when this function is called, or unpredictable behavior may result. Both serial ports can be configured to use 5 to 8 data bits, 1 or 2 stop bits, the handshake control lines, and odd, even, or no parity. # 10.15.6 Exceptions #### **SYNOPSIS** #### **DESCRIPTION** These processor-specific functions provide interrupt and exception handling support. The lower 2000<sub>16</sub> bytes of memory contain routines, which the processor executes upon receiving an interrupt. These routines comprise the low memory interrupt table. For example, upon receiving a vector 200<sub>16</sub> interrupt, the processor branches to address 200<sub>16</sub> in memory and executes the corresponding interrupt routine. The function *vectinit* initializes these routines in the interrupt table so that they reference an unexpected-interrupt handler. vectinit expects a pointer to the default unexpected-interrupt handler and an optional fixed parameter for the handler. This ensures that the board will not hang upon receiving unexpected interrupts. The unexpected-interrupt handler saves the state of the processor at the point of detection and then calls IntrErr, which displays the error and restarts the monitor. For those applications requiring an interrupt vector to perform only a simple task, vectinit has a third parameter. This parameter, vectmask, specifies which vectors to initialize and which vectors to leave unmodified in low memory. The parameter is a 32-bit value, where each set bit indicates that the corresponding routine should be replaced. For example, if vectmask contains FFFF,FFFE<sub>16</sub>, all 32 vector routines will be overwritten except the routine at address $0_{16}$ . If vectmask contains FFFF,FFF3<sub>16</sub>, all the routines will be overwritten except those at addresses 200<sub>16</sub> and 300<sub>16</sub>. The function **connecthandler** initializes the entry in the vector table to point to the *Handler* address. The argument *Vector* indicates the vector number to be connected and the argument *Handler* is the address of the function that will handle the interrupts. With this structure, assembly language programming for interrupts is avoided. The function *disconnecthandler* modifies the interrupt table entry associated with *Vector* to use the unexpected interrupt handler. It also de-allocates the memory used for the interrupt wrapper allocated by *connecthandler*. Because both *connecthandler* and *disconnecthandler* use the *Malloc* and *Free* facilities, it is necessary for memory management to be initialized. The function **Probe** accesses memory locations that may or may not result in a watchdog timeout or bus error. This function returns TRUE if the location was accessed and FALSE if the access resulted in a bus error. The argument *DirFlag* indicates whether a read (0) or a write (1) should be attempted. The argument *SizeFlag* selects either a byte access (1), a word access (2), or a long access (4). The argument *Address* indicates the address to be accessed, and the argument *Data* is a pointer to the read or write data. ## 10.15.7 Serial I/O ## **SYNOPSIS** ``` unsigned char get_c (void) unsigned char get_d (void) void put_c (unsigned char c) void put_d (unsigned char c) int key_c (void) int key_d (void) int tx_empty (void) int tx_empty_d (void) ``` ## **DESCRIPTION** These functions provide low-level input/output support to read, write, and configure the Ultra I/O controller. These functions interface with both the console and download devices. The **get\_c** and **get\_d** functions read a character from the console or download port, respectively. These functions also check for a break, allowing the monitor to perform a reset or change the baud rate when required. The **put\_c** and **put\_d** functions write the character *c* to the console or download port, respectively. If the character was sent, they return TRUE. If the function times out, they return FALSE. The **key\_c** and **key\_d** functions check for a character on the console or download port, respectively. If a character is available, they return TRUE. If no character is available, they return FALSE. The *tx\_empty* and *tx\_empty\_d* functions determine whether the transmitter is available for sending a character on the console or download port, respectively. If the transmitter is available, they return TRUE; otherwise, they return FALSE. ## 10.15.8 Initialize Board #### **SYNOPSIS** ``` void config_MMU(void) void configSerDevs(void) void ConfigCaches(void) ``` ## **DESCRIPTION** These functions provide initialization of the board's interfaces at various points in the monitor. They use the nonvolatile memory configuration to determine how to configure an interface, so the data structures must contain valid data before the functions are called. The **ConfigBoard** command executes all of these functions. The *config\_MMU* function sets the block address translation registers of the processor. *ConfigSerDevs* sets the console and download serial ports as specified by the NVRAM parameters. *ConfigCaches* initializes the processor caches to be On or Off as defined by the NVRAM parameters. #### 10.15.9 Initialize FIFO ## **SYNOPSIS** ## **DESCRIPTION** These functions provide the necessary interface to initialize, read, and write a software FIFO. The FIFO is used for buffering serial I/O when using transparent mode, but could be used for a variety of applications. All three functions accept a pointer *FPtr* as the first argument to a FIFO management structure. This FIFO structure is described briefly below: ``` struct Fifo { unsigned char *Top; unsigned char *Bottom; int Length; unsigned char *Front; unsigned char *Rear; int Count; } ``` The function *InitFifo* initializes the FIFO control structure specified by *FPtr* to use the unsigned character buffer starting at *StartAddr* that is of size *Length*. The function **ToFifo** writes the byte *c* to the specified FIFO. This function returns TRUE if there is room in the FIFO (before adding *c* to the FIFO), or FALSE if the FIFO is full. The function **FromFifo** reads a byte from the specified FIFO. If a character is available, it is written to the address specified by the pointer *Ptr* and the function returns TRUE. If no character is available, the function returns FALSE. #### 10.15.10 Initialize Ethernet Address #### **SYNOPSIS** void ConfigEthernet(int serialnum) ## **DESCRIPTION** The function *ConfigEthernet* sets the Ethernet address of the board. It combines the decimal serial number with the company code and product ID to form the 6-byte address. When prompted, select the appropriate product name to configure the corresponding ID in the ethernet address. The **EthernetAddr** command displays the current address. # 10.15.11 Interrupts #### **SYNOPSIS** ``` void maskints(void) void unmaskints(void) ``` #### **DESCRIPTION** The functions *unmaskints* and *maskints* are used to enable and disable external interrupts at the processor. # 10.15.12 Interrupt Error #### **SYNOPSIS** void IntrErr(unsigned char Vector) #### **DESCRIPTION** When an unexpected interrupt is received, it is necessary to remove the error condition before returning to the monitor. This function is called from the low-level interrupt service routine, which parses the interrupt record for the address and the vector associated with the interrupt. The device is dealt with accordingly, and the monitor is resumed. Because the interrupt condition might be a program that continually generates exceptions, it is necessary to abort the program and return directly to the monitor level. This is done by calling the function *RestartMon*, which causes the processor to return to the line editor. # 10.15.13 Legal Value Check ## **SYNOPSIS** void IsLegal(unsigned char Type, char \*Str) # **DESCRIPTION** This function is used to determine if the specified character string *Str* contains legal values to allow the string to be parsed as decimal, hex, uppercase, or lowercase. The function *IsLegal* traverses the character string until a NULL is reached. Each character is verified according to the *Type* argument. The effects of specifying each type are described below: Table 10-6. *IsLegal* Function Types | Туре | Value | Legal Characters | |---------|-------|---------------------| | DECIMAL | 0x8 | 0 - 9 | | HEX | 0x4 | 0 - 9, A - F, a - f | | UPPER | 0x2 | A - Z | | LOWER | 0x1 | a - z | | ALPHA | 0x3 | A - Z, a - z | If the character string contains legal characters, this function returns TRUE; otherwise, it returns FALSE. The string equivalent of the character functions isalpha(), isupper(), islower(), and isdigit() can be constructed from this function, which deals with the entire string instead of a single character. # 10.15.14 Memory Management #### **SYNOPSIS** ## **DESCRIPTION** The memory management functions allocate and free memory from a memory pool. The monitor initializes the memory pool to use all on-card memory after the monitor's *bss* section. If any of the autoboot features are used, the memory pool is not initialized and the application program is required to set up the memory pool for these functions. The functions *Malloc*, *Calloc* and *ReAlloc* allocate memory from the memory pool. Each of these functions returns a pointer to the memory requested if the request can be satisfied and NULL if there is not enough memory to satisfy the request. The function *Malloc* accepts one argument *NumBytes* indicating the number of bytes requested. The function *Calloc* accepts two arguments *NumElements* and *Size* indicating a request for a specified number of elements of the specified size. The function *ReAlloc* reallocates a memory block by either returning the block specified by *Block* to the free pool and allocating a new block of size *NumBytes*, or by determining that the memory block specified by *Block* is big enough and returning the same block to be reused. The functions *Free* and *CFree* return blocks of memory that were requested by *Malloc*, *Calloc*, or *ReAlloc* to the free memory pool. The address of the block to be returned is specified by the argument *MemLoc*, which must be the same value returned by one of the allocation functions. An attempt to return memory that was not acquired by the allocation functions is a fairly reliable way of blowing up a program and should be avoided. The function *MemReset* sets the free memory pool to the empty state. This function must be called once for every reset operation and before the memory management facilities can be used. It is also necessary to call this function before every call to *MemAdd*. The function **MemAdd** initializes the free memory pool to use the memory starting at *MemAddr* of size specified by *MemSize*. This function currently allows for only one contiguous memory pool and must be preceded by a function call to **MemReset**. The function *MemStats* monitors memory usage. This function outputs a table showing how much memory is available and how much is used and lost as a result of overhead. ## **SEE ALSO** MemTop, MemBase. ## 10.15.15 Miscellaneous #### **SYNOPSIS** ``` unsigned char *MemTop(void) unsigned char *MemBase(void) ``` #### **DESCRIPTION** This is a collection of miscellaneous board support functions. The functions MemTop and MemBase are used to determine the addresses of the last and first long words in free memory. The size of DRAM is determined by bits DH(0:3) of the Board Configuration register (FF00,0600<sub>16</sub>). The base of free memory is determined by the compiler-created variable End, which indicates the end of the monitor's bss section. # 10.15.16 Artesyn Monitor ## **SYNOPSIS** ``` int NvHkOffset(void) int NvMonOffset(void) int NvMonSize(void) int NvMonAddr(void) ``` #### DESCRIPTION These functions allow the nonvolatile library functions to operate on the nonvolatile memory sections without actually compiling the board configuration files into the library. The **NvHkOffset** and **NvMonOffset** functions describe where in the nonvolatile memory device the Artesyn- and monitor-defined data sections begin. In general, the Artesyn-defined data section and the monitor data section reside in the user-writeable section of the nonvolatile memory device. The returned value is the offset in bytes from the beginning of the device in which the section is loaded. The functions *NvMonSize* and *NvMonAddr* return the size and location of the nonvolatile monitor configuration data structure. This again allows other monitor facilities and application programs to get at the monitor configuration structure without having to know too much about the monitor. # 10.15.17 Support Functions #### **SYNOPSIS** #### **DESCRIPTION** The support functions used for displaying, initializing, and modifying the nonvolatile memory data structures can also be used to manage other data structures that may or may not be stored in nonvolatile memory. The method used to create a display of a data structure is to create a second structure that contains a description of every field of the first structure. This description is done using the NVGroup structure. Each entry in the NVGroup structure describes a field name, pointer to the field, size of the field, indication of how the field is to be displayed, and the initial value of the field. An example data structure is shown below, as well as the NVGroup data structure necessary to describe the data structure. This example might describe the coordinates and depth of a window structure. ``` struct NVExample { NV_Internal Internal; unsigned long XPos, YPos; unsigned short Mag; ``` If passed a pointer to the ExGroups structure, the function **DispGroup** generates the display shown below. The second parameter *EditFlag* indicates whether to allow changes to the data structure after it is displayed (same as in the **nvdisplay** command). ``` Window Display Configuration XPos 100 YPos 200 Magnitude 4 ``` The **SetNvDefaults** function, when called with a pointer to the ExGroup structure, initializes the data structure to those values specified in the NVGroup structure. The second parameter *NumGroups* indicates the number of groups to be initialized. The **NVOp** function stores and recovers data structures from nonvolatile memory. The only requirement of the data structure to be stored in nonvolatile memory is that the first field of the structure be NVInternal, which is where all the bookkeeping for the nonvolatile memory section is done. The first parameter *NVOpCmd* indicates the command to be performed. A summary of the commands is shown in the following table: | <b>Table 10-7. <i>NVOp</i> Comma</b> | ands | |--------------------------------------|------| |--------------------------------------|------| | Command | Value | Description | |-------------|-------|----------------------------------------| | NV_OP_FIX | 0 | Fix nonvolatile section checksum. | | NV_OP_CLEAR | 1 | Clear nonvolatile section. | | NV_OP_CK | 2 | Check if nonvolatile section is valid. | | NV_OP_OPEN | 3 | Open nonvolatile section. | | NV_OP_SAVE | 4 | Save nonvolatile section. | | NV_OP_CMP | 5 | Compare nonvolatile section data. | The second parameter, *Base*, indicates the base address of the data structure to be operated on, and the *Size* parameter indicates the size of the data structure to be operated on. The *Offset* parameter specifies the byte offset in the non-volatile memory device where the data structure is to be stored. An example of how to initialize, store, and recall the example data structure is shown below. ``` NVOp(NV_OP_CLEAR, &NVEx, sizeof(NVEx), 0); NVOp(NV_OP_SAVE, &NVEx, sizeof(NVEx), 0); NVOp(NV_OP_OPEN, &NVEx, sizeof(NVEx), 0); NVOp(NV_OP_FIX, &NVEx, sizeof(NVEx), 0); NVOp(NV_OP_SAVE, &NVEx, sizeof(NVEx), 0); ``` The clear, save, and open operations cause the nonvolatile device to be cleared and filled with the NVEx data structure; then the data structure is filled from nonvolatile memory. The fix and save operation are used to modify the nonvolatile device, which updates the internal data structures and then writes them back to the nonvolatile memory device. If errors are encountered during the check, save, or compare operations, an error message is returned from the function *NVOp*. The error codes are listed below. Table 10-8. NVOp Error Codes | Error | Number | Description | |--------------|--------|------------------------------------------------| | NVE_NONE | 0 | No errors. | | NVE_OVERFLOW | 1 | Nonvolatile device write count exceeded. | | NVE_MAGIC | 2 | Bad magic number read from nonvolatile device. | | NVE_CKSUM | 3 | Bad checksum read from nonvolatile device. | | NVE_STORE | 4 | Write to nonvolatile device failed. | | NVE_CMD | 5 | Unknown operation requested. | | NVE_CMP | 6 | Data does not compare to nonvolatile device. | # **SEE ALSO** NVFields.h. ## 10.15.18 Seed ## **SYNOPSIS** void Seed(unsigned long Value) #### **DESCRIPTION** The *Seed* function sets the initial value for the random number generator command **rand**. # 10.15.19 Serial Support #### **SYNOPSIS** ``` unsigned char getchar (void) void putchar(char c) int KBHit(void) int TxMT(void) void ChBaud(int Baud) ``` #### **DESCRIPTION** The serial support functions defined here provide the ability to read, write, and poll the monitor's console device, which provides the user interface. The serial port is configured at reset according to the nonvolatile memory configuration. The function *getchar* reads characters from the console device. When called, this functions does not return until a character has been received from the serial port. The character read is returned to the function. The function *putchar* writes the character *c* from the console device. If the serial port does not accept the character, the function eventually times out. The function **KBHit** polls the console device for available characters. If the receiver indicates a character is available, this function returns TRUE; otherwise, it returns FALSE. The function *TxMT* polls the console device if the transmitter can accept more characters. If the transmitter indicates a character can be sent, this function returns TRUE; otherwise, it returns FALSE. The function *ChBaud* modifies the console's baud rate. The argument *Baud* specifies the new baud rate to use for the port. Because this function accepts any baud rate, care must be taken to request only those baud rates supported by the terminal. # **SEE ALSO** get\_c, put\_c, key\_c, tx\_empty, baud\_c. # 10.15.20 Unexpected Interrupt Handler #### **SYNOPSIS** SetUnExpIntFunct(unsigned long Funct) #### **DESCRIPTION** If desired, a program can call the **SetUnExpIntFunct** function to attach its own interrupt handler to all unexpected interrupts. This function attaches the handler specified by *Funct*. The new interrupt handler must determine the source of the unexpected interrupt and remove it. # 10.15.21 Strings #### **SYNOPSIS** ``` int CmpStr(char *Str1, char *Str2) int StrCmp(char *Str1, char *Str2) void StrCpy(char *Dest, char *Source) int StrLen(char *Str) void StrCat(char *DestStr, char *SrcStr) ``` ## **DESCRIPTION** These functions provide the basic string manipulation functions necessary to compare, copy, concatenate, and determine the length of strings. The function *CmpStr* compares the two null terminated strings pointed to by *Str1* and *Str2*. If they are equal, it returns TRUE; otherwise, it returns FALSE. Note that this version does not act the same as the UNIX® strcmp function. *CmpStr* is not case-sensitive and only matches characters up to the length of *Str1*. This is useful for pattern matching and other functions. The function **StrCmp** compares the two null terminated strings pointed to by *Str1* and *Str2*. If they are equal, it returns zero; otherwise, it returns the difference between the first two characters in the strings that fail to match (not case-sensitive). Note that this function is not the same as the UNIX **strcmp** function, which is case-sensitive. The function *StrCpy* copies the null terminated string *Source* into the string specified by *Dest*. There are no checks to verify that the string is large enough or is null terminated. The only limit is the monitor-defined constant MAXLN (80), which is the largest allowed string length the monitor supports. The length of the string is returned to the calling function. The function *StrLen* determines the length of the null terminated string *Str* and returns the length. If the length exceeds the monitor defined limit MAXLN, the function returns MAXLN. The function *StrCat* concatenates the string *SrcStr* onto the end of the string *DestStr*. ## 10.15.22 Test Suite #### **SYNOPSIS** ``` void TestSuite(unsigned long BaseAddr, unsigned long TopAddr, int TSPass) void ByteAddrTest (unsigned char *BaseAddr, unsigned char *TopAddr) void WordAddrTest(unsigned short *BaseAddr, unsigned short *TopAddr) void LongAddrTest(unsigned long *BaseAddr, unsigned long *TopAddr) void RotTest(unsigned long *BaseAddr, unsigned long *TopAddr) void PingPongAddrTest(unsigned long BaseAddr, unsigned long TopAddr) void Interact (int Mod, unsigned char *StartAddr, unsigned char *EndAddr) ``` ## **DESCRIPTION** The function **TestSuite** and the memory tests which make up this function verify a memory interface. Each of these functions accepts two arguments *BaseAddr* and *TopAddr* which describe the memory region to be tested. The argument *TSPass* defines the number of passes to perform. Each test and the intended goals of the test are described briefly below. The function *ByteAddrTest* performs a byte-oriented test of the specified memory region. Each location is tested by writing the lowest byte of the location address through the entire memory region and verifying each location. The function **WordAddrTest** performs a word-oriented test of the specified memory region. Each location is tested by writing the lowest word of the location address through the entire memory region and verifying each location. The function *LongAddrTest* performs a long-oriented test of the specified memory region. Each location is tested by writing the location address through the entire memory region and verifying each location. The function **RotTest** performs a long word-oriented test of the specified memory region. Each memory location is tested by rotating a single bit through the long-word location. The function **PingPongAddrTest** is used to test the reliability of memory accesses in an environment where the data addresses are varying widely. The intention is to cause the address buffers and multiplexors to change dramatically. The function *Interact* is used to test byte interaction in the memory region specified by *StartAddr* and *EndAddr*. The main goal of this test is to check for mirrors in memory. This is accomplished by testing the interaction between bytes at different points in memory. ## 10.15.23 Timer #### **SYNOPSIS** ``` void time delay(unsigned long duration) ``` ## **DESCRIPTION** The **time\_delay** function causes a delay of *duration* microseconds. This function makes use of the time base counter on the CPU to generate the delay. ## 10.15.24 Printing ## **SYNOPSIS** #### **DESCRIPTION** This function serves as a System V UNIX®-compatible **printf()** without floating point. It implements all features of %d, %o, %u, %x, %X, %c, and %s. An additional control statement has been added to allow printing of binary values (%b). The **xprintf** and **xsprintf** functions format an argument list according to a control string *CtrlStr*. The function **xprintf** prints the parsed control string to the console, while the function **xsprintf** writes the characters to the *Buffer*. The control string format is a string that contains plain characters to be processed as is, and special characters that are used to indicate the format of the next argument in the argument list. There must be at least as many arguments as special characters, or the function may act unreliably. Special character sequences are started with the character %. The characters after the % can provide information about left or right adjustment, blank and zero padding, argument conversion type, precision, and more things too numerous to list. If detailed information on the argument formats and argument modifiers is required, see your local C programmer's manual for details. Not all of the argument formats are supported. The supported formats are %d, %o, %u, %x, %X, %c, and %s. # Index | A | C | |------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------| | abbreviations for monitor commands 10-13<br>address<br>modifier signal descriptions 6-26<br>space, VMEbus 6-1<br>summary 1-5 | cache CPU memory 3-8 level 2 3-9 certifications 1-6 character arguments for monitor commands 10-14 | | air flow requirements 2-15 | checksum, S-records 10-40 | | ambiguous command, monitor error 10-46 | command reference 10-13 | | arbitration, PCI 5-7 | command-line | | Artesyn identifier, Ethernet 7-3 | editor 10-3 | | AUI 7-5 | history 10-3 | | autoboot 10-8 | interface 10-2 | | cancellation 10-46 | component | | | overview, BajaPPCM 1-1 | | В | configuration<br>groups, NVRAM 10-26 | | D | connectors | | BERR 6-26 | Ethernet 7-5 | | binary format records, downloading 10-37 | overview 2-12 | | block diagram, BajaPPCM 1-3 | PMC J1x 5-10 | | board | PMC J2x 5-11 | | configuration from the monitor 10-44 | serial port A 8-13 | | revision number 2-12 | serial port B 8-14 | | boot | convention in terminology and notation 1-7 | | booting up 2-16, 10-51 | counter/timer 9-1 | | commands 10-14 | count register 9-2 | | device configuration 10-31 | int ack register 9-3 | | booting applications | mode register 9-4 | | from EPROM 10-15, 10-16, 10-17<br>from flash 10-16 | overflow 9-3 | | from ROM 10-16 | period formula 9-2 | | from serial port 10-17 | period register 9-2 | | over a bus interface 10-14 | reset 9-4 | | burst cycles 4-5 | status register 9-2 | | bus interface, VME 6-1 | test command 10-34 | | BUSMODE1*-4* 5-8 | CPU | | byte, terminology 1-7 | cache memory 3-8 | | , | exceptions 3-6<br>features 3-1 | | | initialization 3-2 | | | interrupt handling 3-7 | 0002M621-15 Index-1 | reference manual 1-7 | features | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | reset 3-2 | BajaPPCM 1-1 | | CRT terminal setup 2-16 | CPU 3-1 | | customer support | Ethernet 7-1 | | service 2-18 | ISA bridge 8-1 | | | PMC 5-1 | | | flags | | D | | | D | for memory monitor commands 10-18 | | data transfer | for monitor commands 10-14 | | PCI 5-7 | PASS/FAIL monitor tests 10-34 | | | PASS/FAIL power-up diagnostics 10-7 | | read/write cycle 6-28 | flash memory commands 10-23 | | VMEbus 6-1 | free memory 10-58 | | debug header 3-11 | functional description 1-3 | | defaults, monitor 10-60 | fuse | | diagnostics, power-up 10-1 | Ethernet 7-5 | | double long word, terminology 1-7 | locations 2-11 | | double-width PMC module 5-2 | power route, J1x conn. 5-10 | | download | • | | configuring the serial port 10-33 | power route, J2x conn. 5-11 | | from monitor 10-36 | power route, P1 conn. 6-30 | | DRAM 4-3 | power source 2-15, 5-1 | | controller 4-3 | spare 2-11, 5-1 | | | | | timing 4-4 | | | | G | | F | | | E | grounding 2-1 | | | | | aditar commands manitar 10.2 | | | editor commands, monitor 10-3 | | | EPROM, booting from 10-15, 10-16, 10-17 | Н | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 | Н | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 | H key 10-2 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 | H key 10-2<br>hex-Intel | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 | H key 10-2 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 | H key 10-2<br>hex-Intel<br>file example 10-39 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. | H key 10-2<br>hex-Intel<br>file example 10-39<br>records 10-36, 10-37 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples | H key 10-2<br>hex-Intel<br>file example 10-39 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 | H key 10-2<br>hex-Intel<br>file example 10-39<br>records 10-36, 10-37 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 | H key 10-2<br>hex-Intel<br>file example 10-39<br>records 10-36, 10-37 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 | H key 10-2<br>hex-Intel<br>file example 10-39<br>records 10-36, 10-37 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 / I/O addresses 1-5 controller 8-4 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 / I/O addresses 1-5 controller 8-4 initialization | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 / I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 of nonvolatile memory, caution 10-30 installation | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 F Fast Ethernet address 7-3, 10-45 AUI 7-5 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 of nonvolatile memory, caution 10-30 installation BajaPPCM 2-14, 2-16 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 F Fast Ethernet address 7-3, 10-45 AUI 7-5 cabling considerations 7-6 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 of nonvolatile memory, caution 10-30 installation BajaPPCM 2-14, 2-16 PMC module 5-3 | | EPROM, booting from 10-15, 10-16, 10-17 equipment for setup 2-14 error messages 10-46 ESC key 10-3 ESD prevention 2-1 Ethernet. See Fast Ethernet. examples default boot device 10-31 hex-Intel file 10-39 nvdisplay monitor command 10-29 S-record file 10-42 expansion site, PMC 5-2 extended address record in monitor 10-38 VME 6-25 F Fast Ethernet address 7-3, 10-45 AUI 7-5 | H key 10-2 hex-Intel file example 10-39 records 10-36, 10-37 history of commands, monitor 10-3 I/O addresses 1-5 controller 8-4 initialization error, nonvolatile memory 10-46 of board to defaults 10-55 of counter/timer 9-4 of memory from the monitor 10-13 of nonvolatile memory, caution 10-30 installation BajaPPCM 2-14, 2-16 | Index-2 BajaPPC-750: Index | INTC* 5-9 | compare addresses 10-18 | |-------------------------------|-------------------------------------| | INTD* 5-9 | controller 4-1 | | interrupt | copy 10-19 | | controller PLD 9-1 | destructive test 10-22 | | request, VMEbus 6-27 | display 10-19 | | switch 2-13 | fill with specified value 10-19 | | vectors for CPU 3-7 | flash block write 10-23 | | interrupts | flash byte write 10-23 | | PMC 5-7, 5-9 | flash clear status 10-23 | | VMEbus 6-1 | flash erase block 10-24 | | ISA bridge 8-1 | get configuration 10-45 | | basic operation 8-2 | initializing from the monitor 10-13 | | registers 8-2 | management 10-58 | | ISA bus | map, BajaPPCM 1-4 | | I/O controller 8-4 | map, NVRAM 4-8 | | interface 8-1 | modify 10-21 | | | monitor commands 10-18 | | | nondestructive test 10-21 | | 1 | read 10-20 | | <i>)</i> | rewrite monitor image 10-25 | | j key 10-3 | search 10-20 | | J1x | search for string 10-20 | | PMC pin assignments 5-10 | swap 10-21 | | signal descriptions 5-8 | test failure 10-1 | | J2x | wide flash block write 10-24 | | PMC pin assignments 5-11 | wide flash clear status 10-24 | | signal descriptions 5-8 | wide flash erase block 10-24 | | JTAG/COP interface 3-10 | write 10-22 | | | write ASCII string 10-22 | | V | monitor | | K | autoboot 10-8 | | k key 10-3 | character arguments 10-14 | | keys | command syntax 10-13 | | ESC 10-3 | command-line editor 10-3 | | H 10-2 | command-line history 10-3 | | j 10-3 | command-line interface 10-2 | | k 10-3 | commands. See monitor commands | | | flags 10-14 | | | flash commands 10-23 | | 1 | functions. See monitor functions. | | <b>L</b> | NVRAM commands 10-25 | | LED 2-13 | power-up/reset sequence 10-5 | | long word, terminology 1-7 | typographic conventions 10-14 | | | version number 2-12 | | | monitor commands | | M | add 10-43 | | mailboxes 6-22 | bootbus 10-14 | | | booteprom 10-15, 10-16, 10-17 | | master interface, VMEbus 6-15 | bootflash 10-16 | | mechanical specifications 2-2 | bootrom 10-16 | | memory | bootserial 10-17 | | boot ROM/flash 4-2 | cachetest 10-35 | | checksum 10-18 | call 10-36 | | clearing 10-18 | checksummem 10-18 | 0002M621-15 Index-3 | | | - " | |----|--------------------------------------|-------------------------| | | clearmem 10-18 | Calloc 10-58 | | | cmpmem 10-18 | CFree 10-58 | | | cntrtest 10-34 | ChBaud 10-63 | | | config_PCI 10-45 | clrHID0 10-48 | | | configboard 10-25, 10-44 | clrMSR 10-48 | | | copymem 10-19 | CmpStr 10-64 | | | displaymem 10-19 | config_MMU 10-55 | | | div 10-43 | ConfigCaches 10-55 | | | download 10-37 | ConfigEthernet 10-56 | | | ethernetaddr 10-45 | ConfigSerDevs 10-52 | | | ethertest 10-34 | configSerDevs 10-55 | | | fillmem 10-19 | connecthandler 10-53 | | | findmem 10-20 | disable_dcache 10-51 | | | findnotmem 10-20 | disable_icache 10-51 | | | | | | | findstr 10-20 | disconnecthandler 10-53 | | | flashblkwr 10-23 | DispGroup 10-60 | | | flashbytewrite 10-23 | DisplayTemp 10-49 | | | flashclrstat 10-23 | enable_dcache 10-51 | | | flasheraseblk 10-24 | enable_icache 10-51 | | | getboardconfig 10-45 | FindBitSet 10-50 | | | help 10-45 | flush_dcache 10-51 | | | itctest 10-34 | flush_L2 10-51 | | | mul 10-44 | Free 10-58 | | | nvdisplay 10-16, 10-17, 10-25, 10-34 | FromFifo 10-55 | | | nvinit 10-30 | get_c 10-54 | | | nvopen 10-30 | get_d 10-54 | | | nvramtest 10-35 | get_dbatl_entry 10-48 | | | nvset 10-30 | get_dbatu_entry 10-48 | | | nvupdate 10-16, 10-17, 10-31 | getchar 10-63 | | | rand 10-44 | getDEC 10-48 | | | readmem 10-20 | getHID0 10-48 | | | rewritemonitor 10-25 | getMSR 10-48 | | | serialtest 10-35 | getPVR 10-48 | | | | getSRR0 10-48 | | | setmem 10-21<br>sub 10-44 | 9 | | | | getTBL 10-48 | | | swapmem 10-21 | getTBU 10-48 | | | testmem 10-21 | HexToBin 10-50 | | | um 10-22 | InitFifo 10-55 | | | wideflashblkwr 10-24 | Interact 10-65 | | | wideflashclrstat 10-24 | IntrErr 10-57 | | | wideflasheraseblk 10-24 | invalidate_dcache 10-51 | | | writemem 10-22 | invalidate_icache 10-51 | | | writestr 10-22 | KBHit 10-63 | | mo | nitor functions | key_c 10-54 | | | atob 10-50 | L2_off 10-52 | | | atod 10-50 | L2_on 10-51 | | | atoh 10-50 | LongAddrTest 10-65 | | | atoo 10-50 | Malloc 10-58 | | | atoX 10-50 | maskints 10-56 | | | baud_c 10-52 | MemAdd 10-58 | | | baud_d 10-52 | MemBase 10-59 | | | BitToHex 10-50 | MemReset 10-58 | | | BootUp 10-51 | MemStats 10-58 | | | ByteAddrTest 10-65 | MemTop 10-59 | | | by conduited 10-05 | Wichitop 10-37 | Index-4 BajaPPC-750: Index | mmu_data_disable 10-52 | Misc 10-28, 10-34 | |-------------------------|------------------------------------------| | mmu_data_enable 10-52 | Network 10-28 | | mmu_inst_disable 10-52 | Service 10-29 | | mmu_inst_enable 10-52 | VMEbus 10-26 | | NvHkOffset 10-59 | MPC106 4-1 | | NvMonAddr 10-59 | | | NvMonOffset 10-59 | | | NvMonSize 10-59 | N | | NVOp 10-60 | | | PingPongAddrTest 10-65 | non-burst cycles 4-5 | | Probe 10-53 | nonvolatile memory | | put_c 10-54 | checking 10-30 | | put_d 10-54 | commands 10-25 | | putchar 10-63 | modifying 10-30 | | ReadGrackleCfgb 10-47 | notation conventions 1-7 | | ReadGrackleCfghw 10-47 | number bases for monitor arguments 10-13 | | ReadGrackleCfgw 10-47 | numeric format 10-13 | | readw_bus8 10-49 | NVRAM configuration groups 10-26 | | ReAlloc 10-58 | | | RestartMon 10-57 | | | RotTest 10-65 | O | | Seed 10-62 | operating temperature 2-15 | | setDEC 10-48 | overflow 9-3 | | setHID0 10-48 | Overnow 9-3 | | setMSR 10-48 | | | SetNvDefaults 10-60 | Р | | SetUnExpIntFunct 10-64 | r | | StrCat 10-64 | P1, P2 | | StrCmp 10-64 | signal descriptions 6-25 | | StrCpy 10-64 | parallel port 8-1 | | StrLen 10-64 | PASS/FAIL flags 10-7, 10-34 | | TestSuite 10-65 | PCI | | time_delay 10-66 | bridge initialization 5-6 | | ToFifo 10-55 | bridge to ISA 8-1 | | tx_empty 10-54 | signal descriptions 5-8 | | tx_empty_d 10-54 | slave images 6-12 | | TxMT 10-63 | pin assignments | | unmaskints 10-56 | AUI port 6-33 | | vectinit 10-53 | Ethernet 7-5 | | WordAddrTest 10-65 | J1x, PMC 5-10 | | WriteGrackleCfgb 10-47 | J2x, PMC 5-11 | | WriteGrackleCfghw 10-47 | parallel port 6-33 | | WriteGrackleCfgw 10-47 | PMC connector 5-10 | | writew_bus8 10-49 | serial ports 6-33, 8-13 | | xprintf 10-66 | VMEbus connector 6-28 | | xsprintf 10-66 | PMC | | monitor group | arbitration 5-7 | | BootParams 10-28, 10-31 | connector pin assignments 5-10 | | Cache 10-28 | double-width module 5-2 | | Console 10-26 | expansion sites 5-2 | | Download 10-26 | interface features 5-1 | | HardwareConfig 10-29 | interrupts 5-7, 5-9 | | MailBox 10-27 | module configurations 5-2 | | Manufacturing 10-29 | module initialization 10-45 | 0002M621-15 Index-5 | module installation 5-3, 10-45 | serial number | |---------------------------------------------|----------------------------------| | overview 5-1 | circuit board 2-12 | | pin assignments, J1x 5-10 | operating system 2-12 | | pin assignments, J2x 5-11 | user ROM 2-12 | | single-width module 5-2 | serial ports 8-1 | | power requirements 2-15 | handshaking jumper 8-15 | | power-up | pin assignments 8-13 | | errors 10-46 | SERR* 5-9 | | monitor sequence 10-5 | service 2-18 | | power-up diagnostics 10-1 | setup | | cache test 10-35 | CRT terminal 2-16 | | counter/timer test 10-34 | requirements 2-14 | | Ethernet test 10-34 | seven-segment display 2-13 | | NVRAM test 10-35 | short address, VME 6-25 | | PASS/FAIL flags 10-7 | signal descriptions, PCI | | serial test 10-35 | bus command 5-8 | | precautions 2-14 | BUSMODE1*-4* 5-8 | | product code, Ethernet 7-3 | byte enables 5-8 | | programmable timers 9-1 | clock 5-8 | | | cycle frame 5-9 | | | device select 5-8 | | R | grant 5-9 | | | initialization device select 5-9 | | radix, terminology 1-7 | initiator ready 5-9 | | real-time clock 4-6 | interrupts 5-9 | | configuration registers 4-7 | lock 5-9 | | records | parity 5-9 | | data 10-38, 10-41 | parity error 5-9 | | data count 10-41 | request 5-9 | | end-of-file 10-39 | reset 5-9 | | extended address 10-38 | stop 5-9 | | start address 10-39 | systems error 5-9 | | termination and start address 10-42 | target ready 5-9 | | user defined 10-40 | signal descriptions, VME | | references, manuals, and data books 1-7 | +5V STDBY 6-28 | | register monitor commands 10-18 | AC failure 6-25 | | reset | address modifier 6-26 | | counter/timer 9-4 | address strobe 6-26 | | methods 2-16 | bus busy 6-26 | | monitor sequence 10-5 | bus clear 6-26 | | switch 2-13 | bus error 6-26 | | return merchandise authorization (RMA) 2-18 | bus grant 6-26 | | returning the board to Artesyn 2-18 | bus request 6-26 | | | data bus 6-26 | | r | data strobe 6-26 | | S | data transfer acknowledge 6-26 | | screen messages 10-46 | interrupt acknowledge 6-27 | | SDRAM. See DRAM. | interrupt request 6-27 | | semaphores 6-25 | long word 6-27 | | serial I/O | read/write 6-28 | | control from the monitor 10-63 | system clock 6-27 | | constant the monitor 10 05 | system fail 6-27 | | | system reset 6-27 | | | | Index-6 BajaPPC-750: Index | single-width PMC module 5-2<br>slave | U | |--------------------------------------|-------------------------------------| | interface, VMEbus 6-17 | Ultra 8-4 | | specifications | configuration 8-5 | | environmental 2-15 | Universe | | mechanical 2-13 | control registers 6-2 | | | initialization values 6-7 | | S-records 10-36, 10-37, 10-40 | interrupt channel 6-20 | | file example 10-42 | location monitor 6-24 | | standard address, VME 6-25 | mailboxes 6-22 | | standby power supply 6-28 | | | static control 2-1 | master control register 6-10 | | string format 10-13 | miscellaneous control register 6-11 | | switch, interrupt 2-13 | PCI base address 6-8 | | symbol format 10-13, 10-14 | PCI configuration 6-8 | | synchronous 4-3 | PCI slave images 6-12 | | syntax for monitor commands 10-13 | semaphores 6-25 | | SYSCLK 6-27 | VMEbus master 6-12 | | SYSFAIL* 6-27 | VMEbus slave images 6-13 | | control 6-22 | unpacking 2-16 | | SYSRESET* 2-16, 6-27 | | | system | | | controller, driving SYSCLK 6-27 | V | | controller, VMEbus 6-1, 6-22 | | | fail, VMEbus 6-27 | vi editing commands 10-3 | | reset, VMEbus 6-27 | VMEbus | | • | +5V STDBY 6-28 | | | address space 6-1 | | T | bus priorities 6-26 | | • | connector pin assignments 6-28 | | technical references 1-7 | data transfers 6-1 | | terminology 1-7 | features 6-1 | | test commands | interrupts 6-1 | | PASS/FAIL flags 10-34 | mailboxes 6-1 | | timing, DRAM 4-4 | master images 6-12 | | toggle switch 2-13 | master interface 6-15 | | troubleshooting 2-17 | signal descriptions 6-25 | | typographic conventions 10-14 | slave enables 6-2 | | 71 3 1 | slave images 6-13 | | | slave interface 6-17 | | | system controller 6-1, 6-22 | | | W | | | word, terminology 1-7 | 0002M621-15 Index-7